刚开始是在一个canvas上,两个文字路径分别裁切同一个图片,这样生成的pdf文件,用pdf打开显示没问题,但是用AI打开有问题,所以分别在两个PdfFormXObject上的canvas上,分别用文字路径去裁切图片,然后添加到同一个canvas上,这样最后生成的pdf文件,用AI打开也是没问题的。
实现代码:
public void textArt(String dest) throws Exception {
Rectangle pageSize = new Rectangle(800,800);
PdfDocument pdfDoc = new PdfDocument(new PdfWriter(DEST));
pdfDoc.setDefaultPageSize(new PageSize(pageSize));
pdfDoc.addNewPage();
ImageData imageData = ImageDataFactory.create(SRC);
Image image = new Image(imageData);
//PdfFormXObject pageXObject = srcDoc.getFirstPage().copyAsFormXObject(pdfDoc);
PdfImageXObject pageXObject = (PdfImageXObject) image.getXObject();
String firstLine = "二月";
String secondLine = "你好鸭";
float fontSize = 80;
float top=getDrawTop(fontSize);
PdfFont font = PdfFontFactory.createFont("E:/upload/font/MXYZ-1A5208E7355D4A0CB7E92BC83A21D772.ttf", PdfEncodings.IDENTITY_H,true);
float w1=font.getWidth(firstLine,fontSize);
float w2=font.getWidth(secondLine,fontSize);
Rectangle rect1 = new Rectangle(100, 400,w2,top*2);
PdfFormXObject t_canvas1 = new PdfFormXObject(pageSize);
PdfCanvas canvas1 = new PdfCanvas(t_canvas1, pdfDoc);
canvas1.beginText()
.moveText(100+w2-w1, 400+top)
.setFontAndSize(font, fontSize)
.setTextRenderingMode(PdfCanvasConstants.TextRenderingMode.CLIP)
.showText(firstLine)
.endText()
.clip()
.newPath();
canvas1.addXObject(pageXObject,rect1);
PdfFormXObject t_canvas2 = new PdfFormXObject(pageSize);
PdfCanvas canvas2 = new PdfCanvas(t_canvas2, pdfDoc);
canvas2.beginText()
.moveText(100, 400)
.setFontAndSize(font, fontSize)
.setTextRenderingMode(PdfCanvasConstants.TextRenderingMode.CLIP)
.showText(secondLine)
.endText()
.clip()
.newPath();
canvas2.addXObject(pageXObject,rect1);
PdfCanvas canvas = new PdfCanvas(pdfDoc.getFirstPage());
canvas.addXObject(t_canvas1, 0, 0);
canvas.addXObject(t_canvas2, 0, 0);
pdfDoc.close();
}