今天下午什么都没做,就搞了两个例子,一个是针对Application开发的,另一个是针对Web开发的。当然我是刚刚学习这东西,在所难免要借某些同仁的作品参考,在这里要特别谢谢日月星辰的作者。同时也要感谢来了,就好!的作者。
一、JFreeChart获取。
JFreeChart是JFreeChart公司在开源网站SourceForge.net上的一个项目,该公司的主要产品有如下:
1、JFreeReport:报表解决工具
2、JFreeChart:Java图形解决方案(Application/Applet/Servlet/Jsp)
3、JCommon:JFreeReport和JFreeChart的公共类库
4、JFreeDesigner:JFreeReport的报表设计工具
我们可以从jfree官方网站上获取***版本和相关资料(但是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、为了配置成功,我们需要关注的文件有如下三个:jfreechart-0.9.21.jar、libjcommon-0.9.6.jar、libgnujaxp.jar
3、如果是Application开发,把上述三个文件拷贝到%JAVA_HOME%LIB中,同时在环境变量CLASSPATH中加入如果是WEB开发,以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的开发了。这里值得提出的是jfreechart的类结构设计前后兼容性不是很好,不同版本的jfreechart中类库结构可能不一样,有时候可能需要查源码。如果是中文显示的时候可能依据观感需要改变源码的字体,不过我个人觉得这个版本比以前版本要好一些。
三、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
(态图表,饼图(二维和三维) , 柱状图 (水平,垂直),线图,点图,时间变化图,甘特图, 股票行情图,混和图, 温度计图, 刻度图等常用商用图表)
图形可以导出成PNG和JPEG格式,同时还可以与PDF和EXCEL关联。
JFreeChart核心类库介绍:
研究jfreechart源码发现源码的主要由两个大的包组成:org.jfree.chart,org.jfree.data。其中前者主要与图形本身有关,后者与图形显示的数据有关。具体研究如果大家有兴趣的话可以自己研究,以后有时间我会告诉大家怎么去研究源码。
核心类主要有:
org.jfree.chart.JFreeChart:图表对象,任何类型的图表的最终表现形式都是在该对象进行一些属性的定制。JFreeChart引擎本身提供了一个工厂类用于创建不同类型的图表对象
org.jfree.data.category.XXXDataSet:数据集对象,用于提供显示图表所用的数据。根据不同类型的图表对应着很多类型的数据集对象类
org.jfree.chart.plot.XXXPlot:图表区域对象,基本上这个对象决定着什么样式的图表,创建该对象的时候需要Axis、Renderer以及数据集对象的支持
org.jfree.chart.axis.XXXAxis:用于处理图表的两个轴:纵轴和横轴
org.jfree.chart.render.XXXRender:负责如何显示一个图表对象
org.jfree.chart.urls.XXXURLGenerator:用于生成Web图表中每个项目的鼠标点击链接
XXXXXToolTipGenerator:用于生成图象的帮助提示,不同类型图表对应不同类型的工具提示类
四、JFreeChart开发(Application/Applet)
1、居于Application的开发,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("开发人员",45);
- dpd.setValue("其他人员",5);
- //Create JFreeChart object
- //参数可以查看源码
- JFreeChart pieChart = ChartFactory.createPieChart("CityInfoPort公司组织架构图",dpd,true,true,false);
- ChartFrame pieFrame = new ChartFrame("CityInfoPort公司组织架构图",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 {
- //构造函数
- public FirstJFreeChart(String s){
- super(s);
- setContentPane(createDemoPanel());
- }
- public static void main(String[] args){
- FirstJFreeChart fjc = new FirstJFreeChart("CityInfoPort公司组织架构图");
- fjc.pack();
- RefineryUtilities.centerFrameOnScreen(fjc);
- fjc.setVisible(true);
- }
- //生成饼图数据集对象
- public static PieDataset createDataset(){
- DefaultPieDataset defaultpiedataset = new DefaultPieDataset();
- defaultpiedataset.setValue("管理人员",10.02D);
- defaultpiedataset.setValue("市场人员",20.23D);
- defaultpiedataset.setValue("开发人员",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公司组织架构图",piedataset,true,true,false);
- //获得图表显示对象
- PiePlot pieplot = (PiePlot)jfreechart.getPlot();
- //设置图表标签字体
- 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的开发,这里特别要声明,要把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); //可选,设置图片背景色
- chart.setTitle("Welcome to Jfreechart !"); //可选,设置图片标题
- 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
【编辑推荐】