Version 8.3.4
 —  Special Development Topics  —

Creating Statistical Charts

This document covers the following topics:


Structure

The creation of statistical charts is done by a library that is part of the Application Designer library.

Structure

The library offers an API in which you pass the data to be rendered into a chart. It interprets the data and creates an SVG (scalable vector graphics) string out of it. This SVG string can be directly passed back to the calling application.

In addition, the SVG string can be rendered into a JPEG image. Internally, the Apache batik.jar is used for this purpose.

When should you use which format?

The chart library in principle is a self-containing library, packaged into the cis.jar. The result can be flexibly used inside Application Designer.

Top of page

Class com.softwareag.cis.chart.CHARTInfo

The class CHARTInfo is the central class for creating charts. See the Java API documentation. The infomation below will only provide an example of how to use this library.

Top of page

Creating a Simple Chart

The following chart will be created:

graphics/image195.png

Let us take a look at the Java program that creates the chart:

private void renderChart()
{
     CHARTInfo chart = buildChart();
     String svg = chart.getSVGBarChart();
}
private CHARTInfo buildChart()
{
    // CHARTInfo chart = new CHARTInfo("300","300"); // width/height
    // set descriptions
    chart.setXAxisDescription("Region","#000000");
    chart.setYAxisDescription("Month","#000000");
    // Define x-axis
    chart.addXAxisScale("North");
    chart.addXAxisScale("Central");
    chart.addXAxisScale("South");
    // Define "value lines"		
    chart.addDataDescription("January","#FF0000");
    chart.addDataDescription("February","#00FF00");
    // Define values
    chart.addData("North","January",100);
    chart.addData("Central","January",200);
    chart.addData("South","January",300);
    chart.addData("North","February",300);
    chart.addData("Central","February",200);
    chart.addData("South","February",100);
    return chart;
}

The program is split into two methods: one method (buildChart) fills a CHARTInfo object with data. The other method (renderChart) takes the result and triggers the output of the SVG information.

First have a look at the buildChart() method:

At the end, the chart information is logically filled.

The rendering is triggered at the point of time when accessing the CHARTInfo's getSVG*() or getJPEG*() methods. This is done in the example's renderChart() method. For each type of graphic, you have a different method.

Examples:

The SVG methods return an SVG string. There are corresponding other methods that return a JPEG file.

Top of page

Setting the Scale of the y-Axis

If the scale of the y-axis is not specified explicitly, the scale will be calculated automatically:

You can also set the scale on your own.

graphics/image201.png

To do so, use the following method:

chart.setYAxisDimension(90,350);

The system will still try to find optimal interim scale values. However, you also can set the y-scale completely on your own:

graphics/image202.png

The code for doing so is:

chart.addYAxisScale(95,"#FF0000");
chart.addYAxisScale(175,"#00FF00");

Top of page