ChartDirector 7.0 (PHP Edition)
Square Angular Meters
Source Code Listing
<?php
require_once("../lib/phpchartdir.php");
function createChart($viewer, $chartIndex)
{
# The value to display on the meter
$value = 4.75;
# Create an AugularMeter object of size 110 x 110 pixels, using silver background color with a
# black 2 pixel 3D depressed border.
$m = new AngularMeter(110, 110, silverColor(), 0x000000, -2);
# Set meter appearance according to a parameter
if ($chartIndex == 0) {
# Set the meter center at bottom left corner (15, 95), with radius 85 pixels. Meter spans
# from 90 - 0 degrees.
$m->setMeter(15, 95, 85, 90, 0);
# Add a label to the meter centered at (35, 75)
$m->addText(35, 75, "VDC", "Arial Bold", 12, TextColor, Center);
# Add a text box to show the value at top right corner (103, 7)
$m->addText(103, 7, $m->formatValue($value, "2"), "Arial", 8, 0xffffff, TopRight
)->setBackground(0, 0, -1);
} else if ($chartIndex == 1) {
# Set the meter center at top left corner (15, 15), with radius 85 pixels. Meter spans from
# 90 - 180 degrees.
$m->setMeter(15, 15, 85, 90, 180);
# Add a label to the meter centered at (35, 35)
$m->addText(35, 35, "AMP", "Arial Bold", 12, TextColor, Center);
# Add a text box to show the value at bottom right corner (103, 103)
$m->addText(103, 103, $m->formatValue($value, "2"), "Arial", 8, 0xffffff, BottomRight
)->setBackground(0, 0, -1);
} else if ($chartIndex == 2) {
# Set the meter center at top right corner (15, 95), with radius 85 pixels. Meter spans from
# 270 - 180 degrees.
$m->setMeter(95, 15, 85, 270, 180);
# Add a label to the meter centered at (75, 35)
$m->addText(75, 35, "KW", "Arial Bold", 12, TextColor, Center);
# Add a text box to show the value at bottom left corner (7, 103)
$m->addText(7, 103, $m->formatValue($value, "2"), "Arial", 8, 0xffffff, BottomLeft
)->setBackground(0, 0, -1);
} else {
# Set the meter center at bottom right corner (95, 95), with radius 85 pixels. Meter spans
# from 270 - 360 degrees.
$m->setMeter(95, 95, 85, 270, 360);
# Add a label to the meter centered at (75, 75)
$m->addText(75, 75, "RPM", "Arial Bold", 12, TextColor, Center);
# Add a text box to show the value at top left corner (7, 7)
$m->addText(7, 7, $m->formatValue($value, "2"), "Arial", 8, 0xffffff, TopLeft
)->setBackground(0, 0, -1);
}
# Meter scale is 0 - 10, with a major tick every 2 units, and minor tick every 1 unit
$m->setScale(0, 10, 2, 1);
# Set 0 - 6 as green (99ff99) zone, 6 - 8 as yellow (ffff00) zone, and 8 - 10 as red (ff3333)
# zone
$m->addZone(0, 6, 0x99ff99, 0x808080);
$m->addZone(6, 8, 0xffff00, 0x808080);
$m->addZone(8, 10, 0xff3333, 0x808080);
# Add a semi-transparent black (80000000) pointer at the specified value
$m->addPointer($value, 0x80000000);
# Output the chart
$viewer->setChart($m, SVG);
}
# This example includes 4 charts
$viewers = array();
for ($i = 0; $i < 4; ++$i) {
$viewers[$i] = new WebChartViewer("chart$i");
createChart($viewers[$i], $i);
}
?>
<!DOCTYPE html>
<html>
<head>
<title>Square Angular Meters</title>
<!-- Include ChartDirector Javascript Library to support chart interactions -->
<script type="text/javascript" src="cdjcv.js"></script>
</head>
<body style="margin:5px 0px 0px 5px">
<div style="font:bold 18pt verdana;">
Square Angular Meters
</div>
<hr style="border:solid 1px #000080; background:#000080" />
<div style="font:10pt verdana; margin-bottom:1.5em">
<a href="viewsource.php?file=<?=basename(__FILE__)?>">View Chart Source Code</a>
</div>
<!-- ****** Here are the chart images ****** -->
<?php
for ($i = 0; $i < count($viewers); ++$i) {
echo $viewers[$i]->renderHTML(), " ";
}
?>
</body>
</html>