Размещение изображения в середине ячейки с использованием Apache POI ⇐ Excel
Размещение изображения в середине ячейки с использованием Apache POI
Я пытаюсь поместить изображение в середину ячейки листа Excel в приложении Scala. Я использую версию ApachePOI 5.0.0. Однако моя логика отображает изображение только в верхнем левом углу ячейки.
Как разместить изображение посередине данной ячейки. Это моя логика кода:
def addImageToCell (imagePath: String, лист: XSSFSheet, columnsIdx: Int, rowNum: Int): Unit = { val fis = Files.newInputStream(Path.of(imagePath)) val imageBytes = IOUtils.toByteArray(fis) val imageIdx =sheet.getWorkbook.addPicture(pictureBytes, Workbook.PICTURE_TYPE_PNG) фис.закрыть() val helper =sheet.getWorkbook.getCreationHelper val рисунок = лист.createDrawingPatriarch() val якорь = helper.createClientAnchor якорь.setCol1(columnIdx) якорь.setRow1(rowNum) якорь.setAnchorType(ClientAnchor.AnchorType.MOVE_AND_RESIZE) // загружаем изображение и получаем его размеры valufferedImg = ImageIO.read(новый файл(imagePath)) val originalDimension = новое измерение (bufferedImg.getWidth,ufferedImg.getHeight) // получаем ширину и высоту ячейки в пикселях val colWidthInPixels = Math.round(sheet.getColumnWidthInPixels(columnIdx)) val rowHeightInPixels = Math.round(sheet.getRow(rowNum).getHeightInPoints / 72 * 96) // вычисляем масштабный коэффициент val ScaleX = colWidthInPixels.toDouble/originalDimension.width val ScaleY = rowHeightInPixels.toDouble / originalDimension.height // используем меньший масштабный коэффициент, чтобы изображение помещалось в ячейку val шкала = Math.min(scaleX, ScaleY) // гарантирует, что масштабный коэффициент не может быть ниже "0,1" - иначе изображения будут слишком маленькими val пересмотренныйScale = Math.max(масштаб, 0,1) // изменение размера изображения val image: Picture = Drawing.createPicture(anchor, PictureIdx) картинка.resize(revisedScale) // вычисляем новую высоту и ширину масштабированного изображения val ScaledWidth = (originalDimension.width * пересмотренныйScale).toInt val ScaledHeight = (originalDimension.height * reviewScale).toInt // вычисляем, на сколько нужно переместить изображение, чтобы центрировать его в ячейке val moveX = (colWidthInPixels - ScaledWidth)/2 val moveY = (rowHeightInPixels - ScaledHeight)/2 // перемещаем изображение по центру ячейки якорь.setDx1(moveX) якорь.setDy1(moveY) } Любая помощь будет высоко оценена.
Я пытаюсь поместить изображение в середину ячейки листа Excel в приложении Scala. Я использую версию ApachePOI 5.0.0. Однако моя логика отображает изображение только в верхнем левом углу ячейки.
Как разместить изображение посередине данной ячейки. Это моя логика кода:
def addImageToCell (imagePath: String, лист: XSSFSheet, columnsIdx: Int, rowNum: Int): Unit = { val fis = Files.newInputStream(Path.of(imagePath)) val imageBytes = IOUtils.toByteArray(fis) val imageIdx =sheet.getWorkbook.addPicture(pictureBytes, Workbook.PICTURE_TYPE_PNG) фис.закрыть() val helper =sheet.getWorkbook.getCreationHelper val рисунок = лист.createDrawingPatriarch() val якорь = helper.createClientAnchor якорь.setCol1(columnIdx) якорь.setRow1(rowNum) якорь.setAnchorType(ClientAnchor.AnchorType.MOVE_AND_RESIZE) // загружаем изображение и получаем его размеры valufferedImg = ImageIO.read(новый файл(imagePath)) val originalDimension = новое измерение (bufferedImg.getWidth,ufferedImg.getHeight) // получаем ширину и высоту ячейки в пикселях val colWidthInPixels = Math.round(sheet.getColumnWidthInPixels(columnIdx)) val rowHeightInPixels = Math.round(sheet.getRow(rowNum).getHeightInPoints / 72 * 96) // вычисляем масштабный коэффициент val ScaleX = colWidthInPixels.toDouble/originalDimension.width val ScaleY = rowHeightInPixels.toDouble / originalDimension.height // используем меньший масштабный коэффициент, чтобы изображение помещалось в ячейку val шкала = Math.min(scaleX, ScaleY) // гарантирует, что масштабный коэффициент не может быть ниже "0,1" - иначе изображения будут слишком маленькими val пересмотренныйScale = Math.max(масштаб, 0,1) // изменение размера изображения val image: Picture = Drawing.createPicture(anchor, PictureIdx) картинка.resize(revisedScale) // вычисляем новую высоту и ширину масштабированного изображения val ScaledWidth = (originalDimension.width * пересмотренныйScale).toInt val ScaledHeight = (originalDimension.height * reviewScale).toInt // вычисляем, на сколько нужно переместить изображение, чтобы центрировать его в ячейке val moveX = (colWidthInPixels - ScaledWidth)/2 val moveY = (rowHeightInPixels - ScaledHeight)/2 // перемещаем изображение по центру ячейки якорь.setDx1(moveX) якорь.setDy1(moveY) } Любая помощь будет высоко оценена.
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение
-
-
Apache Poi `4.1.2` Файл PowerPoint Corrupt On Open, работал с Apache Poi` 3.17`
Anonymous » » в форуме JAVA - 0 Ответы
- 32 Просмотры
-
Последнее сообщение Anonymous
-
-
-
Apache Poi `4.1.2` Файл PowerPoint Corrupt On Open, работал с Apache Poi` 3.17`
Anonymous » » в форуме JAVA - 0 Ответы
- 30 Просмотры
-
Последнее сообщение Anonymous
-