使用poi和jfreechart生成excel图表图片

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

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

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

图1是前端base64码生成的:

图2是后台jfreechart生成的:

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

1、maven导包:

<dependency>
    	<groupId>org.apache.poi</groupId>
    	<artifactId>poi-ooxml</artifactId>
    	<version>3.8</version>
</dependency>
<dependency>
    	<groupId>org.apache.poi</groupId>
    	<artifactId>poi-scratchpad</artifactId>
    	<version>3.8</version>
</dependency>
<dependency>
    	<groupId>jfree</groupId>
    	<artifactId>jfreechart</artifactId>
    	<version>1.0.13</version>
</dependency>

2、java测试main方法代码:

package test;
import java.awt.BasicStroke;
import java.awt.Color;
import java.awt.Font;
import java.awt.image.BufferedImage;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import javax.imageio.ImageIO;
import org.apache.poi.hssf.usermodel.HSSFClientAnchor;
import org.apache.poi.hssf.usermodel.HSSFPatriarch;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.jfree.chart.ChartColor;
import org.jfree.chart.ChartFactory;
import org.jfree.chart.ChartUtilities;
import org.jfree.chart.JFreeChart;
import org.jfree.chart.axis.CategoryAxis;
import org.jfree.chart.axis.CategoryLabelPositions;
import org.jfree.chart.axis.NumberAxis;
import org.jfree.chart.axis.NumberTickUnit;
import org.jfree.chart.axis.ValueAxis;
import org.jfree.chart.plot.CategoryPlot;
import org.jfree.chart.plot.PlotOrientation;
import org.jfree.chart.renderer.category.LineAndShapeRenderer;
import org.jfree.chart.title.LegendTitle;
import org.jfree.chart.title.TextTitle;
import org.jfree.data.category.DefaultCategoryDataset;
import org.jfree.ui.RectangleEdge;

/**
 * 结合poi和jfreechart创建图表图片
 *
 * @author tuzongxun
 * @date 2016年9月19日 上午10:55:09
 */
public class ExcelDemo2 {
	public static void main(String[] args) throws Exception {
		// excel2003工作表
		HSSFWorkbook wb = new HSSFWorkbook();
		HSSFSheet sheet = wb.createSheet("Sheet 1");
		ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream();
		;
		// 设置具体数据
		List<String> timeList = new ArrayList<String>();
		timeList.add("10:00");
		timeList.add("11:00");
		timeList.add("12:00");
		List<Integer> appList = new ArrayList<Integer>();
		appList.add(120);
		appList.add(200);
		appList.add(150);
		List<Integer> oraList = new ArrayList<Integer>();
		oraList.add(230);
		oraList.add(200);
		oraList.add(235);
		// 设置图片中的字体和颜色以及字号
		Font titleFont = new Font("黑体", Font.BOLD, 12);
		Font xfont = new Font("黑体", Font.BOLD, 10);
		Font labelFont = new Font("黑体", Font.BOLD, 10);
		// 设置数据区域
		DefaultCategoryDataset dataset = new DefaultCategoryDataset();
		for (int i = 0; i < timeList.size(); i++) {
			String time = timeList.get(i);
			dataset.addValue(appList.get(i), "苹果", time);
			dataset.addValue(oraList.get(i), "橘子", time);
		}
		JFreeChart chart = ChartFactory.createLineChart("水果时间段销量", "时间", "销量", dataset, PlotOrientation.VERTICAL, true,
		    true, true);
		// 设置图例字体
		chart.getLegend().setItemFont(new Font("黑体", Font.BOLD, 10));
		// 设置标题字体
		chart.setTitle(new TextTitle(chart.getTitle().getText(), titleFont));
		// 图形的绘制结构对象
		CategoryPlot plot = chart.getCategoryPlot();
		// 获取显示线条的对象
		LineAndShapeRenderer lasp = (LineAndShapeRenderer) plot.getRenderer();
		// 设置拐点是否可见/是否显示拐点
		lasp.setBaseShapesVisible(true);
		// 设置拐点不同用不同的形状
		lasp.setDrawOutlines(true);
		// 设置线条是否被显示填充颜色
		lasp.setUseFillPaint(false);
		LineAndShapeRenderer renderer = (LineAndShapeRenderer) plot.getRenderer();
		// 设置折线大小以及折线的颜色
		renderer.setSeriesStroke(0, new BasicStroke(1.0F));
		renderer.setSeriesPaint(0, new Color(210, 105, 30));
		renderer.setSeriesStroke(1, new BasicStroke(1.0F));
		renderer.setSeriesPaint(1, new Color(0, 191, 255));
		// 设置折点的大小
		lasp.setSeriesOutlineStroke(0, new BasicStroke(0.025F));
		lasp.setSeriesOutlineStroke(1, new BasicStroke(0.05F));
		// 设置网格线
		plot.setDomainGridlinePaint(Color.gray);
		plot.setDomainGridlinesVisible(true);
		plot.setRangeGridlinePaint(Color.gray);
		plot.setRangeGridlinesVisible(true);
		// x轴
		CategoryAxis domainAxis = plot.getDomainAxis();
		// 设置x轴不显示,即让x轴和数据区重合
		domainAxis.setAxisLineVisible(false);
		// x轴标题
		domainAxis.setLabelFont(xfont);
		// x轴数据倾斜
		domainAxis.setCategoryLabelPositions(CategoryLabelPositions.createUpRotationLabelPositions(0.95D));
		// X轴坐标上数值字体
		domainAxis.setTickLabelFont(labelFont);
		// 设置Y轴间隔
		NumberAxis numAxis = (NumberAxis) plot.getRangeAxis();
		numAxis.setTickUnit(new NumberTickUnit(50));
		// y轴
		ValueAxis rangeAxis = plot.getRangeAxis();
		rangeAxis.setLabelFont(xfont);
		// 设置y轴不显示,即和数据区重合
		rangeAxis.setAxisLineVisible(false);
		// y轴坐标上数值字体
		rangeAxis.setTickLabelFont(labelFont);
		rangeAxis.setFixedDimension(0);
		CategoryPlot cp = chart.getCategoryPlot();
		// 背景色设置
		cp.setBackgroundPaint(ChartColor.WHITE);
		cp.setRangeGridlinePaint(ChartColor.GRAY);
		// 创建图例,设置图例的位置,这里的设置实际不起作用,怎么设都在下边
		LegendTitle legendTitle = new LegendTitle(chart.getPlot());
		legendTitle.setPosition(RectangleEdge.BOTTOM);
		try {
			ChartUtilities.writeChartAsPNG(byteArrayOut, chart, 400, 200);
			String fileSavePath = "exTest.png";
			BufferedImage bufferImg = ImageIO.read(new File(fileSavePath));
			ImageIO.write(bufferImg, "png", byteArrayOut);
		} catch (IOException e) {
		}
		// 画图的顶级管理器,一个sheet只能获取一个(一定要注意这点)
		HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
		// 八个参数,前四个表示图片离起始单元格和结束单元格边缘的位置,
		// 后四个表示起始和结束单元格的位置,如下表示从第2列到第12列,从第1行到第15行,需要注意excel起始位置是0
		HSSFClientAnchor anchor = new HSSFClientAnchor(0, 0, 0, 0, (short) 2, (short) 1, (short) 12, (short) 15);
		anchor.setAnchorType(3);
		// 插入图片
		patriarch.createPicture(anchor, wb.addPicture(byteArrayOut.toByteArray(), HSSFWorkbook.PICTURE_TYPE_PNG));
		// excel2003后缀
		FileOutputStream fileOut = new FileOutputStream("exTest.xls");
		wb.write(fileOut);
		fileOut.close();
	}
}

结果如图:

时间: 2024-12-04 23:45:51

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

java使用poi开源框架生成excel文件并对其进行加密登入用户名若为汉字则出现乱码

问题描述 java使用poi开源框架生成excel文件并对其进行加密登入用户名若为汉字则出现乱码 public static byte[] encryptExcel(byte[] bytes String password String userName) { byte[] enExcelBytes = null; try { // 创建一个工作薄 HSSFWorkbook workbook = new HSSFWorkbook(new ByteArrayInputStream(bytes));

Highcharts结合PhantomJS在服务端生成高质量的图表图片

项目背景 最近忙着给部门开发一套交互式的报表系统,来替换原有的静态报表系统. 老系统是基于dotnetCHARTING开发的,dotnetCHARTING的优势是图表类型丰富,接口调用简单,使用时只 需绑定数据源即可(指定连接字符和sql语句,简单的配置一下就能出图),支持生成静态图表图片:缺点就 是生成好的图是图片,传到了前台就失去了交互性(当然它还提供了一个jsCharting,不过感觉交互性做的还 是不够好),再有就是这东东是收费的呀,用的话需要折腾破解版本. 我最终选择了Highchar

有谁知道POI 怎么生成带图表的excel,或者在一个sheet中引用另一个sheet中的cell?

问题描述 如题生成如下图表,但是图表数据来自另外一个sheet 解决方案 先做一个excel模板,在里面用变量代替图表的值,然后调用poi的API替换里面的变量.思路是这样,不知道可不可以解决你的问题.解决方案二:你那用POI实现了图形报表没?

jsp利用POI生成Excel并在页面中导出的示例_JSP编程

java中导出Excel有两个组件可以使用,一个是jxl,一个是POI,我这里用的是POI.导出是可以在服务器上生成文件,然后下载,也可以利用输出流直接在网页 中弹出对话框提示用户保存或下载.生成文件的方式会导致服务器中存在着垃圾文件,实现方式不太优雅,所以这里我采用的是后面直接通过输出流的方式. 1.修改WEB服务器的CONF/web.xml,添加 Xml代码 <mime-mapping> <extension>xls</extension> <mime-typ

Windows中使用Java生成Excel文件并插入图片的方法_java

生成简单的Excel文件 在现实的办公中,我们常常会有这样一个要求:要求把报表直接用excel打开.在实习中有这样一个需求.根据所选择的资源查询用户所提供附件的全部信息并生成excel供下载.但是在查询的时候我们需要来检测用户所提供的附件里面的信息是否有错误(身份证).有错误的生成错误信息excel.      Apache的POI项目,是目前比较成熟的HSSF接口,用来处理Excel对象.其实POI不仅仅只能处理excel,它还可以处理word.PowerPoint.Visio.甚至Outlo

在Struts中用JFreeChart生成图表

1.类中方法 引入必要的包: import javax.servlet.http.HttpSession; import javax.servlet.http.HttpServletRequest; import org.jfree.chart.JFreeChart; import org.jfree.chart.ChartFactory; import org.jfree.data.general.DefaultPieDataset; import org.jfree.chart.plot.P

poi生成excel设置表格保护后,组合显示也被保护了,该怎么取消?

问题描述 poi生成excel设置表格保护后,组合显示也被保护了,该怎么取消? 今天小弟碰到一个问题,望懂的大神帮忙看看,感激不尽: 我用poi生成excel时先设置了一个表格保护(sheet.protectSheet("123")),然 后有在表中生成过组合(sheet.groupRow(i+4,h+2);)这样的话这个生成的组合就用不了了,该怎么给这个组合按钮取消保护呢? 解决方案 没人知道吗?自己顶下下下下下

MSChart控件生成的图表保存为图片后是空的,什么都没有

问题描述 我做的是b/s,用MSChart控件生产图表,现在想把生成的图表导出去,用SaveImage保存后,得到的图片却是空的,啥都没有,这是为什么呀????急求呀 解决方案 解决方案二:是不是保存方法有问题解决方案三:背景色透明注意了木有?解决方案四:chart1.SaveImage("c:\1.jpeg",System.Drawing.Imaging.ImageFormat.Jpeg);

poi处理excel-小白求助:poi生成excel速度过慢问题,该怎么优化

问题描述 小白求助:poi生成excel速度过慢问题,该怎么优化 package poiMain; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.io.InputStream; import java.text.DateFormat; import java.text.DecimalFormat; import java.text.S