如何在单元格内的图像顶部添加文本

本文关键字:图像 顶部 添加 文本 单元格 | 更新日期: 2023-09-27 18:32:25

我在将文本放在单元格内图像的顶部(而不是下方)时遇到问题。

我的代码如下所示:

Image img = Image.GetInstance(imagePatch);
img.Alignment = Image.UNDERLYING;
img.ScaleToFit(img.Width, img.Height);
img.ScaleAbsoluteWidth(ptable.TotalWidth);
pcell.AddElement(img);
pcell.addElement(new Paragraph("text", font));
img.SetAbsolutePosition(0, ptable.TotalHeight);`

但是文本显示在图像下方而不是顶部。

我能做什么?有没有办法将填充从图像边框设置为文本内容?

如何在单元格内的图像顶部添加文本

根据

实际要求,有多种方法可以实现您想要的。

方法1:

第一种方法在水印图像 1 示例中进行了说明。在此示例中,我们创建一个PdfTemplate,向其添加图像以及一些写在该图像之上的文本。然后,我们可以将此PdfTemplate包装在图像中,并将该图像及其水印一起添加到单元格中。

这是执行所有魔术的方法:

public Image getWatermarkedImage(PdfContentByte cb, Image img, String watermark) throws DocumentException {
    float width = img.getScaledWidth();
    float height = img.getScaledHeight();
    PdfTemplate template = cb.createTemplate(width, height);
    template.addImage(img, width, 0, 0, height, 0, 0);
    ColumnText.showTextAligned(template, Element.ALIGN_CENTER,
            new Phrase(watermark, FONT), width / 2, height / 2, 30);
    return Image.getInstance(template);
}

方法2.a

第二种方法在水印图像2示例中进行了说明。在这种情况下,我们将每个图像添加到 PdfPCell .此PdfPCell将缩放图像,使其适合页面的宽度。为了添加水印,我们使用一个单元格事件:

class WatermarkedCell implements PdfPCellEvent {
    String watermark;
    public WatermarkedCell(String watermark) {
        this.watermark = watermark;
    }
    public void cellLayout(PdfPCell cell, Rectangle position,
        PdfContentByte[] canvases) {
        PdfContentByte canvas = canvases[PdfPTable.TEXTCANVAS];
        ColumnText.showTextAligned(canvas, Element.ALIGN_CENTER,
            new Phrase(watermark, FONT),
            (position.getLeft() + position.getRight()) / 2,
            (position.getBottom() + position.getTop()) / 2, 30);
    }
}

此单元格事件可以像这样使用:

PdfPCell cell;
cell = new PdfPCell(Image.getInstance(IMAGE1), true);
cell.setCellEvent(new WatermarkedCell("Bruno"));
table.addCell(cell);
cell = new PdfPCell(Image.getInstance(IMAGE2), true);
cell.setCellEvent(new WatermarkedCell("Dog"));
table.addCell(cell);
cell = new PdfPCell(Image.getInstance(IMAGE3), true);
cell.setCellEvent(new WatermarkedCell("Fox"));
table.addCell(cell);
cell = new PdfPCell(Image.getInstance(IMAGE4), true);
cell.setCellEvent(new WatermarkedCell("Bruno and Ingeborg"));
table.addCell(cell);

如果所有图像的大小大致相同,并且您不想担心图像是否适合页面,则将使用此方法。

方法2.b:

除了将文本添加到包含图像的单元格的单元格事件的TEXTCANVAS,还可以将图像添加到包含文本的单元格的单元格事件的BACKGROUNDCANVAS

注意:您的问题可能会因重复而关闭 如何向图像添加文本?