JFreeChart在JSP中的应用实例

前段时间,也就是去年,在做一个项目的时候有这样一个需求,根据用户在Web页面上向服务器提交的数据,根据条件从数据库中取出相应的一系列数据后,要能在web浏览器上以图表的形式显示结果,形成直观的对比,于是就要我们实现饼图,柱图的动态生成。在网上找了很久,找到了JFreeChart这么一个东西。

JFreeChart
  是一个开源的   JAVA   项目,它主要用来开发各种各样的图表,这些图表包括:饼图、柱状图   (   普通柱状图以及堆栈柱状图   )   、线图、区域图、分布图、混合图、甘特图以及一些仪表盘等等。在这些不同式样的图表上可以满足目前商业系统的要求。   JFreeChart   是一种基于   JAVA   语言的图表开发技术。   JFreeChart   可用于   Servlet     JSP   Applet     Java Appication   环境中,通过   JDBC   可动态显示任何数据库数据,结合   Itext   可以输出至   PDF   文件。

这个东西正符合我们的需求,于是对他进行了研究并试验。前些时间懒,一直没有把研究测试心得写出来,现在闲下来,整理了一下,搞两个例子放上来供大家参考吧。


一、饼图实例

jsp页面:index.jsp

<% @ page contentType="text/html;charset=GBK" %>
<% @ page import="org.jfree.data.general.DefaultPieDataset" %>
<% @ page import="org.jfree.chart.*" %>
<% @ page import="org.jfree.chart.plot.*" %>
<% @ page import="org.jfree.chart.servlet.ServletUtilities" %>
<% @ page import="org.jfree.chart.labels.StandardPieToolTipGenerator" %>
<% @ page import="org.jfree.chart.urls.StandardPieURLGenerator" %>
<% @ page import="org.jfree.chart.entity.StandardEntityCollection" %>
<% @ page import="java.io.*" %>

< HTML > 
< HEAD > 
< META  http-equiv =Content-Type  content ="text/html; charset=GBK" > 
< META  NAME ="Author"  CONTENT ="Alpha" >
< TITLE >程序员学历情况调查表-By Alpha </ TITLE > 
</ HEAD > 
< BODY > 
<%
            DefaultPieDataset data 
= new DefaultPieDataset(); 
            
//数据初始化
            data.setValue(
"高中以下",380); 
            data.setValue(
"高中",1620); 
            data.setValue(
"大专",6100); 
            data.setValue(
"本科",8310); 
            data.setValue(
"硕士",3520); 
            data.setValue(
"博士",180); 
            
            
//HttpSession session = request.getSession();

            PiePlot3D plot 
= new PiePlot3D(data);//生成一个3D饼图 
            
//plot.setURLGenerator(new StandardPieURLGenerator("DegreedView.jsp"));//设定图片链接 
            JFreeChart chart 
= new JFreeChart("",JFreeChart.DEFAULT_TITLE_FONT, plot, true); 
            chart.setBackgroundPaint(java.awt.Color.white);
//可选,设置图片背景色 
            chart.setTitle(
"程序员学历情况调查表-By Alpha");//可选,设置图片标题 
            plot.setToolTipGenerator(
new StandardPieToolTipGenerator()); 
            StandardEntityCollection sec 
= new StandardEntityCollection(); 
            ChartRenderingInfo info 
= new ChartRenderingInfo(sec); 
            PrintWriter w 
= new PrintWriter(out);//输出MAP信息 
            
//500是图片长度,300是图片高度
            
//String filename = ServletUtilities.saveChartAsPNG(chart,500,300,info,session); 
            
String filename = ServletUtilities.saveChartAsJPEG(chart,500,300,info,session); 
            ChartUtilities.writeImageMap(w,
"map0",info,false); 

            
String graphURL = request.getContextPath() + "/servlet/DisplayChart?filename=" + filename;
%> 

< ALIGN ="CENTER" > 
< img  src ="<%= graphURL %>"  width =500  height =300  border =0  usemap ="#map0" > 
</ P > 
</ BODY > 
</ HTML >

本例效果图:



二、柱图实例

jsp页面:index1.jsp

<%  @page contentType  =  "  text/html; charset=GB2312  "  %> 

<%  @page import  =  "  java.io.FileNotFoundException  "  %> 
<%  @page import  =  "  java.io.FileOutputStream  "  %> 
<%  @page import  =  "  org.apache.commons.logging.Log  "  %> 
<%  @page import  =  "  java.io.IOException  "  %> 

<%  @page import  =  "  org.apache.commons.logging.LogFactory  "  %> 
<%  @page import  =  "  org.jfree.chart.ChartFactory  "  %> 
<%  @page import  =  "  org.jfree.chart.ChartUtilities  "  %> 
<%  @page import  =  "  org.jfree.chart.JFreeChart  "  %> 
<%  @page import  =  "  org.jfree.chart.plot.PlotOrientation  "  %> 
<%  @page import  =  "  org.jfree.data.category.CategoryDataset  "  %> 
<%  @page import  =  "  org.jfree.data.category.DefaultCategoryDataset  "  %> 

<%  @page import  =  "  java.awt.Color  "  %> 
<%  @page import  =  "  org.jfree.chart.renderer.category.BarRenderer3D  "  %> 
<%  @page import  =  "  org.jfree.chart.labels.StandardCategoryItemLabelGenerator  "  %> 
<%  @page import  =  "  org.jfree.chart.axis.CategoryAxis  "  %> 
<%  @page import  =  "  org.jfree.chart.plot.CategoryPlot  "  %> 

<% 
  DefaultCategoryDataset dataset    
  =     new   DefaultCategoryDataset();
  dataset.addValue(
  150    "  北京  "    "  苹果  "  );
  dataset.addValue(
  530    "  上海  "    "  苹果  "  );
  dataset.addValue(
  160    "  广州  "    "  苹果  "  );
  dataset.addValue(
  120    "  北京  "    "  梨子  "  );
  dataset.addValue(
  230    "  上海  "    "  梨子  "  );
  dataset.addValue(
  360    "  广州  "    "  梨子  "  );
  dataset.addValue(
  600    "  北京  "    "  葡萄  "  );
  dataset.addValue(
  430    "  上海  "    "  葡萄  "  );
  dataset.addValue(
  560    "  广州  "    "  葡萄  "  );
  dataset.addValue(
  400    "  北京  "    "  香蕉  "  );
  dataset.addValue(
  530    "  上海  "    "  香蕉  "  );
  dataset.addValue(
  660    "  广州  "    "  香蕉  "  );
  dataset.addValue(
  500    "  北京  "    "  荔枝  "  );
  dataset.addValue(
  630    "  上海  "    "  荔枝  "  );
  dataset.addValue(
  430    "  广州  "    "  荔枝  "  );
  
    JFreeChart chart 
  =   ChartFactory.createBarChart3D(  "  水果销量图统计-By Alpha  "  ,  "  水果种类-http://www.blogjava.net/Alpha/  "  ,  "  销量  " ,dataset,PlotOrientation.VERTICAL,  true  ,  false  ,  false  );
        chart.setBackgroundPaint(Color.WHITE);
        CategoryPlot plot 
  =   chart.getCategoryPlot();

        CategoryAxis domainAxis 
  =   plot.getDomainAxis();
        
  //  domainAxis.setVerticalCategoryLabels(  false  );
        plot.setDomainAxis(domainAxis);

        BarRenderer3D renderer 
  =     new   BarRenderer3D();
        renderer.setBaseOutlinePaint(Color.BLACK);

        
  //  设置每个地区所包含的平行柱的之间距离
        renderer.setItemMargin(
  0.1  );
        
  //  显示每个柱的数值,并修改该数值的字体属性
        renderer.setItemLabelGenerator(
  new   StandardCategoryItemLabelGenerator());
        renderer.setItemLabelsVisible(
  true  );
        plot.setRenderer(renderer);

        
  //   设置柱的透明度
        plot.setForegroundAlpha(
  0  .8f);

    ChartUtilities.writeChartAsJPEG(response.getOutputStream(),chart,
  640  ,  400  );
%> 


本例效果图:




三、服务配制

    
web.xml文件的配制一直困扰了我很久,之前在网上找到的配制都是有问题的,搞得生成出来的图形显示不出来,后来自己才把这个配制研究成功,网上的东西也很不可靠,找了N多配制,都是一样的,同现同样的问题,看来都是转来转去的结果 。

web.xml 文件

<?  xml version="1.0" encoding="ISO-8859-1"  ?> 

<!  DOCTYPE web-app
    PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN"
    "http://java.sun.com/dtd/web-app_2_3.dtd"
  > 

<  web-app  > 

      <  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  > 

      <  welcome-file-list  > 
          <  welcome-file  > index.jsp  </  welcome-file  > 
      </  welcome-file-list  > 
    
</  web-app  > 


补充:(07.5.4更新)
新增甘特图的例子与上面例子所有源代码一起打包提供下载,下载后直接部署就可以运行了。 

点击下载
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值