<cfscript>
// ChartDirector for ColdFusion API Access Point
cd = CreateObject("java", "ChartDirector.CFChart");
// A utility to allow us to create arrays with data in one line of code
function Array() {
var result = ArrayNew(1);
var i = 0;
for (i = 1; i LTE ArrayLen(arguments); i = i + 1)
result[i] = arguments[i];
return result;
}
// The data for the chart
data = Array(51, 15, 51, 40, 17, 87, 94, 21, 35, 88, 50, 60);
// The labels for the chart
labels = Array("Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sept", "Oct", "Nov", "Dec");
// Create a PolarChart object of size 400 x 420 pixels
c = cd.PolarChart(400, 420);
// Set background color to a 2 pixel pattern color, with a black border and 1 pixel 3D border effect
c.setBackground(c.patternColor(Array("0xffffff", "0xe0e0e0"), 2), 0, 1);
// Add a title to the chart using 16pt Arial Bold Italic font. The title text is white (0xffffff) on
// 2 pixel pattern background
c.addTitle("Chemical Concentration", "Arial Bold Italic", 16, "0xffffff").setBackground(
c.patternColor(Array("0x000000", "0x000080"), 2));
// Set center of plot area at (200, 240) with radius 145 pixels. Set background color to blue
// (9999ff)
c.setPlotArea(200, 240, 145, "0x9999ff");
// Color the region between radius = 40 to 80 as green (99ff99)
c.radialAxis().addZone(40, 80, "0x99ff99");
// Color the region with radius > 80 as red (ff9999)
c.radialAxis().addZone(80, 999, "0xff9999");
// Set the grid style to circular grid
c.setGridStyle(False);
// Set the radial axis label format
c.radialAxis().setLabelFormat("{value} ppm");
// Use semi-transparent (40ffffff) label background so as not to block the data
c.radialAxis().setLabelStyle().setBackground("0x40ffffff", "0x40000000");
// Add a legend box at (200, 30) top center aligned, using 9pt Arial Bold font. with a black border.
legendBox = c.addLegend(200, 30, False, "Arial Bold", 9);
legendBox.setAlignment(cd.TopCenter);
// Add legend keys to represent the red/green/blue zones
legendBox.addKey("Under-Absorp", "0x9999ff");
legendBox.addKey("Normal", "0x99ff99");
legendBox.addKey("Over-Absorp", "0xff9999");
// Add a blue (000080) spline line layer with line width set to 3 pixels and using yellow (ffff00)
// circles to represent the data points
layer = c.addSplineLineLayer(data, "0x000080");
layer.setLineWidth(3);
layer.setDataSymbol(cd.CircleShape, 11, "0xffff00");
// Set the labels to the angular axis as spokes.
c.angularAxis().setLabels(labels);
// Output the chart
chart1URL = c.makeSession(GetPageContext(), "chart1");
// Include tool tip for the chart.
imageMap1 = layer.getHTMLImageMap("", "", "title='Concentration on {label}: {value} ppm'");
</cfscript>
<html>
<body style="margin:5px 0px 0px 5px">
<div style="font-size:18pt; font-family:verdana; font-weight:bold">
Circular Zones
</div>
<hr style="border:solid 1px #000080" />
<cfoutput>
<div style="font-size:9pt; font-family:verdana; margin-bottom:1.5em">
<a href='viewsource.cfm?file=#CGI.SCRIPT_NAME#'>View Source Code</a>
</div>
<img src="getchart.cfm?#chart1URL#" usemap="##map1" border="0" />
<map name="map1">#imageMap1#</map>
</cfoutput>
</body>
</html> |