站内搜索: 请输入搜索关键词

当前页面: 开发资料首页Java 专题用jfreechart来生成统计图表

用jfreechart来生成统计图表

摘要: 本文介绍了一种开放源码的图形制作包jfreechart的使用方法
<body bgcolor="#FFFFFF" text="#000000"> <table width="570" border="0" cellspacing="0" cellpadding="5" bgcolor="FBE392"> <tr> <td> <table width="570" border="0" cellspacing="0" cellpadding="5"> <tr> <td bgcolor="E1B004" width="200" align="center">天极IT资讯短信服务 电脑小技巧
<table width="100%" border="0" cellspacing="0" cellpadding="3" bgcolor="fffcc0"> function check4() { if (dn.mobile.value.length!=11) { alert("手机号码不正确!"); dn.mobile.focus(); return false; } return true; } <form name=dn action="http://www.my5757.com/tj/join.jsp" target=_blank onSubmit="return check4()"> <tr valign=middle> <td>资费:包月5元
手机: <input type=text name=mobile size=11 style="border:1px solid #000000;height=16px"> <input type=image src="http://www.my5757.com/yesky/images/d34.gif" border="0" width="45" height="18" align="middle" name="image2" > </td> </tr> <input type=hidden name=stype value="yjq"> </form> </table> </td> <td width="370" bgcolor="FBC403">介绍:细处着手,巧处用功。高手和菜鸟之间的差别就是:高手什么都知道,菜鸟知道一些。电脑小技巧收集最新奇招高招,让你轻松踏上高手之路。(首月免费) </td> </tr> </table> </td> </tr> </table>

  在工作中,我们常常碰到需要在网页上绘制统计图的例子。其实实现的办法有很多,我们可以亲自编写全部图形生成代码,比如用flash,或者用svg,这样做代码量很大,还容易出错,很烦的。也可以利用现成的java统计图表库。例如用jclass(http://java.quest.com/jclass/jclass.shtml),可是这玩艺却是要收费的。对于我们这种崇尚open source的程序员来说,有没有一个开源的统计图形库呢。有,它就是www.jfree.org推出的jfreecha rt包,它从柱形图,饼形图,到雷达图,蜡烛图等等无所不包,可以在c/s,b/s,甚至是实时环境都能一显身手。最关键的是它是open source!我在这里给出一个在网页上绘制饼形图的简单例子。

<iframe width="360" height="300" align="right"scrolling="No" frameborder="0" marginheight="0" marginwidth="0" SRC="http://images.chinabyte.com/adjs/iframe-pip/y-software-pip.html"></iframe>

  1、到www.jfree.org下载一个最新的java库,置jfreechart.jar和jcommon.jar.jar于classpath中

  2、编写一个java bean,用来生成饼形图。(GSPieChart.java)

<table width="100%" bgColor=#ffffff> <tr> <td>package gov.gwssi.tax.nspg.datadisposal;
import java.awt.Insets;
import java.awt.Image;
import java.io.PrintWriter;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.Locale;
import java.text.NumberFormat;
import javax.servlet.http.HttpSession;
import org.jfree.data.*;
import org.jfree.chart.*;
import org.jfree.chart.axis.*;
import org.jfree.chart.renderer.VerticalBarRenderer;
import org.jfree.chart.renderer.StandardXYItemRenderer;
import org.jfree.chart.plot.*;
import org.jfree.chart.entity.*;
import org.jfree.chart.tooltips.*;
import org.jfree.chart.urls.*;
import org.jfree.chart.servlet.*;
import java.awt.Font;

/**
 * <p>Title: </p>
 * <p>Description: </p>
 * <p>Copyright: Copyright (c) 2003</p>
 * <p>Company: </p>
 * @author jagie
 * @version 1.0
*/

public class GSPieChart
{
 public static void main(String[] args)
 {
  Long[] testData =
   {
    new Long(10), new Long(20), new Long(30), new Long(40)
   } ;
 generatePieChart(testData, "", null, new PrintWriter(System.out), 580, 250);
}

/**
 * 生成图像文件
 * @param datas Long[]数组
 * @param targetUrl 点饼形图上的扇形,定向到的url
 * @param session httpsession
 * @param pw PrintWriter
 * @param w 生成的图的宽度
 * @param h 生成的图的高度
 * @return 生成的图像文件的路径
*/

public static String generatePieChart
 (Long[] datas, String targetUrl,
  HttpSession session,
  PrintWriter pw, int w, int h)
 {
  String filename = null;
  try
  {
   DefaultPieDataset data = new DefaultPieDataset();
   data.setValue("正常纳税人", datas[0]);
   data.setValue("异常纳税人", datas[1]);
   data.setValue("数据不全纳税人", datas[2]);
   data.setValue("未处理纳税人", datas[3]);
   // Create the chart object < BR>   Pie3DPlot plot = new Pie3DPlot(data);
   plot.setInsets(new Insets(0, 5, 5, 5));
   plot.setForegroundAlpha(0.6f);
   plot.setSectionLabelType(plot.NO_LABELS);
   plot.setURLGenerator(new StandardPieURLGenerator(targetUrl, "type"));
   plot.setToolTipGenerator(new StandardPieToolTipGenerator());
   JFreeChart chart = new JFreeChart("数据处理结果统计图", JFreeChart.DEFAULT_TITLE_FONT, plot, true);
   chart.setTitle(new TextTitle("数据处理结果统计图", new Font("黑体", Font.BOLD, 15)));
   StandardLegend sl = (StandardLegend) chart.getLegend();
   sl.setItemFont(new Font("黑体", Font.TRUETYPE_FONT, 12));
   chart.setBackgroundPaint(new java.awt.Color(254, 254, 141));
   // 因为jfreechart把生成的png文件保存在系统的临时文件夹中,你需要在适当的
   //时候调用session.removeAttribute("JFreeChart_Deleter"),这样可以保证png文
   //件被删除掉
   ChartRenderingInfo info = new ChartRenderingInfo(new StandardEntityCollection());
   filename = ServletUtilities.saveChartAsPNG(chart, w, h, info, session);
   // Write the image map to the PrintWriter
   ChartUtilities.writeImageMap(pw, filename, info); pw.flush();
  } catch (Exception e)
   {
    System.out.println("Exception - " + e.toString());
    e.printStackTrace(System.out);
    filename = "public_error_500x300.png";
   }
  return filename;
 }
}</td></tr></table>

  3、在一个jsp文件中使用这个javabean来生成图像,以下是代码片断

.........java代码.................

<table width="100%" bgColor=#ffffff> <tr> <td><%
 //以下部分为图象输出

 String argetUrl="../servlet/gov.gwssi.tax.nspg.controlservlet.GSMainControlServlet?id="+sid;Long[] datas={normals,new Long(totalAbnormal),dataLacks,notProcesses};

String filename=GSPieChart.generatePieChart(datas,targetUrl,session,new PrintWriter(out),580,250);

String graphURL = request.getContextPath() + "/servlet/DisplayChart?filename=" + filename;
%></td></tr></table>
.......html代码................

<table width="100%" bgColor=#ffffff> <tr> <td><!-- pie chart -->
<table width="580" border="0" cellspacing="0" cellpadding="0">
<tr>
<td>
<img src="<%= graphURL %>" width=580 height=250 border=0 usemap="#<%=filename %>">
</td>
</tr>
</table></td></tr></table>
  4、在web.xml中配置jfreechart的图像生成的servlet

<table width="100%" bgColor=#ffffff> <tr> <td><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></td></tr></table>
  以上就是在b/s中使用jfreechart的大体步骤,在你下载的jfreechart的sample文件夹中找到jfreechart-sample.war文件中也有类似的例子,只不过复杂一些。

  最后,希望这篇文章能对你有所启发。如有错误之处,欢迎批评指正。



↑返回目录
前一篇: Java技巧:列表排序
后一篇: Java.io彻底研究