The solution was to write a small PHP script that could be called to build the graphic on the fly. The script is called as the source of an image tag. It expects the following parameters:
Current - Current Amount Raised (eg. 3000)
Goal - Goal Amount (eg. 10000)
Width - Width of the chart in pixels (60 is a good start)
Height - Height of the chart in pixels (150 is a good start)
Font - The font used (1=small, 2=bigger...)
To generate the graph at the right using the above example setting, the script would be called from your html as follows (assuming you have named the script thermometer.php and it's in the same directory as the html file):
This script requires access to a web server that supports PHP and that has the "GD" graphic library installed.
-------- Script Starts Here -------
function thermGraph( $current, $goal, $width, $height, $font ) {
$bar = 0.50;
// create the image
$image = ImageCreate($width, $height);
$bg = ImageColorAllocate($image,255,255,255 );
$fg = ImageColorAllocate($image,255,0,0);
$tx = ImageColorAllocate($image,0,0,0);
// Build background
ImageFilledRectangle($image,0,0,$width,$height,$bg);
// Build bottom bulb
imagearc($image, $width/2, $height-($width/2), $width, $width, 0, 360, $fg);
ImageFillToBorder($image, $width/2, $height-($width/2), $fg, $fg);
// Build "Bottom level
ImageFilledRectangle($image,
($width/2)-(($width/2)*$bar),
$height-$width,
($width/2)+(($width/2)*$bar),
$height-($width/2),
$fg );
// Draw Top Border
ImageRectangle( $image,
($width/2)-(($width/2)*$bar),
0,
($width/2)+(($width/2)*$bar),
$height-$width,
$fg);
// Fill to %
ImageFilledRectangle( $image,
($width/2)-(($width/2)*$bar),
($height-$width) * (1-($current/$goal)),
($width/2)+(($width/2)*$bar),
$height-$width,
$fg );
// Add tic's
for( $k=25; $k<100; $k+=25 ) {
ImageFilledRectangle( $image,
($width/2)+(($width/2)*$bar) -5,
($height-$width) - ($height-$width)*($k/100) -1,
($width/2)+(($width/2)*$bar) -1,
($height-$width) - ($height-$width)*($k/100) +1, $tx );
ImageString($image, $font,
($width/2)+(($width/2)*$bar) +2,
(($height-$width) - ($height-$width)*($k/100)) - (ImageFontHeight($font)/2),
sprintf( "%2d", $k),$tx);
}
// Add % over BULB
$pct = sprintf( "%d%%", ($current/$goal)*100 );
ImageString( $image, $font+2, ($width/2)-((strlen($pct)/2)*ImageFontWidth($font+2)),
($height-($width/2))-(ImageFontHeight($font+2) / 2),
$pct, $bg);
// send the image
header("content-type: image/png");
imagepng($image);
}
thermGraph(
$HTTP_GET_VARS["Current"],
$HTTP_GET_VARS["Goal"],
$HTTP_GET_VARS["Width"],
$HTTP_GET_VARS["Height"],
$HTTP_GET_VARS["Font"] );
?>