zoukankan      html  css  js  c++  java
  • 2.4.5 用NPOI操作EXCEL--插入图片

    我们知道,在Excel中是可以插入图片的。操作菜单是“插入->图片”,然后选择要插入图片,可以很容易地在Excel插入图片。同样,在NPOI中,利用代码也可以实现同样的效果。在NPOI中插入图片的方法与画图的方法有点类似: 

    //add picture data to this workbook.
    byte[] bytes = System.IO.File.ReadAllBytes(@"D:MyProjectNPOIDemoShapeImageimage1.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样式如下:

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

     

    学习教程:http://www.cnblogs.com/atao/archive/2009/09/28/1576044.html

     

  • 相关阅读:
    java jar 后台运行
    【Objective-C】内存管理
    GitHub Gist 指南
    模板发送java邮件
    JDK环境配置
    新装mysql数据库登陆不上去(账号密码正确)
    一个简单的爬取b站up下所有视频的所有评论信息的爬虫
    hexo Nunjucks Errors 解决方法
    新版正方教务系统导出课程表-油猴脚本
    ACM-图论-同余最短路
  • 原文地址:https://www.cnblogs.com/lizihong/p/4320052.html
Copyright © 2011-2022 走看看