欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java Web導出等比例圖片到Excel的實現(xiàn)過程

 更新時間:2023年11月23日 10:42:07   作者:小王和八蛋  
我們使用Java導出圖片到Excel,打開成功導出的Excel一看,商品對應的圖片都很規(guī)矩的按照我的設置鋪滿了整個單元格,但是,商品圖片卻都變形了,這樣肯定是不行的,于是第一反應就是將圖片等比例導出,所以本文本給大家介紹了如何使用Java Web導出等比例圖片到Excel

做個Excel導入導出的Java開發(fā)戶都知道,可以利用Apache的POI來實現(xiàn),為Excel創(chuàng)建每一行,每一單元及對應的內容。當然,圖片的話需要用到POI中的HSSFClientAnchor這個類型來實現(xiàn), HSSFClientAnchor的構造函數(shù)中有八個參數(shù),分類為:int dx1,int dy1,int dx2,int dy2,short col1,int row1,short col2, int row2,其中dx1、dy1定義了該圖片在開始cell的起始位置,dx2、dy2定義了在終cell的結束位置,col1、row1定義了開始cell、col2、row2定義了結束cell。

那么,我們就可以用這個方法來講圖片定位到每一個單元格中。我的做法是:

鋪滿整個單元格,這里的j和i是代碼中要到處多張圖做了循環(huán)定義的變量HSSFClientAnchor anchor = new HSSFClientAnchor(0, 0, 1023, 255, (short) j, i + 1, (short) j, i + 1);

很順利,成功導出!

問題來了,打開成功到處的Excel一看,商品對應的圖片都很規(guī)矩的按照我的設置鋪滿了整個單元格。但是,商品圖片卻都變形了,也就是圖片的 寬高被強行設置了成對應單元格的寬高。

這樣肯定是不行的,于是第一反應就是將圖片等比例導出,但是怎么讓圖片等比例的導出在Excel中呢,苦惱了許久,終于想到了一個可行的方案。就是利用POI設置每一行對應要放圖片的那個單元格的寬度固定,也就是所有導出的圖片的寬度固定,然后根據(jù)這個固定寬度與原圖寬高對比,算出該固定寬度的等比例高度,然后動態(tài)設置該單元格的高度,然后再利用HSSFClientAnchor來鋪滿整個單元格,這樣看起來就不會變形,而且等比例縮放到指定單元格中。

關鍵兩個實現(xiàn)步驟:

第一步 設置單元格固定寬度: 循環(huán)創(chuàng)建每一行的時候,如何設置要放圖片的那個單元的寬度呢?大家都知道,在Excel中,同一列的單元格的寬度都是一樣的,故可以在創(chuàng)建工作簿的時候,就設定好要放圖片的那個單元格的寬度,我是這樣做的:

生成一個表格 HSSFSheet sheet = workbook.createSheet(title);

設置B列的寬度為 30*256; sheet.setColumnWidth(1, 30 * 256);

這里我們看到,SetColumnWidth的第二個參數(shù)要乘以256,是因為這個參數(shù)的單位是1/256個字符寬度,也就是說這里我設置的是30個字符的寬度,至于一個字符寬度是多少,可以用FontDesignMetrics來獲得,一般一個12號字體的寬度大約是13像素。

第二步,設置單元等比率高度:在循環(huán)每一行中,當創(chuàng)建對應放圖片的單元的時候,設置對應的高度。我的做法是,先獲取要導出的圖片,在獲取圖片的原始寬度和高度(主要,這里獲取的是像素寬高),然后根據(jù)前面設置的固定寬度算出等比例的高度:

ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream();
BufferedImage bufferImg = ImageIO.read(new File(savePath + System.getProperty("file.separator") + map.get("productImg")));
ImageIO.write(bufferImg, "jpg", byteArrayOut);
int width = bufferImg.getWidth();//原始寬度
int height = bufferImg.getHeight();//原始高度
// 一個12號字體的寬度為13,前面已設置了列的寬度為30*256,故這里的等比例高度計算如下
height = (int) Math.round((height * (30 * 13) * 1.0 / width));
// excel單元格高度是以點單位,1點=2像素; POI中Height的單位是1/20個點,故設置單元的等比例高度如下
row.setHeight((short) (height / 2 * 20));
// 畫圖的頂級管理器,一個sheet只能獲取一個(一定要注意這點)
HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
// anchor主要用于設置圖片的屬性
HSSFClientAnchor anchor = new HSSFClientAnchor(0, 0, 1023, 255, (short) j, i + 1, (short) j, i + 1);
anchor.setAnchorType(3);
// 插入圖片
patriarch.createPicture(anchor,workbook.addPicture(byteArrayOut.toByteArray(), HSSFWorkbook.PICTURE_TYPE_JPEG));

至此,等比率圖片及相關信息以完美導出到Excel中。

到此這篇關于Java Web導出等比例圖片到Excel的實現(xiàn)過程的文章就介紹到這了,更多相關Java Web導出等比例圖片內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

最新評論