Java图表绘制和操作excel表格(转)

http://www.javaeye.com/topic/507427

 

今天学习了Java中使用JFreeChart,POI,JXL绘制图表,操作excel表格问题,自己动手了写了些小demo,不足之处,请大家指正。谢谢。 ^_^
完整的类文件在附件中。并附上一张截图
====================================
代码『片段』
====================================

Java代码
  1. /** 
  2.      * 根据数据设置图表的相关信息 
  3.      * @param categoryDataset 
  4.      * @return 
  5.      */  
  6.     public static JFreeChart createJFreeChart(CategoryDataset categoryDataset) {  
  7.         /** 
  8.          * 设置图表的相关信息,其参数依次为: 
  9.          * 图表标题,纵坐标显示提示,横坐标显示提示,要显示的数据 
  10.          * 设置要显示图标柱状的横向或纵向.HORIZONTAL表示纵向,VERTICAL表示横向 
  11.          * 后面三个boolean型的参数: 
  12.          * 第一个表示是否显示柱状图例,true为显示,false为不显示 
  13.          */  
  14.         JFreeChart chart = ChartFactory.createBarChart("学生人数统计""省份""数量",  
  15.                 categoryDataset, PlotOrientation.VERTICAL, truetruefalse);  
  16.         // 设置背景颜色  
  17.         chart.setBackgroundPaint(Color.WHITE);  
  18.         CategoryPlot cateforyPlot = chart.getCategoryPlot();  
  19.         cateforyPlot.setBackgroundPaint(Color.WHITE);  
  20.         cateforyPlot.setDomainGridlinePaint(Color.WHITE);  
  21.         // 设置是否可见  
  22.         cateforyPlot.setDomainGridlinesVisible(true);  
  23.         // 设置柱状的颜色  
  24.         cateforyPlot.setRangeGridlinePaint(Color.BLUE);  
  25.         return chart;  
  26.     }  
  27.   
  28.     /** 
  29.      * 生成二维的柱状图 
  30.      * @param session 客户端当前session 
  31.      * @param out 输出流 
  32.      * @return 返回所生成图片的URL 
  33.      */  
  34.     public static String getBarChartURL(HttpSession session, PrintWriter out) {  
  35.         String fileName = "";  
  36.         //调用静态的方法获取数据集  
  37.         CategoryDataset categoryDataset = getDataSet();  
  38.         //调用类中静态方法创建图表对象  
  39.         JFreeChart chart = createJFreeChart(categoryDataset);  
  40.         ChartRenderingInfo chartInfo = new ChartRenderingInfo(  
  41.                 new StandardEntityCollection());  
  42.         try {  
  43.             //将生成的图片以PNG文件格式显示  
  44.             fileName = ServletUtilities.saveChartAsPNG(chart, 500300,  
  45.                     chartInfo, session);  
  46.         } catch (IOException e) {  
  47.             e.printStackTrace();  
  48.         }  
  49.         try {  
  50.             //向客户端显示图片  
  51.             ChartUtilities.writeImageMap(out, fileName, chartInfo, true);  
  52.         } catch (IOException e) {  
  53.             e.printStackTrace();  
  54.         }  
  55.         out.flush();  
  56.         return fileName;  
  57.     }  
/** * 根据数据设置图表的相关信息 * @param categoryDataset * @return */public static JFreeChart createJFreeChart(CategoryDataset categoryDataset) {/** * 设置图表的相关信息,其参数依次为: * 图表标题,纵坐标显示提示,横坐标显示提示,要显示的数据 * 设置要显示图标柱状的横向或纵向.HORIZONTAL表示纵向,VERTICAL表示横向 * 后面三个boolean型的参数: * 第一个表示是否显示柱状图例,true为显示,false为不显示 */JFreeChart chart = ChartFactory.createBarChart("学生人数统计", "省份", "数量",categoryDataset, PlotOrientation.VERTICAL, true, true, false);// 设置背景颜色chart.setBackgroundPaint(Color.WHITE);CategoryPlot cateforyPlot = chart.getCategoryPlot();cateforyPlot.setBackgroundPaint(Color.WHITE);cateforyPlot.setDomainGridlinePaint(Color.WHITE);// 设置是否可见cateforyPlot.setDomainGridlinesVisible(true);// 设置柱状的颜色cateforyPlot.setRangeGridlinePaint(Color.BLUE);return chart;}/** * 生成二维的柱状图 * @param session 客户端当前session * @param out 输出流 * @return 返回所生成图片的URL */public static String getBarChartURL(HttpSession session, PrintWriter out) {String fileName = "";//调用静态的方法获取数据集CategoryDataset categoryDataset = getDataSet();//调用类中静态方法创建图表对象JFreeChart chart = createJFreeChart(categoryDataset);ChartRenderingInfo chartInfo = new ChartRenderingInfo(new StandardEntityCollection());try {//将生成的图片以PNG文件格式显示fileName = ServletUtilities.saveChartAsPNG(chart, 500, 300,chartInfo, session);} catch (IOException e) {e.printStackTrace();}try {//向客户端显示图片ChartUtilities.writeImageMap(out, fileName, chartInfo, true);} catch (IOException e) {e.printStackTrace();}out.flush();return fileName;}

 

66aa233e-2007-356f-8b58-b640392e3b5d.png

转载于:https://www.cnblogs.com/guoxu/articles/1733970.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值