多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > php開源 > php教程 > 使用poi和jfreechart生成excel圖表圖片

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

來源:程序員人生   發布時間:2017-01-11 09:48:47 閱讀次數:3943次

最近項目在頻繁的操作excel,里邊觸及到很多和圖表有關的東西。有時候需要使用java操作excel自帶的圖標,比較復雜的我們都是使用excel模板的情勢實現。
除此以外,也有1些功能只需要生成對應的圖標樣式的圖片就好,我們實現的時候主要用了兩種方式,1種就是由前臺生成圖片base64碼,然后后臺解碼生成圖片插入到excel,但是這類方式有 1定的局限性,也就是當某些功能需要后臺定時生成excel的時候,就沒法獲得這個圖片。
因而我們采取了另外一種方法,也就是是用jfreechart生成對應的圖片,然后結合poi插入到excel對應的位置,下圖是項目中使用后的真實效果:
圖1是前端base64碼生成的:
這里寫圖片描述
圖2是后臺jfreechart生成的:
這里寫圖片描述

以下是抽空做的1個簡單的整理:
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) { } // 畫圖的頂級管理器,1個sheet只能獲得1個(1定要注意這點) HSSFPatriarch patriarch = sheet.createDrawingPatriarch(); // 8個參數,前4個表示圖片離起始單元格和結束單元格邊沿的位置, // 后4個表示起始和結束單元格的位置,以下表示從第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(); } }

結果如圖:
這里寫圖片描述

生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 亚洲春色校园 | 秋霞一级片 | 在线午夜影院 | 国产精品久久久久毛片真精品 | 亚洲午夜精品久久久久久成年 | 美女网站在线观看视频免费的 | 亚洲一二四区性毛片1在线 亚洲一个色 | 亚洲人成网站999久久久综合 | 最好的中文字幕2018免费视频 | 亚洲涩福利高清在线 | 伊人三级| 一区二区三区四区视频在线观看 | 亚洲国产aaa毛片无费看 | 波多野结衣视频免费 | 高清一区二区 | 欧美我不卡 | 92精品国产自产在线观看 | 中文字幕精品一区二区2021年 | 亚洲精品一区二区三区 | 亚洲无限乱码一二三四区 | 久久久一区二区三区 | 美女福利在线观看 | 手机看片福利日韩国产 | 欧美性猛交黑人xxxx | 丁香综合五月 | 亚洲欧美久久一区二区 | 波多野结衣一二区 | 欧美在线观看成人高清视频 | 亚洲综合图片 | 国产免费福利体检区久久 | 大色虫成人午夜在线观看 | 在线视频中文 | a在线视频| 亚洲欧美国产一区二区三区 | 国产农村女人一级毛片了 | 国内精品91久久久久 | 日本一级做a爱片 | 国产1区2区3区在线观看 | 91在线九色 | 国内精品久久国产大陆 | 日本欧美一区二区免费视 |