欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 科技 > 能源 > apachePoi中XSSFClientAnchor图片坐标简述;填充多张图片

apachePoi中XSSFClientAnchor图片坐标简述;填充多张图片

2025/2/12 17:28:50 来源:https://blog.csdn.net/weixin_43944305/article/details/131077871  浏览:    关键词:apachePoi中XSSFClientAnchor图片坐标简述;填充多张图片

概述

业务中经常会遇到在单元格内填充图片的需求,而且要求指定图片在单元格内的位置。

一般都是用的apache的poi,设置图片坐标。

HSSFClientAnchor(int dx1, int dy1, int dx2, int dy2, short col1, int row1, short col2, int row2)

dx1 dy1 起始单元格中的x,y坐标.

dx2 dy2 结束单元格中的x,y坐标

col1,row1 指定起始的单元格,下标从0开始

col2,row2 指定结束的单元格 ,下标从0开始

在这里插入图片描述

在这里插入图片描述

demo

public static void main(String[] args) {byte[] imgBytes = ResourceUtil.readBytes("test.jpg");// 创建一个 ExcelWriterExcelWriter writer = ExcelUtil.getWriter("output.xlsx");// 获取 sheet 对象Sheet sheet = writer.getWorkbook().getSheetAt(0);int rowNum = 0; // 假设图片插入在第一行int colNum = 0; // 假设图片插入在第一列// 在指定的单元格内插入图片insertImagesToCell(sheet, rowNum, colNum, imgBytes);// 保存到文件writer.flush();
}private static void insertImagesToCell(Sheet sheet, int rowNum, int colNum, byte[] imageBytes) {// 获取 Excel 的工作簿并添加图片Workbook workbook = sheet.getWorkbook();// 获取 Drawing 对象Drawing drawing = sheet.getDrawingPatriarch();if (drawing == null) {drawing = sheet.createDrawingPatriarch();}// 创建 Excel 的行和列Row row = sheet.getRow(rowNum);if (row == null) {row = sheet.createRow(rowNum);}//创建单元格Cell cell = row.createCell(colNum);int pictureIdx = workbook.addPicture(imageBytes, Workbook.PICTURE_TYPE_JPEG);// 创建图片的定位点XSSFClientAnchor anchor = new XSSFClientAnchor();//图片起始列anchor.setCol1(colNum);//图片起始行anchor.setRow1(rowNum);//图片结束列anchor.setCol2(colNum + 1);//图片结束行anchor.setRow2(rowNum + 1);//图片左上角在开始单元格中的X坐标;>0向右;<0向左(有点类似html页面中的padding)anchor.setDx1(Units.EMU_PER_PIXEL * 100);//图片左上角在开始单元格中的Y坐标;>0向下;<0向上(有点类似html页面中的padding)anchor.setDy1(Units.EMU_PER_PIXEL *(100));//图片右下角在结束单元格中的X坐标;>0向右;<0向左anchor.setDx2(Units.EMU_PER_PIXEL *(-100));//图片右下角在结束单元格中的Y坐标;>0向下;<0向上anchor.setDy2(Units.EMU_PER_PIXEL *(-100));anchor.setAnchorType(ClientAnchor.AnchorType.MOVE_AND_RESIZE);// 创建并设置图片drawing.createPicture(anchor, pictureIdx);
}

效果图
在这里插入图片描述

填充多张图片demo
填充多张图片,且开始单元格和结束单元格为同一个单元格

public static void main(String[] args) {byte[] imgBytes = ResourceUtil.readBytes("test.jpg");// 创建一个 ExcelWriterExcelWriter writer = ExcelUtil.getWriter("output.xlsx");// 获取 sheet 对象Sheet sheet = writer.getWorkbook().getSheetAt(0);int rowNum = 0; // 假设图片插入在第一行int colNum = 0; // 假设图片插入在第一列// 在指定的单元格内插入图片insertImagesToCell(sheet, rowNum, colNum, imgBytes);// 保存到文件writer.flush();
}private static void insertImagesToCell(Sheet sheet, int rowNum, int colNum, byte[] imageBytes) {// 获取 Excel 的工作簿并添加图片Workbook workbook = sheet.getWorkbook();// 创建 Excel 的行和列Row row = sheet.getRow(rowNum);if (row == null) {row = sheet.createRow(rowNum);}//创建单元格Cell cell = row.createCell(colNum);// 边距int padding = Units.toEMU(20);// 计算每张图片的宽度和位置int numImages = 5;// 获取 Drawing 对象Drawing drawing = sheet.getDrawingPatriarch();if (drawing == null) {drawing = sheet.createDrawingPatriarch();}//上一张图片的左上角X坐标int preDx1 = 0;//上一张图片的右下角X坐标int preDx2 = 0;//图片宽度int defaultImgWidth = Units.toEMU(80);//图片高度;图片右下角相对结束单元格的y高度int defaultImgHeight = Units.toEMU(100);for (int i = 0; i < numImages; i++) {int pictureIdx = workbook.addPicture(imageBytes, Workbook.PICTURE_TYPE_JPEG);// 创建图片的定位点XSSFClientAnchor anchor = new XSSFClientAnchor();//图片起始列anchor.setCol1(colNum);//图片起始行anchor.setRow1(rowNum);//图片结束列anchor.setCol2(colNum);//图片结束行anchor.setRow2(rowNum);//上一张图片右下角的x坐标 + 图片间距int dx1 = preDx2 + padding;//当前图片的左上角x坐标 + 图片宽度int dx2 = dx1 + defaultImgWidth;//当前图片x坐标anchor.setDx1(dx1);//上边距anchor.setDy1(padding);//图片宽度anchor.setDx2(dx2);//图片高度anchor.setDy2(defaultImgHeight);anchor.setAnchorType(ClientAnchor.AnchorType.MOVE_AND_RESIZE);// 创建并设置图片drawing.createPicture(anchor, pictureIdx);preDx1 = dx1;preDx2 = dx2;}}

填充效果
在这里插入图片描述

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com