最近项目在频繁的操作excel,里边涉及到很多和图表有关的东西。有时候需要使用java操作excel自带的图标,比较复杂的我们都是使用excel模板的形式实现。

除此之外,也有一些功能只需要生成对应的图标样式的图片就好,我们实现的时候主要用了两种方式,一种就是由前台生成图片base64码,然后后台解码生成图片插入到excel,但是这种方式有 一定的局限性,也就是当某些功能需要后台定时生成excel的时候,就无法获取这个图片。

于是我们采用了另一种方法,也就是是用jfreechart生成对应的图片,然后结合poi插入到excel对应的位置,下图是项目中使用后的真实效果:

图1是前端base64码生成的:



图2是后台jfreechart生成的:

以下是抽空做的一个简单的整理:

1、maven导包:

  1. <dependency>
  2. <groupId>org.apache.poi</groupId>
  3. <artifactId>poi-ooxml</artifactId>
  4. <version>3.8</version>
  5. </dependency>
  6. <dependency>
  7. <groupId>org.apache.poi</groupId>
  8. <artifactId>poi-scratchpad</artifactId>
  9. <version>3.8</version>
  10. </dependency>
  11. <dependency>
  12. <groupId>jfree</groupId>
  13. <artifactId>jfreechart</artifactId>
  14. <version>1.0.13</version>
  15. </dependency>

2、java测试main方法代码:

  1. package test;
  2. import java.awt.BasicStroke;
  3. import java.awt.Color;
  4. import java.awt.Font;
  5. import java.awt.image.BufferedImage;
  6. import java.io.ByteArrayOutputStream;
  7. import java.io.File;
  8. import java.io.FileOutputStream;
  9. import java.io.IOException;
  10. import java.util.ArrayList;
  11. import java.util.List;
  12. import javax.imageio.ImageIO;
  13. import org.apache.poi.hssf.usermodel.HSSFClientAnchor;
  14. import org.apache.poi.hssf.usermodel.HSSFPatriarch;
  15. import org.apache.poi.hssf.usermodel.HSSFSheet;
  16. import org.apache.poi.hssf.usermodel.HSSFWorkbook;
  17. import org.jfree.chart.ChartColor;
  18. import org.jfree.chart.ChartFactory;
  19. import org.jfree.chart.ChartUtilities;
  20. import org.jfree.chart.JFreeChart;
  21. import org.jfree.chart.axis.CategoryAxis;
  22. import org.jfree.chart.axis.CategoryLabelPositions;
  23. import org.jfree.chart.axis.NumberAxis;
  24. import org.jfree.chart.axis.NumberTickUnit;
  25. import org.jfree.chart.axis.ValueAxis;
  26. import org.jfree.chart.plot.CategoryPlot;
  27. import org.jfree.chart.plot.PlotOrientation;
  28. import org.jfree.chart.renderer.category.LineAndShapeRenderer;
  29. import org.jfree.chart.title.LegendTitle;
  30. import org.jfree.chart.title.TextTitle;
  31. import org.jfree.data.category.DefaultCategoryDataset;
  32. import org.jfree.ui.RectangleEdge;
  33. /**
  34. * 结合poi和jfreechart创建图表图片
  35. *
  36. * @author tuzongxun
  37. * @date 2016年9月19日 上午10:55:09
  38. */
  39. public class ExcelDemo2 {
  40. public static void main(String[] args) throws Exception {
  41. // excel2003工作表
  42. HSSFWorkbook wb = new HSSFWorkbook();
  43. HSSFSheet sheet = wb.createSheet("Sheet 1");
  44. ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream();
  45. ;
  46. // 设置具体数据
  47. List<String> timeList = new ArrayList<String>();
  48. timeList.add("10:00");
  49. timeList.add("11:00");
  50. timeList.add("12:00");
  51. List<Integer> appList = new ArrayList<Integer>();
  52. appList.add(120);
  53. appList.add(200);
  54. appList.add(150);
  55. List<Integer> oraList = new ArrayList<Integer>();
  56. oraList.add(230);
  57. oraList.add(200);
  58. oraList.add(235);
  59. // 设置图片中的字体和颜色以及字号
  60. Font titleFont = new Font("黑体", Font.BOLD, 12);
  61. Font xfont = new Font("黑体", Font.BOLD, 10);
  62. Font labelFont = new Font("黑体", Font.BOLD, 10);
  63. // 设置数据区域
  64. DefaultCategoryDataset dataset = new DefaultCategoryDataset();
  65. for (int i = 0; i < timeList.size(); i++) {
  66. String time = timeList.get(i);
  67. dataset.addValue(appList.get(i), "苹果", time);
  68. dataset.addValue(oraList.get(i), "橘子", time);
  69. }
  70. JFreeChart chart = ChartFactory.createLineChart("水果时间段销量", "时间", "销量", dataset, PlotOrientation.VERTICAL, true,
  71. true, true);
  72. // 设置图例字体
  73. chart.getLegend().setItemFont(new Font("黑体", Font.BOLD, 10));
  74. // 设置标题字体
  75. chart.setTitle(new TextTitle(chart.getTitle().getText(), titleFont));
  76. // 图形的绘制结构对象
  77. CategoryPlot plot = chart.getCategoryPlot();
  78. // 获取显示线条的对象
  79. LineAndShapeRenderer lasp = (LineAndShapeRenderer) plot.getRenderer();
  80. // 设置拐点是否可见/是否显示拐点
  81. lasp.setBaseShapesVisible(true);
  82. // 设置拐点不同用不同的形状
  83. lasp.setDrawOutlines(true);
  84. // 设置线条是否被显示填充颜色
  85. lasp.setUseFillPaint(false);
  86. LineAndShapeRenderer renderer = (LineAndShapeRenderer) plot.getRenderer();
  87. // 设置折线大小以及折线的颜色
  88. renderer.setSeriesStroke(0, new BasicStroke(1.0F));
  89. renderer.setSeriesPaint(0, new Color(210, 105, 30));
  90. renderer.setSeriesStroke(1, new BasicStroke(1.0F));
  91. renderer.setSeriesPaint(1, new Color(0, 191, 255));
  92. // 设置折点的大小
  93. lasp.setSeriesOutlineStroke(0, new BasicStroke(0.025F));
  94. lasp.setSeriesOutlineStroke(1, new BasicStroke(0.05F));
  95. // 设置网格线
  96. plot.setDomainGridlinePaint(Color.gray);
  97. plot.setDomainGridlinesVisible(true);
  98. plot.setRangeGridlinePaint(Color.gray);
  99. plot.setRangeGridlinesVisible(true);
  100. // x轴
  101. CategoryAxis domainAxis = plot.getDomainAxis();
  102. // 设置x轴不显示,即让x轴和数据区重合
  103. domainAxis.setAxisLineVisible(false);
  104. // x轴标题
  105. domainAxis.setLabelFont(xfont);
  106. // x轴数据倾斜
  107. domainAxis.setCategoryLabelPositions(CategoryLabelPositions.createUpRotationLabelPositions(0.95D));
  108. // X轴坐标上数值字体
  109. domainAxis.setTickLabelFont(labelFont);
  110. // 设置Y轴间隔
  111. NumberAxis numAxis = (NumberAxis) plot.getRangeAxis();
  112. numAxis.setTickUnit(new NumberTickUnit(50));
  113. // y轴
  114. ValueAxis rangeAxis = plot.getRangeAxis();
  115. rangeAxis.setLabelFont(xfont);
  116. // 设置y轴不显示,即和数据区重合
  117. rangeAxis.setAxisLineVisible(false);
  118. // y轴坐标上数值字体
  119. rangeAxis.setTickLabelFont(labelFont);
  120. rangeAxis.setFixedDimension(0);
  121. CategoryPlot cp = chart.getCategoryPlot();
  122. // 背景色设置
  123. cp.setBackgroundPaint(ChartColor.WHITE);
  124. cp.setRangeGridlinePaint(ChartColor.GRAY);
  125. // 创建图例,设置图例的位置,这里的设置实际不起作用,怎么设都在下边
  126. LegendTitle legendTitle = new LegendTitle(chart.getPlot());
  127. legendTitle.setPosition(RectangleEdge.BOTTOM);
  128. try {
  129. ChartUtilities.writeChartAsPNG(byteArrayOut, chart, 400, 200);
  130. String fileSavePath = "exTest.png";
  131. BufferedImage bufferImg = ImageIO.read(new File(fileSavePath));
  132. ImageIO.write(bufferImg, "png", byteArrayOut);
  133. } catch (IOException e) {
  134. }
  135. // 画图的顶级管理器,一个sheet只能获取一个(一定要注意这点)
  136. HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
  137. // 八个参数,前四个表示图片离起始单元格和结束单元格边缘的位置,
  138. // 后四个表示起始和结束单元格的位置,如下表示从第2列到第12列,从第1行到第15行,需要注意excel起始位置是0
  139. HSSFClientAnchor anchor = new HSSFClientAnchor(0, 0, 0, 0, (short) 2, (short) 1, (short) 12, (short) 15);
  140. anchor.setAnchorType(3);
  141. // 插入图片
  142. patriarch.createPicture(anchor, wb.addPicture(byteArrayOut.toByteArray(), HSSFWorkbook.PICTURE_TYPE_PNG));
  143. // excel2003后缀
  144. FileOutputStream fileOut = new FileOutputStream("exTest.xls");
  145. wb.write(fileOut);
  146. fileOut.close();
  147. }
  148. }

结果如图:

使用poi和jfreechart生成excel图表图片的更多相关文章

  1. 利用JFreeChart生成组合图表 (8) (转自 JSP开发技术大全)

    利用JFreeChart生成组合图表 (8) (转自 JSP开发技术大全) 14.8 利用JFreeChart生成组合图表  实例位置:光盘\mingrisoft\14\dxyy\02 通过JFree ...

  2. JAVA生成EXCEL图表

    跟据客户的要求,需要开发一套包括图形的报表,还需要导出WORD 图表需要这样: 这样: 这样: 还有这样: 接下来是实现思路: 以往用的最多的就是JFreechart,手上也有实现各种图形的资源,但是 ...

  3. phantomjs server + highchart 在服务器端生成highchart图表图片

    前言 当项目需要将一个highchart图表以邮件发送的时候,js+css形式的highcharts 图表肯定是不好做的,有查可以借助flash去执行js,但很麻烦,所以折中将highchart图表转 ...

  4. python生成Excel图表(通过xlsxwriter)

    前面介绍了pandas的简单用法,pandas的数据可以通过matlab第三方包将数据生成报表,但是我想将报表生成在Excel中,这时候就可以借助xlsxwriter第三方包来生成图标   缺点:xl ...

  5. 【JAVA】POI生成EXCEL图表(柱状图、折线等)

    1.使用excel工具自带的图形工具创建一个图: 2.绑定数据区域: 3.数据区域绑定完成,我们要做的就是将数据写入到数据区域中: 4.标记 5.POI 引入包 <!-- https://mvn ...

  6. springboot2.1.8使用poi导出数据生成excel(.xlsx)文件

    前言:在实际开发中经常需要将数据库的数据导出成excel文件,poi方式则是其中一种较为常用的导出框架.简单读取excel文件在之前的一篇有说明 本项目实现需求:user发出一个导出student信息 ...

  7. 是用Epplus生成Excel 图表

    1.  前言 这是我最近项目刚要的需求,然后在网上找了半天的教材  但是很不幸,有关于Epplus的介绍真的太少了,然后经过了我的不断研究然后不断的采坑,知道现在看到Excel都想吐的时候,终于成功的 ...

  8. POI tools 参数化生成excel表格

    package com.eccom.neteagle.server.confsave.service.impl; import java.io.File; import java.io.FileNot ...

  9. 使用Epplus生成Excel 图表

    1.  前言 这是我最近项目刚要的需求,然后在网上找了半天的教材  但是很不幸,有关于Epplus的介绍真的太少了,然后经过了我的不断研究然后不断的采坑,知道现在看到Excel都想吐的时候,终于成功的 ...

随机推荐

  1. python --- 基础多线程编程

    在python中进行多线程编程之前必须了解的问题: 1. 什么是线程? 答:线程是程序中一个单一的顺序控制流程.进程内一个相对独立的.可调度的执行单元,是系统独立调度和分派CPU的基本单位指运行中的程 ...

  2. java对象引用-要掌握的细节

    hello ,好久没来了. 今天我来和大家分享一下有关引用变量的注意事项,一是加深一下自己的理解,二是对这块不太理解的同学可以看看. 大神可飘过,有什么不对或不足的地方请多多指教,谢谢. 假设场景: ...

  3. FC经典游戏还原之:松鼠大作战2

    版权声明:本文原创发布于博客园"优梦创客"的博客空间(id:raymondking123) 原帖地址:http://www.cnblogs.com/raymondking123/p ...

  4. AWWWB.COM网站克隆器

    AWWWB.COM建议收费软件实行免费化的倡议书:AWWWB.COM原打算对软件中的高级功能收取260元的注册费,但是,考虑到网友使用软件的同时也是对软件的支持和传播,所以,放弃收费计划,实施一种免费 ...

  5. Spring源码情操陶冶-PropertyPlaceholderBeanDefinitionParser注解配置解析器

    本文针对spring配置的context:property-placeholder作下简单的分析,承接前文Spring源码情操陶冶-自定义节点的解析 spring配置文件应用 <context: ...

  6. java 世界中Annotation

    java 世界中Annotation 在github上开始汇总一些自己学习,收集,总结,经验的一些信息,有利于跟踪,修改,提升.如果你感兴趣 可以关注一下,也可以提供自己的内容进来. https:// ...

  7. python实现时间o(1)的最小栈

    这是毕业校招二面时遇到的手写编程题,当时刚刚开始学习python,整个栈写下来也是费了不少时间.毕竟语言只是工具,只要想清楚实现,使用任何语言都能快速的写出来. 何为最小栈?栈最基础的操作是压栈(pu ...

  8. xcode7中使用cocos2d-x3.8的webview控件

    在XCode7中使用cocos2d-x 3.3以上版本的WebView控件时,碰到了编译错误 App Transport Security has blocked a cleartext HTTP ( ...

  9. 从一个实例学习----FLASK-WTF

    本案例通过实现一个注册页面的编写,来带你了解FLASK-WTF的运用. 主要功能为表单基础的功能--手机号码必须为11位数,且通过数据库查找不能有已经注册的了,密码要求输入两遍且必须一样,且所有内容不 ...

  10. react-native WebView 返回处理 (非回调方法可解决)

    1.前言 项目中有些页面内容是变更比较频繁的,这些页面我们会考虑用网页来解决. 在RN项目中提供一个公用的Web页,如果是网页内容,就跳转到这个界面展示. 此时会有一个问题是,网页会有一级页面,二级页 ...