快速业务通道

用JFreeChart创建基于Web的图表 - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-23
的不是同一个数据集类,另外饼图不支持同一个类别的项目中还有子项目这样的数据。我们只给出创建饼图的代码,至于写图表到一个文件则与柱状图一致,无需重复。

[code] package lius.chart.demo; import java.io.*; import org.jfree.data.*; import org.jfree.chart.*; /** * 用于演示饼图的生成 * @author Winter Lau */ public class PieChartDemo {  public static void main(String[] args) throws IOException{   DefaultPieDataset data = getDataSet();   JFreeChart chart = ChartFactory.createPie3DChart("水果产量图", // 图表标题    data,    true, // 是否显示图例    false,    false   );   //写图表对象到文件,参照柱状图生成源码   } /** * 获取一个演示用的简单数据集对象 * @return */  private static DefaultPieDataset getDataSet() {   DefaultPieDataset dataset = new DefaultPieDataset();   dataset.setvalue("苹果",100);   dataset.setvalue("梨子",200);   dataset.setvalue("葡萄",300);   dataset.setvalue("香蕉",400);   dataset.setvalue("荔枝",500);   return dataset;  } } [/code]

生成的饼图文件效果如下:

用JFreeChart创建基于Web的图表 - 编程入门网

图6

用JFreeChart创建基于Web的图表(5)

时间:2010-12-11

四、将生成的图表移到浏览器上

为了将生成的图表直接传给客户端浏览器,只需要将前面两个例子中的文件流换成是通过HttpServletResponse对象获取到的输出流,详细代码清单如下:

package lius.chart.demo; import java.io.IOException; import javax.servlet.*; import javax.servlet.http.HttpServlet; import org.jfree.data.*; import org.jfree.chart.*; /** * 演示通过servlet直接输出图表 * @author Winter Lau */ public class ChartDemoServlet extends HttpServlet { public void service(ServletRequest req, ServletResponse res) throws ServletException, IOException {  res.setContentType("image/jpeg");  DefaultPieDataset data = getDataSet();  JFreeChart chart = ChartFactory.createPie3DChart("水果产量图",   data,   true,   false,   false  );  ChartUtilities.writeChartAsJPEG(res.getOutputStream(),100,chart,400,300,null); } /** * 获取一个演示用的简单数据集对象 * @return */ private static DefaultPieDataset getDataSet() {  DefaultPieDataset dataset = new DefaultPieDataset();  dataset.setvalue("苹果",100);  dataset.setvalue("梨子",200);  dataset.setvalue("葡萄",300);  dataset.setvalue("香蕉",400);  dataset.setvalue("荔枝",500);  return dataset; } }

高级主题

很多情况我们不仅仅要求可以在浏览器上显示一个图表,我们更需要客户可以直接在图表上做一下交互的操作,例如获取信息提示,点击图表某个部分进行更详细信息的展示等等。例如前面生成的简单柱状图,用户需要在看到柱状图后点击某种水果例如是苹果即可看到各个地区苹果产量的情况。为此就要求该图形具有交互操作的功能。在HTML中为了让一个图像具有可交互的功能就必须给该图像定义一个Map对象。下表节选一段具有该功能的HTML代码

<MAP NAME="chartMap"> <AREA SHAPE="RECT" COORDS="81,15,126,254" href="?series=0&category=100" title="100 = 7,048" onclick="javascript:clickChart(''100'');retur

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号