专注收集记录技术开发学习笔记、技术难点、解决方案
网站信息搜索 >> 请输入关键词:
您当前的位置: 首页 > 图形/图像

javase jfreechar 图像图形 饼图之类的包

发布时间:2011-06-27 20:24:54 文章来源:www.iduyao.cn 采编人员:星星草
javase jfreechar 图像图形 饼图等等的包

 

当前的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>
 

 

友情提示:
信息收集于互联网,如果您发现错误或造成侵权,请及时通知本站更正或删除,具体联系方式见页面底部联系我们,谢谢。

其他相似内容:

热门推荐: