JFreeChart簡單介紹及入門實例
今天下午什么都沒做,就搞了兩個例子,一個是針對Application開發(fā)的,另一個是針對Web開發(fā)的。當然我是剛剛學習這東西,在所難免要借某些同仁的作品參考,在這里要特別謝謝日月星辰的作者。同時也要感謝來了,就好!的作者。
一、JFreeChart獲取。
JFreeChart是JFreeChart公司在開源網(wǎng)站SourceForge.net上的一個項目,該公司的主要產(chǎn)品有如下:
1、JFreeReport:報表解決工具
2、JFreeChart:Java圖形解決方案(Application/Applet/Servlet/Jsp)
3、JCommon:JFreeReport和JFreeChart的公共類庫
4、JFreeDesigner:JFreeReport的報表設(shè)計工具
我們可以從jfree官方網(wǎng)站上獲取***版本和相關(guān)資料(但是jfree的document需要40美金才能獲?。@取地址:http://www.jfree.org/jfreechart/index.html(同時可以獲得簡明介紹)
我們以當前***版本:jfreechart_0.9.21.zip為例子進行說明。
二、JFreeChart配置安裝
1、解壓jfreechart_0.9.21.zip到指定位置,其中source是jfreechart的源碼,jfreechart-0.9.21-demo.jar是例子程序(該部分留給大家自己去研究)
2、為了配置成功,我們需要關(guān)注的文件有如下三個:jfreechart-0.9.21.jar、libjcommon-0.9.6.jar、libgnujaxp.jar
3、如果是Application開發(fā),把上述三個文件拷貝到%JAVA_HOME%LIB中,同時在環(huán)境變量CLASSPATH中加入如果是WEB開發(fā),以TOMCAT中的一個WEB項目TEST為例子說明:
把上述三個文件拷貝到TESTWEB-INFLIB中,然后修改TESTWEB-INFweb.xml文件,在其中加入如下代碼:
- <servlet>
 - <servlet-name>DisplayChart</servlet-name>
 - <servlet-class>org.jfree.chart.servlet.DisplayChart</servlet-class>
 - </servlet>
 - <servlet-mapping>
 - <servlet-name>DisplayChart</servlet-name>
 - <url-pattern>/servlet/DisplayChart</url-pattern>
 - </servlet-mapping>
 
至此jfreechart的配置就完成了,下面就可以進行jfreechart的開發(fā)了。這里值得提出的是jfreechart的類結(jié)構(gòu)設(shè)計前后兼容性不是很好,不同版本的jfreechart中類庫結(jié)構(gòu)可能不一樣,有時候可能需要查源碼。如果是中文顯示的時候可能依據(jù)觀感需要改變源碼的字體,不過我個人覺得這個版本比以前版本要好一些。
三、JFreeChart功能介紹
JFreeChart目前是***的java圖形解決方案,基本能夠解決目前的圖形方面的需求,主要包括如下幾個方面:
pie charts (2D and 3D):餅圖(平面和立體)
bar charts (regular and stacked, with an optional 3D effect):柱狀圖
line and area charts:曲線圖
scatter plots and bubble charts time series, high/low/open/close charts and candle stick charts:時序圖
combination charts:復合圖
Pareto charts Gantt charts:甘特圖
wind plots, meter charts and symbol charts wafer map charts
(態(tài)圖表,餅圖(二維和三維) , 柱狀圖 (水平,垂直),線圖,點圖,時間變化圖,甘特圖, 股票行情圖,混和圖, 溫度計圖, 刻度圖等常用商用圖表)
圖形可以導出成PNG和JPEG格式,同時還可以與PDF和EXCEL關(guān)聯(lián)。
JFreeChart核心類庫介紹:
研究jfreechart源碼發(fā)現(xiàn)源碼的主要由兩個大的包組成:org.jfree.chart,org.jfree.data。其中前者主要與圖形本身有關(guān),后者與圖形顯示的數(shù)據(jù)有關(guān)。具體研究如果大家有興趣的話可以自己研究,以后有時間我會告訴大家怎么去研究源碼。
核心類主要有:
org.jfree.chart.JFreeChart:圖表對象,任何類型的圖表的最終表現(xiàn)形式都是在該對象進行一些屬性的定制。JFreeChart引擎本身提供了一個工廠類用于創(chuàng)建不同類型的圖表對象
org.jfree.data.category.XXXDataSet:數(shù)據(jù)集對象,用于提供顯示圖表所用的數(shù)據(jù)。根據(jù)不同類型的圖表對應(yīng)著很多類型的數(shù)據(jù)集對象類
org.jfree.chart.plot.XXXPlot:圖表區(qū)域?qū)ο螅旧线@個對象決定著什么樣式的圖表,創(chuàng)建該對象的時候需要Axis、Renderer以及數(shù)據(jù)集對象的支持
org.jfree.chart.axis.XXXAxis:用于處理圖表的兩個軸:縱軸和橫軸
org.jfree.chart.render.XXXRender:負責如何顯示一個圖表對象
org.jfree.chart.urls.XXXURLGenerator:用于生成Web圖表中每個項目的鼠標點擊鏈接
XXXXXToolTipGenerator:用于生成圖象的幫助提示,不同類型圖表對應(yīng)不同類型的工具提示類
四、JFreeChart開發(fā)(Application/Applet)
1、居于Application的開發(fā),pie charts,代碼如下:
- /**
 - * Description:This application is the first jfreechart
 - * Datetime:20058-02-11
 - */
 - package demo;
 - import org.jfree.chart.JFreeChart;
 - import org.jfree.chart.ChartFactory;
 - import org.jfree.chart.ChartFrame;
 - import org.jfree.data.general.DefaultPieDataset;
 - public class FirstJFreeChart {
 - public FirstJFreeChart() {
 - }
 - public static void main(String[] args){
 - DefaultPieDataset dpd = new DefaultPieDataset();
 - dpd.setValue("管理人員",25);
 - dpd.setValue("市場人員",25);
 - dpd.setValue("開發(fā)人員",45);
 - dpd.setValue("其他人員",5);
 - //Create JFreeChart object
 - //參數(shù)可以查看源碼
 - JFreeChart pieChart = ChartFactory.createPieChart("CityInfoPort公司組織架構(gòu)圖",dpd,true,true,false);
 - ChartFrame pieFrame = new ChartFrame("CityInfoPort公司組織架構(gòu)圖",pieChart);
 - pieFrame.pack();
 - pieFrame.setVisible(true);
 - }
 - }
 
上面例子可以進一步改進,如下:
- /**
 - * Description:This application is the first jfreechart
 - * Datetime:20058-02-11
 - */
 - package com.cityinforport.demo;
 - import org.jfree.chart.JFreeChart;
 - import org.jfree.chart.ChartPanel;
 - import org.jfree.chart.ChartFactory;
 - import org.jfree.chart.ChartFrame;
 - import org.jfree.data.general.DefaultPieDataset;
 - import org.jfree.chart.plot.PiePlot;
 - import org.jfree.data.general.PieDataset;
 - import org.jfree.ui.ApplicationFrame;
 - import org.jfree.ui.RefineryUtilities;
 - import java.awt.Font;
 - import javax.swing.*;
 - public class FirstJFreeChart extends ApplicationFrame {
 - //構(gòu)造函數(shù)
 - public FirstJFreeChart(String s){
 - super(s);
 - setContentPane(createDemoPanel());
 - }
 - public static void main(String[] args){
 - FirstJFreeChart fjc = new FirstJFreeChart("CityInfoPort公司組織架構(gòu)圖");
 - fjc.pack();
 - RefineryUtilities.centerFrameOnScreen(fjc);
 - fjc.setVisible(true);
 - }
 - //生成餅圖數(shù)據(jù)集對象
 - public static PieDataset createDataset(){
 - DefaultPieDataset defaultpiedataset = new DefaultPieDataset();
 - defaultpiedataset.setValue("管理人員",10.02D);
 - defaultpiedataset.setValue("市場人員",20.23D);
 - defaultpiedataset.setValue("開發(fā)人員",60.02D);
 - defaultpiedataset.setValue("OEM人員",10.02D);
 - defaultpiedataset.setValue("其他人員",5.11D);
 - return defaultpiedataset;
 - }
 - //生成圖表主對象JFreeChart
 - public static JFreeChart createChart(PieDataset piedataset){
 - //定義圖表對象
 - JFreeChart jfreechart = ChartFactory.createPieChart("CityInfoPort公司組織架構(gòu)圖",piedataset,true,true,false);
 - //獲得圖表顯示對象
 - PiePlot pieplot = (PiePlot)jfreechart.getPlot();
 - //設(shè)置圖表標簽字體
 - pieplot.setLabelFont(new Font("SansSerif",Font.BOLD,12));
 - pieplot.setNoDataMessage("No data available");
 - pieplot.setCircular(true);
 - pieplot.setLabelGap(0.01D);//間距
 - return jfreechart;
 - }
 - //生成顯示圖表的面板
 - public static JPanel createDemoPanel(){
 - JFreeChart jfreechart = createChart(createDataset());
 - return new ChartPanel(jfreechart);
 - }
 - }
 
2.居于Web的開發(fā),這里特別要聲明,要把jfreechart-0.9.21.jar、libjcommon-0.9.6.jar、libgnujaxp.jar這三個文件放入WEB-INF\lib里面去,OK,下面就來看看這個例子吧。
 
- <%@ page contentType="text/html;charset=GBK"%>
 - <%@ page import="org.jfree.data.general.DefaultPieDataset"%>
 - <%@ page import="org.jfree.chart.JFreeChart"%>
 - <%@ page import="org.jfree.chart.plot.PiePlot"%>
 - <%@ page import="org.jfree.chart.ChartRenderingInfo"%>
 - <%@ page import="org.jfree.chart.servlet.ServletUtilities"%>
 - <%@ page import="org.jfree.chart.urls.StandardPieURLGenerator"%>
 - <%@ page import="org.jfree.chart.entity.StandardEntityCollection"%>
 - <%@ page import="org.jfree.chart.encoders.SunPNGEncoderAdapter"%>
 - <%
 - DefaultPieDataset data = new DefaultPieDataset();
 - data.setValue("六月", 500);
 - data.setValue("七月", 580);
 - data.setValue("八月", 828);PiePlot plot = new PiePlot(data);
 - JFreeChart chart = new JFreeChart("", JFreeChart.DEFAULT_TITLE_FONT, plot, true);
 - chart.setBackgroundPaint(java.awt.Color.white); //可選,設(shè)置圖片背景色
 - chart.setTitle("Welcome to Jfreechart !"); //可選,設(shè)置圖片標題
 - ChartRenderingInfo info = new ChartRenderingInfo(new StandardEntityCollection());
 - //500是圖片長度,300是圖片高度
 - String filename = ServletUtilities.saveChartAsPNG(chart, 500, 300, info, session);
 - String graphURL = request.getContextPath() + "/servlet/DisplayChart?filename=" + filename;
 - %>
 - <HTML>
 - <HEAD>
 - <TITLE>Welcome to Jfreechart !</TITLE>
 - </HEAD>
 - <BODY>
 - <P ALIGN="CENTER">
 - <img src="<%= graphURL %>" width=500 height=300 border=0 usemap="#<%= filename %>">
 - </P>
 - </BODY>
 - </HTML>
 
原文鏈接:http://www.cnblogs.com/yy2011/archive/2011/04/13/2015240.html
【編輯推薦】















 
 
 

 
 
 
 