当前位置: 移动技术网 > IT编程>开发语言>Java > jsp JFreeChart使用心得与例子

jsp JFreeChart使用心得与例子

2017年12月12日  | 移动技术网IT编程  | 我要评论
当前的jfreechart的最新版本为jfreechart-1.0.11.zip。可以到http://www.jfree.org/jfreechart/找到
二、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>

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网