首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用Apache-poi在excel中插入图像

用Apache-poi在excel中插入图像
EN

Stack Overflow用户
提问于 2017-06-26 16:49:16
回答 1查看 4.5K关注 0票数 3

好吧,我修改了我的代码以消除其他因素:

代码语言:javascript
复制
package com.shangzhu.drt;

import org.apache.poi.ss.usermodel.Picture;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.usermodel.*;

import javax.imageio.ImageIO;
import java.awt.image.BufferedImage;
import java.io.ByteArrayOutputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.io.OutputStream;

/**
 * Created by lixiaoming on 2017/6/26.
 */
public class ImageTest2 {

    private static void insertImageWithPOI() throws Exception {
        XSSFWorkbook wwb = new XSSFWorkbook();
        XSSFSheet ws = wwb.createSheet("sheet0");

        BufferedImage image = ImageIO.read(new File("D:/poi.png"));
        ByteArrayOutputStream baps = new ByteArrayOutputStream();
        ImageIO.write(image,"png",baps);

        int pictureIdx = wwb.addPicture(baps.toByteArray(), Workbook.PICTURE_TYPE_PNG);

        XSSFDrawing drawing = ws.createDrawingPatriarch();
        XSSFCreationHelper helper = wwb.getCreationHelper();
        XSSFClientAnchor anchor = helper.createClientAnchor();
        anchor.setCol1(1);
        anchor.setRow1(1);

        Picture picture = drawing.createPicture(anchor, pictureIdx);
        picture.resize();

        File excelFile = new File("D:/POI.xlsx");
        OutputStream ops = new FileOutputStream(excelFile);
        wwb.write(ops);
    }

    public static void main(String[] args) {
        try {
            insertImageWithPOI();
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

下面是代码中的图片(“D:/poi.png”):D:/poi.png

我不认为处理图像的源代码有问题,但我不知道我错过了什么

EN

回答 1

Stack Overflow用户

发布于 2017-06-27 01:32:37

我确认使用默认列大小时存在问题。XSSFPicture.resize需要计算以像素为单位的列宽,以获得XSSFClientAnchor Col2Dx2。只要使用默认列大小,则此计算似乎是错误的。

一种解决方法是在使用XSSFPicture.resize之前定义明确的列大小。那么,以像素为单位的列宽计算似乎是正确的。

在你的代码中:

代码语言:javascript
复制
...
        Picture picture = drawing.createPicture(anchor, pictureIdx);

        for (int c=0; c<20; c++) ws.setColumnWidth(c, 11*256);
        picture.resize();
...
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44755977

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档