java如何使用poi-tl在word模板里渲染多张图片

1、poi-tl官网地址
http://deepoove.com/poi-tl/

2、引入poi-tl的依赖

java 复制代码
	  <dependency>
         <groupId>com.deepoove</groupId>
         <artifactId>poi-tl</artifactId>
         <version>1.12.1</version>
      </dependency>

3、定义word模板

释义: ?为开始标签,/为结束标签,@picture为渲染每一个图片

4、Java测试代码

java 复制代码
@RequestMapping("/test")
@RestController
public class TestController {
	private static final String PICTURE_PATH = "D:\\test\\picture\\";

	@GetMapping("/download")
    public void download(HttpServletResponse response) throws IOException {
    	//定义存储集合
        Map<String, Object> pictureMap= new HashMap<>();
		//创建并得到图片集合,设置图片大小
        List<Map<String, PictureRenderData>> pictureList = createPictureList(100, 100);
        pictureMap.put("pictureList", pictureList);
		//通过XWPFTemplate处理
        XWPFTemplate document = XWPFTemplate.compile(new ClassPathResource("templates/test.docx").getFile()).render(pictureMap);
		//返回数据设置
        setResponseHeader(response);
		//输出流并关闭
        OutputStream os = response.getOutputStream();
        document.write(os);
        os.close();
    }

	private List<Map<String, PictureRenderData>> createPictureList(int width, int height) {
        List<Map<String, PictureRenderData>> list = new ArrayList<>();
		
		//添加多张图片到集合
        list.add(createPictureMap("Banner (1).jpg", width, height));
        list.add(createPictureMap("Banner (10).jpg", width, height));
        list.add(createPictureMap("Banner (100).jpg", width, height));

        return list;
    }

	private Map<String, PictureRenderData> createPictureMap(String pictureName, int width, int height) {
        Map<String, PictureRenderData> map = new HashMap<>();
        //创建PictureRenderData对象并设置其大小
        //Pictures还有其他方法,如Pictures.ofStream()流处理,可根据自己的需求及文档替换
        map.put("picture", Pictures.ofLocal(PICTURE_PATH + pictureName).size(width, height).create());
        return map;
    }

	private void setResponseHeader(HttpServletResponse response) {
        response.reset();
        response.setContentType("application/octet-stream");
        response.setHeader("Content-disposition",
                "attachment;filename=picture_word_" + System.currentTimeMillis() + ".docx");
    }
}

5、测试结果

相关推荐
前端小张同学29 分钟前
服务器部署 gitlab 占用空间太大怎么办,优化思路。
后端
databook39 分钟前
Manim实现闪光轨迹特效
后端·python·动效
武子康1 小时前
大数据-98 Spark 从 DStream 到 Structured Streaming:Spark 实时计算的演进
大数据·后端·spark
该用户已不存在2 小时前
6个值得收藏的.NET ORM 框架
前端·后端·.net
文心快码BaiduComate2 小时前
文心快码入选2025服贸会“数智影响力”先锋案例
前端·后端·程序员
neoooo2 小时前
🌐 Cloudflare Tunnel vs ZeroTier:两个世界的内网穿透哲学
后端
卡尔特斯2 小时前
Android Kotlin 项目代理配置【详细步骤(可选)】
android·java·kotlin
白鲸开源2 小时前
Ubuntu 22 下 DolphinScheduler 3.x 伪集群部署实录
java·ubuntu·开源
涡能增压发动积2 小时前
当你不了解“异步”时请慎用“异步”——记一次生产环境故障排查之旅
后端
文心快码BaiduComate2 小时前
用Comate Zulu开发一款微信小程序
前端·后端·微信小程序