JFreeChart图表应用详解
- 格式:ppt
- 大小:1.17 MB
- 文档页数:38
WEB图表开发系列一:使用JFreeChart生成热点图表<一>前言:JFreeChart是开放源代码站点上的一个JAVA项目。
它的功能十分强大,能创建饼图、柱状图(普通柱状图以及堆栈柱状图)、线图、区域图、分布图、混合图、甘特图以及一些仪表盘等等,并可生成PNG或JPG图片格式文件。
本人在学习过程中发现,网上很多文章都是讲一些JFreeChart的基本应用,而对JFreeChart生成热点图表这样常用的功能虽有所提及却没有一个完整的例子,所以我就写一个简单示例供大家参考,希望对大家的学习有所帮助。
<二>示例说明:假设有一个关于程序员北京,上海,广洲三地程序员学历,开发语言,薪金情况的调查。
首先要以饼图显示程序员学历的分布情况(index.jsp)。
点击饼图的每一部分会以柱状图显示该层次程序员所用开发语言和薪金的情况(barview.jsp)。
重点演示怎样在饼图上添加链接。
<三>准备工作:1.下载最新版本的JFreeChart,当前为jfreechart-1.0.0-rc1下载地址:/jfreechart/index.html2.解压文件,将jfreechart-1.0.0-rc1/lib下的jcommon-1.0.0-rc1.jar,jfreechart-1.0.0-rc1.jar复制到WEB应用的lib目录下。
3.在web.xml文件中增加以下内容:1.<servlet>2.<servlet-name>DisplayChart</servlet-name>3.<servlet-class>org.jfree.chart.servlet.DisplayChart</servlet-class>4.</servlet>5.<servlet-mapping>6.<servlet-name>DisplayChart</servlet-name>7.<url-pattern>/servletDisplayChart</url-pattern>8.</servlet-mapping><四>饼图页面代码(index.jsp)1.<%@ page contentType="text/html;charset=GBK"%>2.<%@ page import="org.jfree.data.general.DefaultPieDataset"%>3.<%@ page import="org.jfree.chart.*"%>4.<%@ page import="org.jfree.chart.plot.*"%>5.<%@ page import="org.jfree.chart.servlet.ServletUtilities"%>6.<%@ page import="bels.StandardPieItemLabelGenerator"%>7.<%@ page import="org.jfree.chart.urls.StandardPieURLGenerator"%>8.<%@ page import="org.jfree.chart.entity.StandardEntityCollection"%>9.<%@ page import="java.io.*"%>10.<HTML>11.<HEAD>12.<META http-equiv=Content-Type content="text/html; charset=GBK">13.<TITLE>nacl_zhuang@</TITLE>14.</HEAD>15.<BODY>16.<%17.18.DefaultPieDataset data = new DefaultPieDataset();19.data.setValue("高中以下",370);20.data.setValue("高中",1530);21.data.setValue("大专",5700);22.data.setValue("本科",8280);23.data.setValue("硕士",4420);24.data.setValue("博士",80);25.26.PiePlot3D plot = new PiePlot3D(data);//3D饼图27.plot.setURLGenerator(new StandardPieURLGenerator("barview.jsp"));//设定链接28.JFreeChart chart = new JFreeChart("",JFreeChart.DEFAULT_TITLE_FONT, plot, true);29.chart.setBackgroundPaint(java.awt.Color.white);//可选,设置图片背景色30.chart.setTitle("程序员学历情况调查表");//可选,设置图片标题31.plot.setToolTipGenerator(new StandardPieItemLabelGenerator());32.StandardEntityCollection sec = new StandardEntityCollection();33.ChartRenderingInfo info = new ChartRenderingInfo(sec);34.PrintWriter w = new PrintWriter(out);//输出MAP信息35.//500是图片长度,300是图片高度36.String filename = ServletUtilities.saveChartAsPNG(chart, 500, 300, info, session);37.ChartUtilities.writeImageMap(w, "map0", info, false);38.39.String graphURL = request.getContextPath() + "/servlet/DisplayChart?filename="+ filename;40.41.%>42.43.<P ALIGN="CENTER">44.<img src="<%= graphURL %>"width=500 height=300 border=0usemap="#map0">45.</P>46.</BODY>47.</HTML>生成的图片如下在浏览器中点右键->查看源文件会发现有以下一段HTML代码:1.<map id="map0"name="map0">2.<area shape="poly"coords="247,61,250,61,250,123,250,123"title="博士= 80"alt=""href="barview.jsp?category=博士&pieIndex=0"/>3.<area shape="poly"coords="148,112,153,102,160,92,170,83,182,76,196,70,212,65,229,62,247,61,250,123,250,123"title="硕士= 4,420"alt=""href="barview.jsp?category=硕士&pieIndex=0"/>4.<area shape="poly"coords="324,167,311,173,297,179,282,182,266,185,250,186,234,185,217,183,202,179,188,173,175,167,165,159,1 57,151,151,142,147,132,146,122,148,112,250,123,250,123"title="本科= 8,280"alt=""href="barview.jsp?category=本科&pieIndex=0"/>5.<area shape="poly"coords="307,72,324,80,338,91,347,103,352,117,352,131,347,144,338,156,324,167,250,123,250,123"title="大专= 5,700"alt=""href="barview.jsp?category=大专&pieIndex=0"/>6.<area shape="poly"coords="261,62,285,65,307,72,250,123,250,123"title="高中= 1,530"alt=""href="barview.jsp?category=高中&pieIndex=0"/>7.<area shape="poly"coords="250,61,261,62,250,123,250,123"title="高中以下= 370"alt=""href="barview.jsp?category=高中以下&pieIndex=0"/>8.</map>这就是MAP信息,我们在IMG标签中加入usemap="#map0"就可以为饼图的每一部分加入链接。
使用JfreeChart开发图表经验总结(含源码)使用JfreeChart开发图表经验总结(含源码)Keith He 2005年10月27日最近,公司一项目要出很多的图表。
由于项目是B/S架构的,所以生成的图表也要考虑能在浏览器上动态显示。
生成基于浏览器的图表方式比较多。
据我所知道的,常用的有三种:1、VML方式实现。
这种方式是通过产生客户端的代码,由客户端根据代码生成相应的图表。
但这种方式产生的图表有很多的局限性,如受限于浏览器,有些浏览器可能并不支持VML。
另外,没有封装完整的图表开发包。
2、通过applet来产生图表。
这种方式也对客户端要求比较高,必须要有JRE,而且通过applet生成的图表在加载过程中会有个Java的Log动画。
用户看了可能会感觉不太舒服。
3、通过服务端直接生成图表的图片。
这种方式对客户端几乎没有什么要求,缺点是加重了服务端的负担,对服务端要求就相对高了点。
经过比较,根据项目自身特点,我们打算采用第三种方式来开发图表。
为了缩短开发周期、节约成本,我们选用了开源的JFreeChart(/jfreechart/)。
jfreechart是一个免费创建图表的java工具,目前最新版本是JFreeChart-1.0.0-rc1。
它可以生成各式各样的图表。
这些图表包括饼图、柱状图、线形图、区域图、甘特图等等,基本可以满足各种项目的要求。
但在开发过程中我也发现了JFreeChart的一些不足,或者说有些称得上是BUG。
总体说来,JFreeChart还是个优秀的开源项目。
关于JFreeChart生成图表的文章比较多了,我主要谈谈使用JFreeChart的一些比较棘手问题以及解决方法。
同时也会将问题所用到的源码(JFreeChart-1.0.0-rc1+Struts1.2.4)从项目中抽象出来一起提供给大家。
一、图片上热点链接中文乱码的解决方法这个问题是在我查阅关于JFreeChart相关资料时出现频率最高的一个问题。
用JFreeChart增强JSP报表的用户体验JFreeChart是一组功能强大、灵活易用的Java绘图API,使用它可以生成多种通用性的报表,包括柱状图、饼图、曲线图、甘特图等。
它能够用在Swing和Web等中制作自定义的图表或报表,并且得到广泛的应用。
本文将通过引领读者学习在JFreeChart中饼图、柱状图和曲线图的进阶应用,来达到熟练使用JFreeChart的目的。
一.下载与环境配置1. 下载JFreeChartJFreeChart是开放源代码的免费软件,但是它的支持文档需要付费才能得到。
其下载地址为:/project/showfiles.php?g roup_id=15494,当前最新版本为1.0.6。
笔者下载的是1.0.6最新版。
说明:1)source目录:为jfreechart的源码目录;2)lib目录:为包目录,我们需要关注的包为jfreechart-1.0.6.ja r、gnujaxp.jar和jcommon-1.0.10.jar这三个包;3)根目录下的jfreechart-1.0.6-demo.jar是例子程序,大家双击后可看到其中有很多例子的运行结果。
2. 环境配置笔者的开发环境如下:JDK:1.5MyEclipse:5.1.1 GATomcat:5.5.28为了后续的“用JFreeChart创建基于Web的图表”的一个例子的展示,我们在MyEclipse中创建一个名为jfreechart的Web工程。
将下载的JFreeChart1.0.6下lib目录下的jar包拷贝到WebRoot/WEB-INF/lib目录下。
另外还需要在web.xml文件中增加如下配置:<servlet><servlet-name>DisplayChart</servlet-name><servlet-class>org.jfree.chart.servlet.DisplayChart</servlet-clas s></servlet><servlet-mapping><servlet-name>DisplayChart</servlet-name><url-pattern>/DisplayChart</url-pattern></servlet-mapping>二.柱状图在WebRoot目录下建立bar目录,用来存放柱状图的各个例子。
JFreeChart使用简介一、JFreeChart产生图形的流程创建一个数据源(dataset)来包含将要在图形中显示的数据,然后创建一个JFreeChart对象来代表要显示的图形,然后把图形输出。
二、重要的类和接口: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下面我们结合不同类型的图形来具体分析这个流程。
三、饼图饼图的dataset一般是用PieDataset接口,具体实现类是DefaultPieDataset1、创建一个数据源(dataset):private static PieDataset createDataset(){DefaultPieDataset defaultpiedataset = new DefaultPieDataset(); //注意是DefaultPieDataset!!defaultpiedataset.setValue(”One”, new Double(43.200000000000003D));defaultpiedataset.setValue(”Two”, new Double(10D));defaultpiedataset.setValue(”Three”, new Double(27.5D));defaultpiedataset.setValue(”Four”, new Double(17.5D));return defaultpiedataset;}2、由ChartFactory 产生 JFreeChart 对象private static JFreeChart createChart(PieDataset piedataset) {JFreeChart jfreechart = ChartFactory.createPieChart(”Pie Chart Demo 1″, //图形标题名称piedataset, // datasettrue, // legend?true, // tooltips?false); //URLs?PiePlot pieplot = (PiePlot)jfreechart.getPlot(); //通过JFreeChart 对象获得 plot:PiePlot!!pieplot.setNoDataMessage(”No data available”); // 没有数据的时候显示的内容return jfreechart;}一些重要的方法:pieplot.setExplodePercent(0,0.3D) //把Lable 为”One” 的那一块”挖”出来30%3、输出略四、柱状图柱状图的dataset 一般是用CatagoryDataset接口(具体实现类是DefaultCategoryDataset),也会用 IntervalXYDataset接口1、创建一个数据源(dataset):private static CategoryDataset createDataset(){String series1 = “First”;String series2 = “Second”;String series3 = “Third”;String category1 = “Category 1″;String category2 = “Category 2″;String category3 = “Category 3″;String category4 = “Category 4″;String category5 = “Category 5″;DefaultCategoryDataset defaultcategorydataset = new DefaultCategoryDataset();defaultcategorydataset.addValue(1.0D, series1, category1);defaultcategorydataset.addValue(4D, series1, category2);defaultcategorydataset.addValue(3D, series1, category3);defaultcategorydataset.addValue(5D, series1, category4);defaultcategorydataset.addValue(5D, series1, category5);defaultcategorydataset.addValue(5D, series2, category1);defaultcategorydataset.addValue(7D, series2, category2);defaultcategorydataset.addValue(6D, series2, category3);defaultcategorydataset.addValue(8D, series2, category4);defaultcategorydataset.addValue(4D, series2, category5);defaultcategorydataset.addValue(4D, series3, category1);defaultcategorydataset.addValue(3D, series3, category2);defaultcategorydataset.addValue(2D, series3, category3);defaultcategorydataset.addValue(3D, series3, category4);defaultcategorydataset.addValue(6D, series3, category5);return defaultcategorydataset;}2、由ChartFactory 产生 JFreeChart 对象private static JFreeChart createChart(CategoryDataset categorydataset){JFreeChart jfreechart = ChartFactory.createBarChart(”Bar Chart Demo”, //图形标题名称“Category”,//domain 轴 Lable这里先简单理解为横坐标Lable好了“Value”, //range 轴 Lable这里也先简单理解为纵坐标Lable好了categorydataset, // datasetPlotOrientation.VERTICAL, //垂直显示true, // legend?true, // tooltips?false); //URLs?jfreechart.setBackgroundPaint(Color.white); //设定背景色为白色CategoryPlot categoryplot = jfreechart.getCategoryPlot(); //获得 plot:CategoryPlot!!categoryplot.setBackgroundPaint(Color.lightGray); //设定图表数据显示部分背景色categoryplot.setDomainGridlinePaint(Color.white); //横坐标网格线白色categoryplot.setDomainGridlinesVisible(true); //可见categoryplot.setRangeGridlinePaint(Color.white); //纵坐标网格线白色//下面两行使纵坐标的最小单位格为整数NumberAxis numberaxis = (NumberAxis)categoryplot.getRangeAxis();numberaxis.setStandardTickUnits(NumberAxis.createIntegerTickUnits());BarRenderer barrenderer = (BarRenderer)categoryplot.getRenderer(); //获得renderer 注意这里是下嗍造型到BarRenderer!!barrenderer.setDrawBarOutline(false); // Bar的外轮廓线不画GradientPaint gradientpaint = new GradientPaint(0.0F, 0.0F, Color.blue,0.0F, 0.0F, new Color(0, 0, 64)); //设定特定颜色GradientPaint gradientpaint1 = new GradientPaint(0.0F, 0.0F, Color.green,0.0F, 0.0F, new Color(0, 64, 0));GradientPaint gradientpaint2 = new GradientPaint(0.0F, 0.0F, Color.red,0.0F, 0.0F, new Color(64, 0, 0));barrenderer.setSeriesPaint(0, gradientpaint); //给series1 Bar 设定上面定义的颜色barrenderer.setSeriesPaint(1, gradientpaint1); //给series2 Bar 设定上面定义的颜色barrenderer.setSeriesPaint(2, gradientpaint2); //给series3 Bar 设定上面定义的颜色CategoryAxis categoryaxis = categoryplot.getDomainAxis(); //横轴上的 Lable 45度倾斜categoryaxis.setCategoryLabelPositions(CategoryLabelPositi ons.UP_45);return jfreechart;}一些重要的方法:(增加一块标记)IntervalMarker intervalmarker = new IntervalMarker(4.5D, 7.5D);intervalmarker.setLabel(”Target Range”);intervalmarker.setLabelFont(new Font(”SansSerif”, 2, 11));intervalmarker.setLabelAnchor(RectangleAnchor.LEFT);intervalmarker.setLabelTextAnchor(TextAnchor.CENTER_LEFT );intervalmarker.setPaint(new Color(222, 222, 255, 128));categoryplot.addRangeMarker(intervalmarker,Layer.BACKGROUND);五、折线图折线图的dataset 两种CatagoryDataset接口(具体实现类是DefaultCategoryDataset),XYDataset 接口1、CatagoryDataset接口:A、创建一个数据源(dataset):private static CategoryDataset createDataset(){String series1 = “First”;String series2 = “Second”;String series3 = “Third”;String type1 = “Type 1″;String type2 = “Type 2″;String type3 = “Type 3″;String type4 = “Type 4″;String type5 = “Type 5″;String type6 = “Type 6″;String type7 = “Type 7″;String type8 = “Type 8″;DefaultCategoryDataset defaultcategorydataset = new DefaultCategoryDataset();defaultcategorydataset.addValue(1.0D, series1, type1);defaultcategorydataset.addValue(4D, series1, type2);defaultcategorydataset.addValue(3D, series1, type3);defaultcategorydataset.addValue(5D, series1, type4);defaultcategorydataset.addValue(5D, series1, type5);defaultcategorydataset.addValue(7D, series1, type6);defaultcategorydataset.addValue(7D, series1, type7);defaultcategorydataset.addValue(8D, series1, type8);defaultcategorydataset.addValue(5D, series2, type1);defaultcategorydataset.addValue(7D, series2, type2);defaultcategorydataset.addValue(6D, series2, type3);defaultcategorydataset.addValue(8D, series2, type4);defaultcategorydataset.addValue(4D, series2, type5);defaultcategorydataset.addValue(4D, series2, type6);defaultcategorydataset.addValue(2D, series2, type7);defaultcategorydataset.addValue(1.0D, series2, type8);defaultcategorydataset.addValue(4D, series3, type1);defaultcategorydataset.addValue(3D, series3, type2);defaultcategorydataset.addValue(2D, series3, type3);defaultcategorydataset.addValue(3D, series3, type4);defaultcategorydataset.addValue(6D, series3, type5);defaultcategorydataset.addValue(3D, series3, type6);defaultcategorydataset.addValue(4D, series3, type7);defaultcategorydataset.addValue(3D, series3, type8);return defaultcategorydataset;}B、由ChartFactory 产生 JFreeChart 对象 (与上面重复的部分就不再注释)private static JFreeChart createChart(CategoryDatasetcategorydataset){JFreeChart jfreechart = ChartFactory.createLineChart(”Line Chart Demo 1″,“Type”,“Value”,categorydataset,PlotOrientation.VERTICAL,true,true,false);jfreechart.setBackgroundPaint(Color.white);CategoryPlot categoryplot = (CategoryPlot)jfreechart.getPlot();categoryplot.setBackgroundPaint(Color.lightGray);categoryplot.setRangeGridlinePaint(Color.white);NumberAxis numberaxis = (NumberAxis)categoryplot.getRangeAxis();numberaxis.setStandardTickUnits(NumberAxis.createInteger TickUnits());numberaxis.setAutoRangeIncludesZero(true);//获得renderer 注意这里是下嗍造型到lineandshaperenderer!!LineAndShapeRenderer lineandshaperenderer = (LineAndShapeRenderer)categoryplot.getRenderer();lineandshaperenderer.setShapesVisible(true); //series 点(即数据点)可见lineandshaperenderer.setSeriesStroke(0, new BasicStroke(2.0F, 1, 1, 1.0F, new float[] {10F, 6F}, 0.0F)); //定义series为”First”的(即series1)点之间的连线,这里是虚线,默认是直线lineandshaperenderer.setSeriesStroke(1, new BasicStroke(2.0F, 1, 1, 1.0F, new float[] {6F, 6F}, 0.0F)); //定义series为”Second”的(即series2)点之间的连线lineandshaperenderer.setSeriesStroke(2, new BasicStroke(2.0F, 1, 1, 1.0F, new float[] {2.0F, 6F}, 0.0F)); //定义series为”Third”的(即series3)点之间的连线return jfreechart;}一些重要的方法:lineandshaperenderer.setLineVisible(true) //series 点(即数据点)间有连线可见2、XYDataset 接口:A、创建一个数据源(dataset):private static XYDataset createDataset(){XYSeries xyseries = new XYSeries(”First”); //先产生XYSeries 对象xyseries.add(1.0D, 1.0D);xyseries.add(2D, 4D);xyseries.add(3D, 3D);xyseries.add(4D, 5D);xyseries.add(5D, 5D);xyseries.add(6D, 7D);xyseries.add(7D, 7D);xyseries.add(8D, 8D);XYSeries xyseries1 = new XYSeries(”Second”);xyseries1.add(1.0D, 5D);xyseries1.add(2D, 7D);xyseries1.add(3D, 6D);xyseries1.add(4D, 8D);xyseries1.add(5D, 4D);xyseries1.add(6D, 4D);xyseries1.add(7D, 2D);xyseries1.add(8D, 1.0D);XYSeries xyseries2 = new XYSeries(”Third”);xyseries2.add(3D, 4D);xyseries2.add(4D, 3D);xyseries2.add(5D, 2D);xyseries2.add(6D, 3D);xyseries2.add(7D, 6D);xyseries2.add(8D, 3D);xyseries2.add(9D, 4D);xyseries2.add(10D, 3D);XYSeriesCollection xyseriescollection = new XYSeriesCollection(); //再用XYSeriesCollection添加入XYSeries 对象xyseriescollection.addSeries(xyseries);xyseriescollection.addSeries(xyseries1);xyseriescollection.addSeries(xyseries2);return xyseriescollection;}B、由ChartFactory 产生 JFreeChart 对象private static JFreeChart createChart(XYDataset xydataset) {JFreeChart jfreechart = ChartFactory.createXYLineChart(”Line Chart Demo 2″,“X”,“Y”,xydataset,PlotOrientation.VERTICAL,true,true,false);jfreechart.setBackgroundPaint(Color.white);XYPlot xyplot = (XYPlot)jfreechart.getPlot(); //获得plot:XYPlot!!xyplot.setBackgroundPaint(Color.lightGray); //设定图表数据显示部分背景色xyplot.setAxisOffset(new RectangleInsets(5D, 5D, 5D, 5D)); //设定坐标轴与图表数据显示部分距离xyplot.setDomainGridlinePaint(Color.white); //网格线颜色xyplot.setRangeGridlinePaint(Color.white);//获得 renderer 注意这里是XYLineAndShapeRenderer !!XYLineAndShapeRenderer xylineandshaperenderer = (XYLineAndShapeRenderer)xyplot.getRenderer();xylineandshaperenderer.setShapesVisible(true); //数据点可见xylineandshaperenderer.setShapesFilled(true); //数据点被填充即不是空心点NumberAxis numberaxis = (NumberAxis)xyplot.getRangeAxis();numberaxis.setStandardTickUnits(NumberAxis.createIntegerTickUnits());return jfreechart;}一些重要的方法:XYLineAndShapeRenderer xylineandshaperenderer = new XYLineAndShapeRenderer();xylineandshaperenderer.setSeriesLinesVisible(0, false); //第一个XYSeries数据点间连线不可见xylineandshaperenderer.setSeriesShapesVisible(1, false); //第二个XYSeries数据点不可见xyplot.setRenderer(xylineandshaperenderer);六、时间序列图时间序列图和折线图很相似,不同的是它在domain轴的数据是时间而不是数字。
利用JFreeChart生成折线图通过JFreeChart插件,既可以生成普通效果的折线图,也可以生成3D效果的折线图。
如果想生成普通效果的折线图,需要通过工厂类ChartFactory的createLineChart()方法获得JFreeChart类的实例;如果想生成3D效果的折线图,需要通过工厂类ChartFactory的createLineChart3D()方法获得JFreeChart类的实例。
这两个方法的入口参数是完全相同的,各个入口参数的类型及功能请参见14.2.1节的表14.2。
可以分别通过绘图区对象CategoryPlot的getDomainAxis()方法和getRangeAxis()方法,获得横轴对象和纵轴对象,通过得到的轴对象可以设置绘制坐标轴的相关属性,常用方法及实现功能如表14.4所示。
表14.4 设置坐标轴绘制属性的部分通用方法纵轴对象还提供了设置坐标最大值的方法setUpperBound(double max),在默认情况下将最大值控制在能够正常绘制统计图的范围内。
通过java.awt.BasicStroke类可以绘制出各种各样的线段,大体分为实线段和虚线段,可控的绘制条件包括线条的宽度、线段端点的风格、折线段的折点风格、虚线段的绘制风格和虚线段的绘制偏移量,BasicStroke类提供的所有构造方法如表14.5所示。
表14.5 BasicStroke类提供的所有构造方法线段端点的修饰风格有3种,分别由3个常量表示,具体信息如表14.6所示。
表14.6 线段端点修饰风格简介线段折点的修饰风格同样有3种,也由3个常量表示,具体信息如表14.7所示。
表14.7 线段折点修饰风格简介入口参数dash 用来定义虚线,为float 型数组,当dash 数组由偶数个元素组成时,索引值为偶数的元素值代表虚线段的长度,索引值为奇数的元素值代表两个虚线段之间的空白部分的长度,需要注意的是,数组的索引值是从0开始的;当数组中只有一个元素时,例如dash={6},等同于dash={6,6}。
jfreechart用法例子一、饼图:DefaultPieDataset dataset=new DefaultPieDataset();//开始填充数据dataset.setValue("Java", new Double(43.200000000000003D));dataset.setValue("Visual Basic", new Double(10D));dataset.setValue("C/C++", new Double(17.5D));dataset.setValue("PHP", new Double(32.5D));dataset.setValue("Perl", new Double(12.5D));JFreeChart chart=ChartFactory.createPieChart("2D饼型图",dataset,true,true,true);chart.setTitle("统计图");//设置图片标题ChartRenderingInfo info=new ChartRenderingInfo(new StandardEntityCollection());StringimgaeFileName=ServletUtilities.saveChartAsJPEG(chart,300,200, info,session);//设置生成图片,包括图片的大小,长度是300,宽是200session.setAttribute("image_name1",imageFileName;String URL= request.getContextPath() + "/servlet/DisplayChart?filename=" + filename;//Display为org.jfree.chart.servlet.DisplayChartsession.setAttribute("image_url1",URL);显示代码:(以下显示代码不注明了,是一样的,只是session中的属性名不同而已,大家注意区别)" width=300 height=200 border=0 usemap="#<%=session.getAttribute("image_name1") %>">二、3D饼图DefaultPieDataset defaultpiedataset = new DefaultPieDataset();defaultpiedataset.setValue("Java", new Double(43.200000000000003D));defaultpiedataset.setValue("Visual Basic", new Double(10D));defaultpiedataset.setValue("C/C++", new Double(17.5D));defaultpiedataset.setValue("PHP", new Double(32.5D));defaultpiedataset.setValue("Perl", new Double(12.5D));JFreeChart jfreechart = ChartFactory.createPieChart3D("3D 饼图", defaultpiedataset, true, false, false);PiePlot3D pieplot3d = (PiePlot3D)jfreechart.getPlot();String imageFileName2= ServletUtilities.saveChartAsJPEG(jfreechart,300,200,session);session.setAttribute("image_name2",imageFileName2);StringURL=request.getContextPath()+"/servlet/DisplayChart?filename ="+imageFileName2;session.setAttribute("image_url2",URL);三、柱图DefaultCategoryDataset dataset=new DefaultCategoryDataset();//设置数据源dataset.setValue(new Double(43.200000000000003D),"图解","Java" );dataset.setValue( new Double(10D),"图解","Visual Basic");dataset.setValue(new Double(17.5D), "图解","C/C++");dataset.setValue(new Double(32.5D), "图解","PHP");dataset.setValue(new Double(12.5D), "图解","Perl");//添加数据,参数包括名称和数值JFreeChart chart1=ChartFactory.createBarChart3D("柱图","大人物","地盘", dataset,PlotOrientation.VERTICAL,false,false,false);CategoryPlot plot=chart1.getCategoryPlot();//BarRenderer3D renderer1=new BarRenderer3D();final BarRenderer renderer1 = (BarRenderer)plot.getRenderer();renderer1.setItemLabelGenerator(new StandardCategoryItemLabelGenerator());renderer1.setItemLabelsVisible(true);//显示每个柱子上的数据renderer1.setItemMargin(0.1);//设置每个柱子之间的距离plot.setRenderer(renderer1);//让上面对柱子的设置生效StringimageFileName=ServletUtilities.saveChartAsJPEG(chart1,300,20 0,session);//生成图片,包括图片的大小session.setAttribute("image_name3",imageFileName);StringURL=request.getContextPath()+"/servlet/DisplayChart?filename ="+imageFileName;session.setAttribute("image_url3",URL);四、线图DefaultCategoryDataset defaultcategorydataset = new DefaultCategoryDataset();defaultcategorydataset.addValue(212D, "Classes", "JDK 1.0");defaultcategorydataset.addValue(504D, "Classes", "JDK 1.1");defaultcategorydataset.addValue(1520D, "Classes", "SDK 1.2");defaultcategorydataset.addValue(1842D, "Classes", "SDK 1.3");defaultcategorydataset.addValue(2991D, "Classes", "SDK 1.4");JFreeChart jfreechart = ChartFactory.createLineChart("Java Standard Class Library", "线图", "Class Count", defaultcategorydataset, PlotOrientation.VERTICAL, false, true, false);jfreechart.addSubtitle(new TextTitle("Number of Classes By Release"));TextTitle texttitle = new TextTitle("线图");texttitle.setFont(new Font("SansSerif", 0, 10));texttitle.setPosition(RectangleEdge.BOTTOM);texttitle.setHorizontalAlignment(HorizontalAlignment.RIGH T);jfreechart.addSubtitle(texttitle);jfreechart.setBackgroundPaint(Color.white);CategoryPlot categoryplot = (CategoryPlot)jfreechart.getPlot();categoryplot.setBackgroundPaint(Color.lightGray);categoryplot.setRangeGridlinePaint(Color.white);NumberAxis numberaxis = (NumberAxis)categoryplot.getRangeAxis();numberaxis.setStandardTickUnits(NumberAxis.createInteger TickUnits());LineAndShapeRenderer lineandshaperenderer = (LineAndShapeRenderer)categoryplot.getRenderer();lineandshaperenderer.setShapesVisible(true);lineandshaperenderer.setDrawOutlines(true);lineandshaperenderer.setUseFillPaint(true);lineandshaperenderer.setFillPaint(Color.white);String imageFileName4 = ServletUtilities.saveChartAsJPEG(jfreechart,500,500,session);session.setAttribute("image_name4",imageFileName4);StringURL=request.getContextPath()+"/servlet/DisplayChart?filename ="+imageFileName4;session.setAttribute("image_url4",URL);五、时序图TimeSeries timeseries = new TimeSeries("Random Data");Dayday = new Day(1, 1, 1990);double d = 100D;for(int j = 0; j < 4000; j++)try{d = (d + Math.random()) - 0.5D;timeseries.add(day, new Double(d));day = (Day)day.next();}catch(SeriesException seriesexception){System.err.println("Error adding to series");}XYDataset xydataset = new TimeSeriesCollection(timeseries);JFreeChart jfreechart = ChartFactory.createTimeSeriesChart("时序图", "Day", "Value", xydataset, false, false, false);XYPlot xyplot = (XYPlot)jfreechart.getPlot();XYLineAndShapeRenderer xylineandshaperenderer = new XYLineAndShapeRenderer();xylineandshaperenderer.setDefaultShapesVisible(false);xylineandshaperenderer.setSeriesStroke(0, new BasicStroke(0.5F, 1, 1, 5F, new float[] {5F, 10F}, 0.0F));xyplot.setRenderer(xylineandshaperenderer);String imageFileName5 = ServletUtilities.saveChartAsJPEG(jfreechart,500,500,session);session.setAttribute("image_name5",imageFileName5);StringURL=request.getContextPath()+"/servlet/DisplayChart?filename ="+imageFileName5;session.setAttribute("image_url5",URL);。
Jfreechart中,只要明白两个东西就好办了:dataset(数据集):用来填充需要显示的数据。
plot(绘图):用来绘图,来设置图表的样子。
下面是我自己的一些总结资料:JFreeChart chart=ChartFactory.createBarChart3D("按"+title+"统计", "", "", getdataCategory(S QL,cxtj), PlotOrientation.VERTICAL, true, false, false);// ChartFactory.createBarChart3D( 图表标题, 目录轴的显示标签, 数值轴的显示标签,数据集, 图表方向:水平、垂直, 是否显示图例(对于简单的柱状图必须是false), 是否生成工具, 是否生成URL链接);chart.setBackgroundPaint(Color.white);CategoryPlot plot = chart.getCategoryPlot();BarRenderer render = (BarRenderer) plot.getRenderer();// 2,设置详细图表的显示细节部分的背景颜色plot.setBackgroundPaint(Color.PINK);// 3,设置垂直网格线颜色plot.setDomainGridlinePaint(Color.black);//4,设置是否显示垂直网格线plot.setDomainGridlinesVisible(true);//5,设置水平网格线颜色plot.setRangeGridlinePaint(Color.black);//6,设置是否显示水平网格线plot.setRangeGridlinesVisible(false);/*------设置X轴标题的倾斜程度----*/CategoryAxis domainAxis = plot.getDomainAxis();domainAxis.setCategoryLabelPositions(CategoryLabelPositions.createUpRotationLabelPositions(Math.PI / 6.0));/*------设置柱状体与图片边框的左右间距--*/domainAxis.setLowerMargin(0.01);domainAxis.setUpperMargin(0.01);/*------设置柱状体与图片边框的上下间距---*/ValueAxis rAxis = plot.getRangeAxis();rAxis.setUpperMargin(0.15);rAxis.setLowerMargin(0.15);/*---------设置每一组柱状体之间的间隔---------*/render.setItemMargin(0.0);chart.getRenderingHints().put(RenderingHints.KEY_TEXT_ANTIALIASING, RenderingHints.VALUE_TEXT_ANTIALIAS_OFF);/*----------设置标题字体--------------------------*/TextTitle textTitle = chart.getTitle();textTitle.setFont(new Font("黑体", Font.PLAIN, 20));/*------设置X轴坐标上的文字-----------*/domainAxis.setTickLabelFont(new Font("sans-serif", Font.PLAIN, 14));/*------设置X轴的标题文字------------*/domainAxis.setLabelFont(new Font("宋体", Font.PLAIN, 12));/*------设置Y轴坐标上的文字-----------*/rAxis.setTickLabelFont(new Font("sans-serif", Font.PLAIN, 12));/*------设置Y轴的标题文字------------*/chart.getLegend().setItemFont(new Font("宋体",Font.PLAIN,16));/*------这句代码解决了底部汉字乱码的问题-----------*/rAxis.setLabelFont(new Font("黑体", Font.PLAIN, 12));我目前也正在使用Jfreemark,希望能帮助你,大家相互学习。
使用JFreeChart来创建基于web的图表WWW的发展使得基于因特网的应用程序不再局限于静态或者简单的动态内容提供。
传统的一些以软件包形式发布应用程序例如报表系统等都在逐渐搬到因特网上。
但是这两者之间有着天壤之别,虽然对于数据获取、业务处理等方面基本类似,但是最大的差别在于用户界面。
为了能在web浏览器上显示要求用户界面使用HTML以及图片的方式来展现数据,而传统的一些利用操作系统本身的控件来开发的用户界面无法适应琳琅满目的客户端,因此在这里也变得无能为力。
回到本文的题目上来,为了创建一个可以在web浏览器上查看到图表一般有两种做法:第一种就是使用applet利用java本身对图形的支持来显示一个图表;第二种就是直接在web服务器端生成好图表图片文件后发送给浏览器。
第一种方式显然对于客户端要求太高,随着现在主流浏览器放弃对JAVA的支持后,这种方式只适合一些局域网的应用,而对于因特网的环境就显得不太适合。
因此我们下面将介绍一个JAVA的图表引擎JFreeChart用来产生基于WEB的图表。
一.J FreeChart项目简介JFreeChart是开放源代码站点上的一个JA V A项目,它主要用来各种各样的图表,这些图表包括:饼图、柱状图(普通柱状图以及堆栈柱状图)、线图、区域图、分布图、混合图、甘特图以及一些仪表盘等等。
这些不同式样的图表基本上可以满足目前的要求。
为了减少篇幅本文主要介绍前面三种类型的图表,读者可以触类旁通去开发其他样式的图表。
下面几个是JFreeChart产生的这三种类型图表的结果:图1图2图3上面的三个图都是表示四个季度的某个产品的销量信息。
在继续下面小节之前必须先准备好开发环境,因为是基于WEB浏览器的图表展现,因此需要一个Servlet引擎或者是J2EE应用服务器(例如WebSphere,Tomcat等)。
WEB环境的搭建就不累赘了,读者根据喜好自行安装。
JFreeChart引擎本身需要到上下载,地址如下:下载的时候需要注意的是必须下载两个文件:JFreeChart以及Jcommon。