利用JFreeChart工具生成统计图的几种方法Word文件下载.docx
《利用JFreeChart工具生成统计图的几种方法Word文件下载.docx》由会员分享,可在线阅读,更多相关《利用JFreeChart工具生成统计图的几种方法Word文件下载.docx(13页珍藏版)》请在冰豆网上搜索。
jfreechart-1.0.1.jar、jcommon-1.0.0.jar、gnujaxp.jar
加上第三个jar包有时web.xml会报错,把它去掉就好了。
至此jfreechart的配置就完成了,下面就可以进行jfreechart的开发了。
这里值得提出的是jfreechart的类
结构设计前后兼容性不是很好,不同版本的jfreechart中类库结构可能不一样,有时候可能需要查源码。
如果是中文显示的时候可能依据观感需要改变源码的字体。
四、JFreeChart功能介绍
JFreeChart目前是最好的java图形解决方案,基本能够解决目前的图形方面的需求,主要包括如下几个方面:
piecharts(2Dand3D):
饼图(平面和立体)
barcharts(regularandstacked,withanoptional3Deffect):
柱状图
lineandareacharts:
曲线图
scatterplotsandbubblecharts
timeseries,high/low/open/closechartsandcandlestickcharts:
时序图
combinationcharts:
复合图
Paretocharts
Ganttcharts:
甘特图
windplots,meterchartsandsymbolcharts
wafermapcharts
(态图表,饼图(二维和三维),柱状图(水平,垂直),线图,点图,时间变化图,甘特图,股票行情图,混和图,温度计图,刻度图等常用商用图表)
图形可以导出成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可以满足大部分图片创建的需要,美中不足的是:
对字体的设置做的不够好,特别是使用中文的时候字体很不清晰。
因为这个原因建议你自己去修改他的源代码,最好使用properties文件去设置字体.还有就是文档要钱所以要多花点时间去看源代码。
或多上社区.
五.开始开发
对JfreeChart有了初步了解并做好准备工作之后,开始作例子程序试验。
在这里我只介绍饼图的做法,而这张图采用不同的方式进行输出,其他类型的图片可以参考jfreechart提供的例子,做法都差不多。
1)直接生成图片
Java代码
1publicclassPieChartPicture{
2publicstaticvoidmain(String[]args)
3{
4PieDatasetdataset=getDataSet();
5JFreeChartchart=ChartFactory.createPieChart3D(
6"
项目进度分布"
//charttitle
7dataset,//data
8true,//includelegend
9true,
10false
11);
12PiePlot3Dplot=(PiePlot3D)chart.getPlot();
13//图片中显示百分比:
默认方式
14//plot.setLabelGenerator(newStandardPieSectionLabelGenerator(StandardPieToolTipGenerator.DEFAULT_TOOLTIP_FORMAT));
15//图片中显示百分比:
自定义方式,{0}表示选项,{1}表示数值,{2}表示所占比例,小数点后两位
16plot.setLabelGenerator(newStandardPieSectionLabelGenerator("
{0}={1}({2})"
NumberFormat.getNumberInstance(),newDecimalFormat("
0.00%"
)));
17//图例显示百分比:
自定义方式,{0}表示选项,{1}表示数值,{2}表示所占比例
18plot.setLegendLabelGenerator(newStandardPieSectionLabelGenerator("
));
19//设置背景色为白色
20chart.setBackgroundPaint(Color.white);
21//指定图片的透明度(0.0-1.0)
22plot.setForegroundAlpha(1.0f);
23//指定显示的饼图上圆形(false)还椭圆形(true)
24plot.setCircular(true);
25//设置图标题的字体
26Fontfont=newFont("
黑体"
Font.CENTER_BASELINE,20);
27TextTitletitle=newTextTitle("
项目状态分布"
);
28title.setFont(font);
29chart.setTitle(title);
30FileOutputStreamfos_jpg=null;
31try{
32fos_jpg=newFileOutputStream("
D:
\\项目状态分布.jpg"
33ChartUtilities.writeChartAsJPEG(fos_jpg,100,chart,640,480,null);
34fos_jpg.close();
35}catch(Exceptione){
36}
37}
38privatestaticPieDatasetgetDataSet(){
39DefaultPieDatasetdataset=newDefaultPieDataset();
40dataset.setValue("
市场前期"
newDouble(10));
41dataset.setValue("
立项"
newDouble(15));
42dataset.setValue("
计划"
43dataset.setValue("
需求与设计"
44dataset.setValue("
执行控制"
newDouble(35));
45dataset.setValue("
收尾"
46dataset.setValue("
运维"
newDouble(10));
47returndataset;
48}
49}
2)采用servlet和struts的action方式输出
采用这种方式输出,不用生成图片。
A.servlet输出
50publicclassPieByServletextendsHttpServlet{
51publicvoidservice(ServletRequestreq,ServletResponseres)
52throwsServletException,IOException
53{
54res.setContentType("
image/jpeg"
55PieDatasetdataset=getDataSet();
56JFreeChartchart=ChartFactory.createPieChart3D(
57"
水果饼图"
58dataset,//data
59true,//includelegend
60true,
61false);
62//设置图表属性
63//输出图片
64ChartUtilities.writeChartAsJPEG(res.getOutputStream(),100,chart,800,600,null);
65}
B.struts的action方式输出
只将这条语句加上trycatch即可,并返回null。
66try{
67ChartUtilities.writeChartAsJPEG(response.getOutputStream(),100,chart,800,600,null);
68}catch(Exceptione){
69}
70returnnull;
其实采用这两种方式与生成图片的方式改动并不大
加上语句response.setContentType("
ChartUtilities.writeChartAsJPEG(newFileOutputStream("
100,chart,640,480,null);
文件流改成response的输出流就可以了
hartUtilities.writeChartAsJPEG(response.getOutputStream(),100,chart,800,600,null);
3)jsp+servlet+javabean方式
1.CreateChartViewerservlet
71publicclassChartViewerextendsHttpServlet{
72publicvoidinit()throwsServletException{
73}
74//ProcesstheHTTPGetrequest
75publicvoiddoGet(HttpServletRequestrequest,HttpServletResponseresponse)throwsServletException,IOException{
76//getthechartfromsession
77HttpSessionsession=request.getSession();
78BufferedImagechartImage=(BufferedImage)session.getAttribute("
chartImage"
79//setthecontenttypesothebrowsercanseethisasapicture
80response.setContentType("
image/png"
81//sendthepicture
82PngEncoderencoder=newPngEncoder(chartImage,false,0,9);
83response.getOutputStream().write(encoder.pngEncode());
84}
85//ProcesstheHTTPPostrequest
86publicvoiddoPost(HttpServletRequestrequest,HttpServletResponseresponse)throwsServletException,IOException{
87doGet(request,response);
88}
89//ProcesstheHTTPPutrequest
90publicvoiddoPut(HttpServletRequestrequest,HttpServletResponseresponse)throwsServletException,IOException{
91}
92//Cleanupresources
93publicvoiddestroy(){}
94}
2.Createaservletmapinweb.xml
95<
?
xmlversion="
1.0"
encoding="
UTF-8"
>
96<
web-app>
97<
servlet>
98<
servlet-name>
ChartViewer<
/servlet-name>
99<
servlet-class>
myapp.webwork.servlets.ChartViewer<
/servlet-class>
100<
/servlet>
101<
servlet-mapping>
102<
103<
url-pattern>
/servlet/ChartViewer<
/url-pattern>
104<
/servlet-mapping>
105<
/web-app>
3.Createachartinajavabean(Pie3DDemo.java)
106publicclassPie3DDemo{
107privateDefaultPieDatasetgetDataset(){
108//categories...
109String[]section=newString[]{"
Jan"
"
Feb"
Mar"
Apr"
May"
Jun"
"
Jul"
Aug"
Sep"
Oct"
Nov"
Dec"
};
110//data...
111double[]data=newdouble[section.length];
112for(inti=0;
i<
data.length;
i++){
113data[i]=10+(Math.random()*10);
114}
115//createthedataset...
116DefaultPieDatasetdataset=newDefaultPieDataset();
117for(inti=0;
118dataset.setValue(section[i],data[i]);
119}
120returndataset;
121}
122publicStringgetChartViewer(HttpServletRequestrequest,HttpServletResponseresponse){
123DefaultPieDatasetdataset=getDataset();
124//createthechart...
125JFreeChartchart=ChartFactory.createPie3DChart(
126"
Pie3DChartDemo"
127dataset,//data
128true,//includelegend
129true,
130false
131);
132//setthebackgroundcolorforthechart...
133chart.setBackgroundPaint(Color.cyan);
134PiePlotplot=(PiePlot)chart.getPlot();
135plot.setNoDataMessage("
Nodataavailable"
136//setdrilldowncapability...
137plot.setURLGenerator(newStandardPieURLGenerator("
Bar3DDemo.jsp"
section"
138plot.setLabelGenerator(null);
139//OPTIONALCUSTOMISATIONCOMPLETED.
140ChartRenderingInfoinfo=null;
141HttpSessionsession=request.getSession();
142try{
143//CreateRenderingInfoobject
144response.setContentType("
text/html"
145info=newChartRenderingInfo(newStandardEntityCollection());
146BufferedImagechartImage=chart.createBufferedImage(640,400,info);
147//puttingchartasBufferedImageinsession,
148//thusmakingitavailablefortheimagereadingactionAction.
149session.setAttribute("
chartImage);
150PrintWriterwriter=newPrintWriter(response.getWriter());
151ChartUtilities.writeImageMap(writer,"
imageMap"
info);
152writer.flush();
153}catch(Exceptione){}
154
155StringpathInfo="
//"
;
156pathInfo+=request.getServerName();
157intport=request.getServerPort();
158pathInfo+="
:
"
+String.valueOf(port);
159pathInfo+=request.getContextPath();
160StringchartViewer=pathInfo+"
/servlet/ChartViewer"
161returnchart