Você está na página 1de 7

Tutorial – JFreeChart

1) Baixar os pacotes necessários

Vá no site http://sourceforge.net/projects/jfreechart/files/, depois clique em JCommon, escolha


a versão desejada e depois escolha o tipo de extensão de compactação, ou seja, “.zip” se
você está trabalhando no Windows ou “.tar.gz” se for no Linux. E salve ele em um local
acessível.

Depois vá no site http://sourceforge.net/projects/jfreechart/files/, novamente, e desta vez


clique em JFreeChart, escolha a versão desejada, de preferência, a mesma versão do
JCommon baixado anteriormente, e depois escolha o tipo de extensão de compactação, ou
seja, “.zip” se você está trabalhando no Windows ou “.tar.gz” se for no Linux. E salve ele em
um local acessível.

2) Obtendo as pastas necessárias para fazer o gráfico

Descompacte o JCommon e o JFreeChart baixados.

Dentro de “jcommon-<versão>” irão aparecer: uma pasta como nome de ”jcommon-


<versão>”, dentro dela várias outras, dentre estas, clique na de nome “source”, e depois
clique na de nome “org”. Dentro de “org” tem outra pasta chamada ”jfree”, e dentro desta
estão as pastas: “chart” e “data”.

Dentro de “jfreechart-<versão>” irão aparecer: uma pasta como nome de ”jfreechart-


<versão>”, dentro dela várias outras, dentre estas clique na de nome “source”, e copie a
pasta “org” para fora da pasta raiz. Dentro de “org” tem outra pasta chamada ”jfree”, e
dentro desta estão vária spastas e alguns arquivos, selecione todos eles e copie para dentro
da pasta “org” que foi retirada da pasta raiz antes.

3) Colocando a pasta “org” preparada anteriormente no eclipse

Vá no(s) projeto(s) em que você for usar o gráfico, e dentro de “src”, crie um pacote como
nome “org”, agora vá no local onde está a pasta “org”, e arraste a pasta “jfree” que está
dentro desta para o pacote “org” criado no eclipse. Pronto, já pode-se utilizar os métodos do
jfreechart para fazer os gráficos.

4) Exemplo básico de gráfico de barras com código comentado.


package p;

import java.awt.Color;

import org.jfree.chart.ChartFactory;

import org.jfree.chart.ChartPanel;

import org.jfree.chart.JFreeChart;

import org.jfree.chart.axis.AxisLocation;

import org.jfree.chart.axis.NumberAxis3D;

import org.jfree.chart.axis.ValueAxis;

import org.jfree.chart.plot.CategoryPlot;

import org.jfree.chart.plot.DatasetRenderingOrder;

import org.jfree.chart.plot.PlotOrientation;

import org.jfree.chart.renderer.category.CategoryItemRenderer;

import org.jfree.chart.renderer.category.LineAndShapeRenderer;

import org.jfree.data.category.CategoryDataset;

import org.jfree.data.category.DefaultCategoryDataset;

import org.jfree.ui.ApplicationFrame;

import org.jfree.ui.RefineryUtilities;

/**

* A simple demonstration application showing how to create a dual axis chart based on
data

* from two {@link CategoryDataset} instances.

*/

public class Teste_grafico_aux_imp extends ApplicationFrame {

/**

*/

private static final long serialVersionUID = 1L;


public Teste_grafico_aux_imp() {

super("Grafico teste");

// TODO Auto-generated constructor stub

final CategoryDataset dataset1 = createDataset1();

// create the chart...

final JFreeChart chart = ChartFactory.createBarChart3D(

"Média de idades - Escola joão paulo I", // este é título do gráfico

"Turmas", // Título do eixo x

"Média_idade", // Título do eixo y

dataset1, // são as informações inerentes a cada barra que vai ser criada na
função abaixo

PlotOrientation.VERTICAL, //coloca as barras na posição vertical

true, // include legend

true,

false

);

// NOW DO SOME OPTIONAL CUSTOMISATION OF THE CHART...

// set the background color for the chart...

chart.setBackgroundPaint(new Color(0xCC, 0xFF, 0xCC));

// chart.getLegend().setAnchor(Legend.SOUTH);

// get a reference to the plot for further customisation...

final CategoryPlot plot = chart.getCategoryPlot();

plot.setDomainAxisLocation(AxisLocation.BOTTOM_OR_LEFT);

plot.setRangeAxisLocation(AxisLocation.TOP_OR_LEFT);

final CategoryItemRenderer renderer1 = plot.getRenderer();


renderer1.setSeriesPaint(0, Color.blue);

renderer1.setSeriesPaint(1, Color.yellow);

renderer1.setSeriesPaint(2, Color.green);

//final CategoryDataset dataset2 = createDataset2();

//final ValueAxis axis2 = new NumberAxis3D("Secondary");

//plot.setRangeAxis(1, axis2);

//plot.setDataset(1, dataset2);

//final CategoryItemRenderer renderer2 = new LineAndShapeRenderer();

//renderer2.setSeriesPaint(0, Color.blue);

//plot.setRenderer(1, renderer2);

plot.mapDatasetToRangeAxis(1, 1);

plot.setDatasetRenderingOrder(DatasetRenderingOrder.REVERSE);

// OPTIONAL CUSTOMISATION COMPLETED.

// add the chart to a panel...

final ChartPanel chartPanel = new ChartPanel(chart);

chartPanel.setPreferredSize(new java.awt.Dimension(500, 270));

setContentPane(chartPanel);

private CategoryDataset createDataset1() {

// esta função serve para formar o dataset, que é a arrumação dos dados no gráfico

//series é cada barra de cor diferente no gráfico

// definindo o nome das barras abaixo

final String series1 = "1º ano";

final String series2 = "2º ano";

final String series3 = "3º ano";


final String series4 = "4º ano";

final String series5 = "5º ano";

final String series6 = "6º ano";

final String series7 = "7º ano";

final String series8 = "8º ano";

// definindo a categoria (o nome do eixo x do gráfico) a que pertencem estas barras

final String category1 = "Categoria turmas";

// definindo o valor correspondente a cada barra e a cada categoria.

final DefaultCategoryDataset dataset = new DefaultCategoryDataset();

dataset.addValue(8.0, series1, category1);

dataset.addValue(10.0, series2, category1);

dataset.addValue(12.0, series3, category1);

dataset.addValue(13.0, series4, category1);

dataset.addValue(16.0, series5, category1);

dataset.addValue(17.0, series6, category1);

dataset.addValue(18.0, series7, category1);

dataset.addValue(20.0, series8, category1);

return dataset;

/**

* Creates a sample dataset.

* @return The dataset.

*/

/*
* Esta parte comentada é para fazer um gráfico de linhas mas segue o mesmo princípio
do de barras

private CategoryDataset createDataset2() {

// row keys...

final String series1 = "Fourth";

// column keys...

final String category1 = "Category 1";

final String category2 = "Category 2";

final String category3 = "Category 3";

final String category4 = "Category 4";

final String category5 = "Category 5";

// create the dataset...

final DefaultCategoryDataset dataset = new DefaultCategoryDataset();

dataset.addValue(15.0, series1, category1);

dataset.addValue(24.0, series1, category2);

dataset.addValue(31.0, series1, category3);

dataset.addValue(25.0, series1, category4);

dataset.addValue(56.0, series1, category5);

return dataset;

}*/

/**

* Starting point for the demonstration application.

* @param args ignored.

*/
public static void main(final String[] args) {

//instanciando um objeto desta classe para poder utilizar os métodos de geração do


gráfico

final Teste_grafico_aux_imp demo = new Teste_grafico_aux_imp();

//colocando todas as propriedades do gráfico juntas

demo.pack();

//colocando o gráfico no centro da tela

RefineryUtilities.centerFrameOnScreen(demo);

//deixando o gráfico visível

demo.setVisible(true);