Upload
yasmmin-cortes-martins
View
6.557
Download
2
Embed Size (px)
Citation preview
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);
}
}