突然想起来有同学说过能不能导出图片,本来我是想说不懂的,后来我上官网查了查,还挺容易。我就简短的写一写怎么导出图片。

  官方提供了导出图片标签:

jx:image(lastCell="D10" src="data:image" imageType="PNG")

  这是在java中的代码调用:

InputStream imageInputStream = ImageDemo.class.getResourceAsStream("business.png");
byte[] imageBytes = Util.toByteArray(imageInputStream);
context.putVar("image", imageBytes);

  我把他写进以前的源码中,给同学们看看怎么导出图片。

  还记得以前写过一个person类吗?

public class Person {
String id;
String name;
Integer age;
byte[] img;
/** 省略构造器和get/set方法 */
}

  我们加入一个新的属性byte[] ,byte数组img。

  然后我们看看main方法怎么写。

public static void main(String[] args) throws Exception {
// 模板位置,输出流
String templatePath = "E:/template3.xls";
OutputStream os = new FileOutputStream("E:/out4.xls");
// 文件流,输入一张叫fly的png图片
InputStream imageInputStream = new FileInputStream("E:/fly.png");
     // 使用工具方法把流转成byte数组
byte[] imageBytes = Util.toByteArray(imageInputStream); // 一个装有对象数据的链表
List<Person> persons = new ArrayList<Person>();
Person p1 = new Person("001", "张三", 18);
Person p2 = new Person("002", "李四", 19);
Person p3 = new Person("003", "王五", 20);
     // 把图片转换的字节数组存进person对象中
p1.setImg(imageBytes);
p2.setImg(imageBytes);
p3.setImg(imageBytes);
persons.add(p1);
persons.add(p2);
persons.add(p3); Map<String, Object> model = new HashMap<String, Object>();
model.put("person", persons); // 把链表放进model中
JxlsUtils.exportExcel(templatePath, os, model);
os.close();
System.out.println("完成");
}

  代码中有个流转字节数组的工具类Util.toByteArray,这个工具类文章后我会提供下载链接。

  下面看下导出模板:

  老生常谈的就不说了,说下画红框框的:

jx:image(lastCell="D4" src="p.img" imageType="PNG")

  这是一个用来导出图片的标签,依照官方说明imageType图片类型默认是PNG,支持:PNG, JPEG, EMF, WMF, PICT, DIB。

  src是model中传入的字节数组byte[]。

  lastCell是图片结束位置,会自动拉伸填充完你定义的格子。比如你在A1中加入了这个注解,lastCell写C6,就会把A1到C6都拉伸填充完。

  行了,执行代码导出吧。

  这里是把字节数组放在遍历对象里的遍历出来的,你要是不想遍历,而是只想显示一张图片,你看了这么多篇我写的文章,应该不用我说该怎么做吧?就是直接把字节数组放进model中,在excel中取出就行了。

  官方图片导出简介:

  http://jxls.sourceforge.net/reference/image_command.html#

  下载工具类依赖的jar包:commons-codec-1.10.rar


  

  我原本的计划是写上五篇JXLS2.4的基础教程的,现在倒是写了六篇,花了两天的时间。目前看来算是写完了。未来会不会有更新机会要看我能把这个工具用到什么程度了。这个工具还有很多的功能,我估计都不大可能用得上了!哈哈哈。先这样吧,写了两天,剩下的国庆时间让我好好的过个国庆!

  有什么意见请在文章后留言,如果你要问我某某某怎么实现,你就先翻翻我有没有写过,如果我没有写过,估计我也不懂。

  我也不知道有没有代码复制下来执行不了的。这么几行代码都有报错,随缘吧!

JXLS 2.4.0系列教程(六)番外篇——导出图片(完结)的更多相关文章

  1. JXLS 2.4.0系列教程(二)——循环导出一个链表的数据

    请务必先看上一篇文章,本文在上一篇文章的代码基础上修改而成. JXLS 2.4.0系列教程(一)--最简单的模板导出 上一篇文章我们介绍了JXLS和模板导出最简单的应用,现在我们要更进一步,介绍在模板 ...

  2. 黄聪:Microsoft Enterprise Library 5.0 系列教程(六) Security Application Block

    原文:黄聪:Microsoft Enterprise Library 5.0 系列教程(六) Security Application Block 开发人员经常编写需要安全功能的应用程序.这些应用程序 ...

  3. JXLS 2.4.0系列教程(一)——最简单的模板导出

    Java中实现excel根据模板导出数据的方法有很多,一般简单的可以通过操作POI进行.还可以使用一些工具很轻松的实现模板导出.这些工具现在还在维护,而且做得比较好的国内的有easyPOI,国外的就是 ...

  4. JXLS 2.4.0系列教程(五)——更进一步的应用和页面边距bug修复

    注:本文代码建立于前面写的代码.不过不看也不要紧. 前面的文章把JXLS 2.4.0 的基本使用写了一遍,现在讲讲一些更进一步的使用方法.我只写一些我用到过的方法,更多的高级使用方法请参考官网. ht ...

  5. JXLS 2.4.0系列教程(四)——多sheet是怎么做到的

    注:本文代码在第一篇文章基础上修改而成,请务必先阅读第一篇文章. http://www.cnblogs.com/foxlee1024/p/7616987.html 本文也不会过多的讲解模板中遍历表达式 ...

  6. JXLS 2.4.0系列教程(四)——拾遗 如何做页面小计

    注:阅读本文前,请先阅读第四篇文章. http://www.cnblogs.com/foxlee1024/p/7619845.html 前面写了第四篇教程,发现有些东西忘了讲了,这里补回来. 忘了讲两 ...

  7. JXLS 2.4.0系列教程(三)——嵌套循环是怎么做到的

    注:本文代码在第一篇文章基础上修改而成,请务必先阅读第一篇文章. http://www.cnblogs.com/foxlee1024/p/7616987.html 本文也不会过多的讲解模板中遍历表达式 ...

  8. 【Python3.6+Django2.0+Xadmin2.0系列教程之三(入门篇-下)】学生信息管理系统

    上一篇我们已经初步的构建起了一个学生管理系统的模型,现在接着来继续完善它吧. 1.上传图片/文件等资源 有时候需要添加一些附件,例如,新生刚入学,大家相互之间还不熟悉,希望能通过照片来加深印象,并且方 ...

  9. Enterprise Library 5.0 系列教程

    1. Microsoft Enterprise Library 5.0 系列教程(一) Caching Application Block (初级) 2. Microsoft Enterprise L ...

随机推荐

  1. ExperDot的博客目录导航

    最近活动 我更新了博客!粒子系统:从零开始画一棵树 Github:[ UWP ] [ JavaScript ] 自然编程  奇幻元纪 上帝创世篇:如何画一颗静态树 女娲补天篇:仿人工拼接碎片 吴刚伐桂 ...

  2. Who's in the Middle

    FJ is surveying his herd to find the most average cow. He wants to know how much milk this 'median' ...

  3. F和弦大横按

    用食指手掌关节顶住. 靠近品柱往上压 右手压住琴尾,这样就很轻松试下C跟F不停转换就快找到感觉 等熟练了,食指自然不会按太上 练得差不多了,手指向琴头倾压,有两个好处 1.手指后面的肉不会碰到弦 2. ...

  4. 搭建PHP本地服务器(XAMPP)

    1.下载XAMPP集成包 https://www.apachefriends.org/download.html2.启动前修改配置文件httpd.conf的端口号,例如:Listen 80803.启动 ...

  5. C# System.Windows.Forms.NumericUpDown 控件全选其中文字

    num_length.Focus();                    UpDownBase updbText = (UpDownBase)num_length;                 ...

  6. 洛谷 P1485 火枪打怪

    题目描述 LXL进入到了一片丛林,结果他发现有n只怪物排成一排站在他面前.LXL有一杆火枪能对付这些怪物.他知道从左至右数第i只怪物的血量是mi.现在LXL可以将一些子弹射向某个怪物.LXL可以控制他 ...

  7. Office 365也是.NET Core应用开发新战场

    最近有幸阅读了陈希章花了一年时间为国内开发者贡献的<Office 365 开发入门指南>. 虽然早期接触过SharePoint的开发,2007年之后就再也没有接触SharePoint的开发 ...

  8. ngx-bootstrap使用02 Accordion组件的使用

    1 Accordion组件 该组件通过一个可折叠的控制面板去在有限空间内显示更多的信息 according组件在可折叠指令的最外层,该组件提供了一些列的项目列表去显示被折叠的内容,这些项目列表包含he ...

  9. Node.js 蚕食计划(三)—— Express 启航

    如果看过上一篇<Node.js 蚕食计划>,就会发现手动搭建一个 web 服务器还是比较繁琐 而 express 就是一个可以极大地提高开发效率的 web 开发框架 一.创建项目 在 ex ...

  10. js 类数组arguments详解

    arguments并不是一个真正的数组,而是一个"类似数组(array-like)"的对象: 就像下面的这段输出,就是典型的类数组对象: [, , callee: ƒ, Symbo ...