2.4.5 用NPOI操作EXCEL--插入图片

      我们知道,在Excel中是可以插入图片的。操作菜单是“插入->图片”,然后选择要插入图片,可以很容易地在Excel插入图片。同样,在NPOI中,利用代码也可以实现同样的效果。在NPOI中插入图片的方法与画图的方法有点类似:
// add picture data to this workbook.
byte [] bytes  =  System.IO.File.ReadAllBytes( @" D:\MyProject\NPOIDemo\ShapeImage\image1.jpg " );
int  pictureIdx  =  hssfworkbook.AddPicture(bytes, HSSFWorkbook.PICTURE_TYPE_JPEG);

// create sheet
HSSFSheet sheet  =  hssfworkbook.CreateSheet( " Sheet1 " );

//  Create the drawing patriarch.  This is the top level container for all shapes. 
HSSFPatriarch patriarch  =  sheet.CreateDrawingPatriarch();

// add a picture
HSSFClientAnchor anchor  =   new  HSSFClientAnchor( 0 0 1023 0 0 0 1 3 );
HSSFPicture pict 
=  patriarch.CreatePicture(anchor, pictureIdx);

      与画简单图形不同的是,首先要将图片读入到byte数组,然后添加到workbook中;最后调用的是patriarch.CreatePicture(anchor, pictureIdx)方法显示图片,而不是patriarch.CreateSimpleShape(anchor)方法。上面这段代码执行后生成的Excel文件样式如下:


      我们发现,插入的图片被拉伸填充在HSSFClientAnchor指定的区域。有时可能我们并不需要拉伸的效果,怎么办呢?很简单,在最后加上这样一句用来自动调节图片大小:

pict.Resize();

添加代码后再执行上述代码,生成的Excel样式如下:

图片已经自动伸缩到原始大小了。

 

返回目录

 

转载于:https://www.cnblogs.com/atao/archive/2009/09/28/1576044.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值