工作中需要生成波形图,并且嵌入到excel中,由于第一次这么处理,费了好大的精神,进行总结
之前的时候采用了 application的 方式进行处理,由于是代码调用,不需要手动处理点击确定之后再生成下一张图,还花费了长时间去了解application的源码,如何自动取消,并且这种方式只能调用一次,第二次调用的时候必须把第一次进程给kill 掉,才能进行第二次调用,采用了手动调用进程,并且手动kill掉进程,效果不太好,于是换了一种方式,采用的jfree 完美解决,并且生成速度也很快
首先引入jfree的pom:
// 直接拿走,可以生成
// 可以自定义图片名称,并且规定x y轴 的大小
//传入的数据 需要指定每张图的存放位置
package com.jxxxx.sys.report.util;
import org.jfree.chart.ChartFactory;
import org.jfree.chart.ChartPanel;
import org.jfree.chart.JFreeChart;
import org.jfree.chart.axis.NumberAxis;
import org.jfree.chart.plot.XYPlot;
import org.jfree.chart.renderer.xy.XYLineAndShapeRenderer;
import org.jfree.data.xy.XYSeries;
import org.jfree.data.xy.XYSeriesCollection;
import org.springframework.stereotype.Component;
import javax.imageio.ImageIO;
import java.awt.*;
import java.awt.image.BufferedImage;
import java.io.File;
import java.io.IOException;
import java.util.List;
import java.util.*;
@Component
public class GeneraterPic {
private static final int WIDTH = 350;
private static final int HEIGHT = 300;
public Boolean generaterPicForWave(List<Map<String,Object>> list) throws IOException {
// 创建数据系列
for(int j = 0;j<list.size() ;j++){
Map<String, Object> stringObjectMap = list.get(j);
String xstr = ""+stringObjectMap.get("seriaX");
String ystr = ""+stringObjectMap.get("seriaY");
String productCode = ""+stringObjectMap.get("productCode");
String filePath = ""+stringObjectMap.get("file