varwidthbar.php
Back to Chart Graphics
addTitle("Energy Generation Breakdown", "Arial Italic", 15);
# Set the plotarea at (60, 60) and of (chart_width - 90) x (chart_height - 100) in size. Use a
# vertical gradient color from light blue (f9f9ff) to sky blue (aaccff) as background. Set grid
# lines to white (ffffff).
$plotAreaBgColor = $c->linearGradientColor(0, 60, 0, $c->getHeight() - 40, 0xaaccff, 0xf9fcff);
$c->setPlotArea(60, 60, $c->getWidth() - 90, $c->getHeight() - 100, $plotAreaBgColor, -1, -1,
0xffffff);
# Add a legend box at (50, 30) using horizontal layout and transparent background.
$c->addLegend(55, 30, false)->setBackground(Transparent);
# Add titles to x/y axes with 10 points Arial Bold font
$c->xAxis->setTitle("Mega Watts", "Arial Bold", 10);
$c->yAxis->setTitle("Cost per MWh (dollars)", "Arial Bold", 10);
# Set the x axis rounding to false, so that the x-axis will fit the data exactly
$c->xAxis->setRounding(false, false);
# In ChartDirector, there is no bar layer that can have variable bar widths, but you may create a
# bar using an area layer. (A bar can be considered as the area under a rectangular outline.) So by
# using a loop to create one bar per area layer, we can achieve a variable width bar chart.
# starting position of current bar
$currentX = 0;
for($i = 0; $i < count($data); ++$i) {
# ending position of current bar
$nextX = $currentX + $widths[$i];
# outline of the bar
$dataX = array($currentX, $currentX, $nextX, $nextX);
$dataY = array(0, $data[$i], $data[$i], 0);
# create the area layer to fill the bar
$layer = $c->addAreaLayer($dataY, $colors[$i], $labels[$i]);
$layer->setXData($dataX);
# Tool tip for the layer
$layer->setHTMLImageMap("", "", "title='" . $labels[$i] . ": " . $widths[$i] . " MW at \$" .
$data[$i] . " per MWh'");
# the ending position becomes the starting position of the next bar
$currentX = $nextX;
}
# Output the chart
$viewer = new WebChartViewer("chart1");
$viewer->setChart($c, SVG);
# Include tool tip for the chart
$viewer->setImageMap($c->getHTMLImageMap(""));
?>
Variable Width Bar Chart
Variable Width Bar Chart
renderHTML(); ?>