欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

jsp JFreeChart使用心得与例子

程序员文章站 2023-12-04 10:03:04
当前的jfreechart的最新版本为jfreechart-1.0.11.zip。可以到http://www.jfree.org/jfreechart/index.html...
当前的jfreechart的最新版本为jfreechart-1.0.11.zip。可以到http://www.jfree.org/jfreechart/index.html找到
二、jfreechart的基本使用
不论创建的是什么图,jfreechart都遵循以下的这个使用步骤:
1、建立dataset。所有的数据都存放在dataset中的。(创建一个数据源(dataset)来包含将要在图形中显示的数据)
2、建立jfreechart。将dataset中的数据导入到jfreechart中。(创建一个 jfreechart 对象来代表要显示的图形 )
3、设置jfreechart的显示属性。这一步可以省略,使用默认的jfreechart显示属性。
3、渲染图表。即生成图片。
4、页面图片显示。
重要的类和接口:
org.jfree.data.general.dataset 所有数据源类都要实现的接口
org.jfree.chart.chartfactory 由它来产生 jfreechart 对象
org.jfree.chart.jfreechart 所有对图形的调整都是通过它噢!!
org.jfree.chart.plot.plot 通过jfreechart 对象获得它,然后再通过它对图形外部部分(例:坐标轴)调整
注意:它有很多子类,一般都下涉及到它的子类!
org.jfree.chart.renderer.abstractrenderer 通过jfreechart 对象获得它,然后再通过它对图形内部部分(例:折线的类型)调整。同样,针对不同类型的报表图,它有着不同的子类实现!在下面我们简称它为 renderer

三、jfreechart使用的具体例子
在web应用中的例子
package com.lzk.bean;
import java.awt.color;
import java.awt.font;
import java.io.ioexception;
import java.io.printwriter;
import java.text.numberformat;
import java.text.simpledateformat;
import javax.servlet.http.httpsession;
import org.jfree.chart.chartfactory;
import org.jfree.chart.chartrenderinginfo;
import org.jfree.chart.chartutilities;
import org.jfree.chart.jfreechart;
import org.jfree.chart.axis.dateaxis;
import org.jfree.chart.axis.numberaxis;
import org.jfree.chart.entity.standardentitycollection;
import org.jfree.chart.labels.standardxytooltipgenerator;
import org.jfree.chart.plot.xyplot;
import org.jfree.chart.renderer.xy.xyitemrenderer;
import org.jfree.chart.renderer.xy.xylineandshaperenderer;
import org.jfree.chart.servlet.servletutilities;
import org.jfree.chart.title.texttitle;
import org.jfree.data.time.day;
import org.jfree.data.time.timeseries;
import org.jfree.data.time.timeseriescollection;
import org.jfree.data.xy.xydataset;
import org.jfree.ui.rectangleinsets;
/**
* 曲线图的绘制
*/
public class linexychart
{
/**
* 返回生成图片的文件名
* @param session
* @param pw
* @return 生成图片的文件名
*/
public string getlinexychart(httpsession session, printwriter pw)
{
xydataset dataset = this.createdateset();//建立数据集
string filename = null;
//建立jfreechart
jfreechart chart = chartfactory.createtimeserieschart(
"jfreechart时间曲线序列图", // title
"date", // x-axis label
"price", // y-axis label
dataset, // data
true, // create legend?
true, // generate tooltips?
false // generate urls?
);
//设置jfreechart的显示属性,对图形外部部分进行调整
chart.setbackgroundpaint(color.red);//设置曲线图背景色
//设置字体大小,形状
font font = new font("宋体", font.bold, 16);
texttitle title = new texttitle("jfreechart时间曲线序列图", font);
chart.settitle(title);
//副标题
texttitle subtitle =
new texttitle("副标题", new font("黑体", font.bold, 12));
chart.addsubtitle(subtitle);
chart.settitle(title); //标题

//设置图示标题字符
//timeseries s1 = new timeseries("历史曲线", day.class);该中文字符
legendtitle legengtitle = chart.getlegend();
legengtitle.setitemfont(font);

xyplot plot = (xyplot) chart.getplot();//获取图形的画布
plot.setbackgroundpaint(color.lightgray);//设置网格背景色
plot.setdomaingridlinepaint(color.green);//设置网格竖线(domain轴)颜色
plot.setrangegridlinepaint(color.white);//设置网格横线颜色
plot.setaxisoffset(new rectangleinsets(5.0, 5.0, 5.0, 5.0));//设置曲线图与xy轴的距离
plot.setdomaincrosshairvisible(true);
plot.setrangecrosshairvisible(true);
xyitemrenderer r = plot.getrenderer();
if (r instanceof xylineandshaperenderer)
{
xylineandshaperenderer renderer = (xylineandshaperenderer) r;
renderer.setbaseshapesvisible(true);
renderer.setbaseshapesfilled(true);
renderer.setshapesvisible(true);//设置曲线是否显示数据点
}
//设置y轴
numberaxis numaxis = (numberaxis) plot.getrangeaxis();
numberformat numformater = numberformat.getnumberinstance();
numformater.setminimumfractiondigits(2);
numaxis.setnumberformatoverride(numformater);
//设置提示信息
standardxytooltipgenerator tipgenerator = new standardxytooltipgenerator(
"历史信息{1} 16:00,{2})", new simpledateformat("mm-dd"),numformater);
r.settooltipgenerator(tipgenerator);
//设置x轴(日期轴)
dateaxis axis = (dateaxis) plot.getdomainaxis();
axis.setdateformatoverride(new simpledateformat("mm-dd"));
chartrenderinginfo info = new chartrenderinginfo(
new standardentitycollection());
try
{
filename = servletutilities.savechartaspng(chart, 500, 300, info,
session);//生成图片
// write the image map to the printwriter
chartutilities.writeimagemap(pw, filename, info, false);
}
catch (ioexception e)
{
e.printstacktrace();
}
pw.flush();
return filename;//返回生成图片的文件名
}
/**
* 建立生成图形所需的数据集
* @return 返回数据集
*/
private xydataset createdateset()
{
timeseriescollection dataset = new timeseriescollection();//时间曲线数据集合
timeseries s1 = new timeseries("历史曲线", day.class);//创建时间数据源,每一个//timeseries在图上是一条曲线
//s1.add(new day(day,month,year),value),添加数据点信息
s1.add(new day(1, 2, 2006), 123.51);
s1.add(new day(2, 2, 2006), 122.1);
s1.add(new day(3, 2, 2006), 120.86);
s1.add(new day(4, 2, 2006), 122.50);
s1.add(new day(5, 2, 2006), 123.12);
s1.add(new day(6, 2, 2006), 123.9);
s1.add(new day(7, 2, 2006), 124.47);
s1.add(new day(8, 2, 2006), 124.08);
s1.add(new day(9, 2, 2006), 123.55);
s1.add(new day(10, 2, 2006), 122.53);
dataset.addseries(s1);
dataset.setdomainispointsintime(true);
return dataset;
}
}


在jsp文件中显示图片
首先在web应用程序部署文件web.xml中添加以下代码:

<!-- 图片显示,使用专用的servlet来进行显示,它会完成路径的搜索及映射 -->
<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>
然后在jsp中显示图片
完整的jsp文件:
<!--文件名称:timeline.jsp-->
<%@ page contenttype="text/html;charset=gb2312" pageencoding="gb2312"%>
<%@ page import="com.hong.bean.linexychart"%>
<%@ page import = "java.io.printwriter" %>
<%
linexychart xychart=new linexychart();
string filename=xychart.getlinexychart(session,new printwriter(out));
string graphurl = request.getcontextpath() + "/servlet/displaychart?filename=" + filename;
%>
<html>
</head>
<title> jfreechart使用例子</title>
<meta http-equiv="content-type" content="text/html; charset=gb2312">
</head>
<body>
<img src="<%= graphurl %>" width=500 height=300 border=0 usemap="<%= filename %>">
</body>
</html>