poi导出excel2007报表时图片写入到excel2007后显示不出来如何解决?

mrZhan_223 发布于 2013/08/22 11:57
阅读 1K+
收藏 1

在导出excel报表时,我是这样写入图片的:

xssfdrawing draw = sheet.createdrawingpatriarch();

draw.createpicture(anchor,workbook.addpicture(bytevalue,xssfworkbook.picture_type_png));

其中bytevalue是要显示图片的字节数组;

不知道是写入图片的方法没有用对还是其他什么原因,导出的excel没有将写入的图片显示出来,请各位高人指点。谢谢!

加载中
0
m
mrZhan_223
有人知道使用poi如何往excel中写入图片吗?写入后必须要能正常显示出来。
0
joychencheng
joychencheng
Drawing patriarch = sheet.createDrawingPatriarch();
ClientAnchor anchor = null;
if(workBook instanceof HSSFWorkbook){
anchor = new HSSFClientAnchor(dx1, dy1, dx2, dy2,
col1, row1, col2, row2);
}else{
anchor = new XSSFClientAnchor(dx1, dy1, dx2, dy2,
col1, row1, col2, row2);
}


// 插入图片
byte[] pictureData = byteArrayOutputStream.toByteArray();
int pictureFormat = HSSFWorkbook.PICTURE_TYPE_JPEG;
int pictureIndex = workBook.addPicture(pictureData, pictureFormat);
patriarch.createPicture(anchor, pictureIndex);
七宝妙树
七宝妙树
我今天也碰见了这个问题。 图片在Excel2003显示没有问题,但我用07把模板重新保存之后,写入的图片显示不出来了。 试了几次,只能归结于07改变了sheet的内部属性值。 但是我用07直接建一个*.xls的空文件,可以显示。我用的放座标方法用的是HSSFClientAnchor写入的。 我倒没有注意看我们POI版本,XSSFClientAnchor是针对07的吗?哪一版加的? 求指点。
返回顶部
顶部