ChartDirector 7.0 (PHP Edition)
Multi-Pointer Horizontal Meter
Source Code Listing
<?php
require_once("../lib/phpchartdir.php");
# The values to display on the meter
$value0 = 30.99;
$value1 = 45.35;
$value2 = 77.64;
# Create an LinearMeter object of size 250 x 75 pixels, using silver background with a 2 pixel black
# 3D depressed border.
$m = new LinearMeter(250, 75, silverColor(), 0, -2);
# Set the scale region top-left corner at (15, 25), with size of 220 x 20 pixels. The scale labels
# are located on the top (implies horizontal meter)
$m->setMeter(15, 25, 220, 20, Top);
# Set meter scale from 0 - 100, with a tick every 10 units
$m->setScale(0, 100, 10);
# Set 0 - 50 as green (99ff99) zone, 50 - 80 as yellow (ffff66) zone, and 80 - 100 as red (ffcccc)
# zone
$m->addZone(0, 50, 0x99ff99);
$m->addZone(50, 80, 0xffff66);
$m->addZone(80, 100, 0xffcccc);
# Add deep red (000080), deep green (008000) and deep blue (800000) pointers to reflect the values
$m->addPointer($value0, 0x000080);
$m->addPointer($value1, 0x008000);
$m->addPointer($value2, 0x800000);
# Add a label at bottom-left (10, 68) using Arial Bold/8pt/red (c00000)
$m->addText(10, 68, "Temp C", "Arial Bold", 8, 0xc00000, BottomLeft);
# Add three text boxes to show the values in this meter
$m->addText(148, 70, $m->formatValue($value0, "2"), "Arial", 8, 0x6666ff, BottomRight
)->setBackground(0, 0, -1);
$m->addText(193, 70, $m->formatValue($value1, "2"), "Arial", 8, 0x33ff33, BottomRight
)->setBackground(0, 0, -1);
$m->addText(238, 70, $m->formatValue($value2, "2"), "Arial", 8, 0xff3333, BottomRight
)->setBackground(0, 0, -1);
# Output the chart
$viewer = new WebChartViewer("chart1");
$viewer->setChart($m, SVG);
?>
<!DOCTYPE html>
<html>
<head>
<title>Multi-Pointer Horizontal Meter</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;">
Multi-Pointer Horizontal Meter
</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 is the chart image ****** -->
<?php echo $viewer->renderHTML(); ?>
</body>
</html>