Blame view

site/jpgraph/Examples/odoex07.php 5.24 KB
8ec98c9f   Guillaume   MAJ
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
  <?php
  //=============================================================================
  // File:	ODOEX07.PHP
  // Description: Example 1 for odometer graphs
  // Created:	2002-02-22
  // Version:	$Id$
  // 
  // Comment:
  // Example file for odometer graph. This examples extends odoex06
  // by changing the start and end angles for the scale.
  //
  // Copyright (C) 2002 Johan Persson. All rights reserved.
  //=============================================================================
  require_once ('jpgraph/jpgraph.php');
  require_once ('jpgraph/jpgraph_odo.php');
  
  //---------------------------------------------------------------------
  // Create a new odometer graph (width=250, height=200 pixels)
  //---------------------------------------------------------------------
  $graph = new OdoGraph(250,250);
  
  //---------------------------------------------------------------------
  // Change the color of the odometer plotcanvas. NOT the odometer
  // fill color itself.
  //---------------------------------------------------------------------
  $graph->SetColor("lightyellow");
  
  //---------------------------------------------------------------------
  // Specify title and subtitle using default fonts
  // * Note each title may be multilines by using a '\n' as a line
  // divider.
  //---------------------------------------------------------------------
  $graph->title->Set("Odometer title");
  $graph->title->SetColor("white");
  $graph->subtitle->Set("2002-02-13");
  $graph->subtitle->SetColor("white");
  
  //---------------------------------------------------------------------
  // Specify caption.
  // * (This is the text at the bottom of the graph.) The margins will
  // automatically adjust to fit the height of the text. A caption
  // may have multiple lines by including a '\n' character in the 
  // string.
  //---------------------------------------------------------------------
  $graph->caption->Set("First caption row\n... second row");
  $graph->caption->SetColor("white");
  
  //---------------------------------------------------------------------
  // Now we need to create an odometer to add to the graph.
  // By default the scale will be 0 to 100
  //---------------------------------------------------------------------
  $odo = new Odometer(ODO_FULL); 
  
  //---------------------------------------------------------------------
  // Set color indication 
  //---------------------------------------------------------------------
  $odo->AddIndication(0,50,"green");
  $odo->AddIndication(50,80,"yellow");
  $odo->AddIndication(80,100,"red");
  
  //---------------------------------------------------------------------
  // Set the center area that will not be affected by the color bands
  //---------------------------------------------------------------------
  $odo->SetCenterAreaWidth(0.4);  // Fraction of radius
  
  //---------------------------------------------------------------------
  // Adjust scale ticks to be shown at 10 steps interval and scale
  // labels at every second tick
  //---------------------------------------------------------------------
  $odo->scale->SetTicks(10,2);
  
  //---------------------------------------------------------------------
  // Make the tick marks 2 pixel wide
  //---------------------------------------------------------------------
  $odo->scale->SetTickWeight(2);
  
  //---------------------------------------------------------------------
  // Use a bold font for tick labels
  //---------------------------------------------------------------------
  $odo->scale->label->SetFont(FF_FONT1, FS_BOLD);
  
  //---------------------------------------------------------------------
  // Change the start and end angle for the scale
  //---------------------------------------------------------------------
  $odo->scale->SetAngle(20,340);
  
  //---------------------------------------------------------------------
  // Set display value for the odometer
  //---------------------------------------------------------------------
  $odo->needle->Set(64);
  
  //---------------------------------------------------------------------
  // Specify scale caption. Note that depending on the position of the
  // indicator needle this label might be partially hidden. 
  //---------------------------------------------------------------------
  $odo->label->Set("% Passed");
  
  //---------------------------------------------------------------------
  // Set a new style for the needle
  //---------------------------------------------------------------------
  $odo->needle->SetStyle(NEEDLE_STYLE_MEDIUM_TRIANGLE);
  $odo->needle->SetLength(0.7);  // Length as 70% of the radius
  $odo->needle->SetFillColor("orange");
  
  //---------------------------------------------------------------------
  // Setup the second indicator needle
  //---------------------------------------------------------------------
  $odo->needle2->Set(15);
  $odo->needle2->SetStyle(NEEDLE_STYLE_SMALL_TRIANGLE);
  $odo->needle2->SetLength(0.55);  // Length as 70% of the radius
  $odo->needle2->SetFillColor("lightgray");
  $odo->needle2->Show();  
  
  
  //---------------------------------------------------------------------
  // Add the odometer to the graph
  //---------------------------------------------------------------------
  $graph->Add($odo);
  
  //---------------------------------------------------------------------
  // ... and finally stroke and stream the image back to the browser
  //---------------------------------------------------------------------
  $graph->Stroke();
  
  // EOF
  ?>