我很新的iText的,并试图实现以下目标:
- 读取本地高清的文本文件列表
- 排列文件的文本中有2列布局的PDF文件
- 每个文本前加一个连续编号指数
我开始与MovieColumns1例子( http://itextpdf.com/examples/iia.php?id=64 ),并结束了与下面的代码:
final float[][] COLUMNS_COORDS = { { 36, 36, 296, 806 }, { 299, 36, 559, 806 } };
Document document = new Document(PageSize.A4);
PdfWriter writer = PdfWriter.getInstance(document, resultFile);
document.open();
ColumnText ct = new ColumnText(writer.getDirectContent());
ct.setSimpleColumn(COLUMNS_COORDS[0][0], COLUMNS_COORDS[0][1],
COLUMNS_COORDS[0][2], COLUMNS_COORDS[0][3]);
File textDir = new File("c:/Users/raddatz/Desktop/123/texts/");
File[] files = textDir.listFiles();
int i = 1;
int column = 0;
for (File file : files) {
String text = FileUtils.readFileToString(file, "UTF-8");
float yLine = ct.getYLine();
System.out.println("adding '" + file.getName() + "'");
PdfPCell theText = new PdfPCell(new Phrase(text, new Font(Font.HELVETICA, 10)));
theText.setBorder(Rectangle.NO_BORDER);
theText.setPaddingBottom(10);
PdfPCell runningNumber = new PdfPCell(new Phrase(new DecimalFormat("00").format(i++), new Font(
Font.HELVETICA, 14, Font.BOLDITALIC,
new Color(0.7f, 0.7f, 0.7f))));
runningNumber.setBorder(Rectangle.NO_BORDER);
runningNumber.setPaddingBottom(10);
PdfPTable table = new PdfPTable(2);
table.setWidths(new int[] { 12, 100 });
table.addCell(runningNumber);
table.addCell(theText);
ct.addElement(table);
int status = ct.go(true);
if (ColumnText.hasMoreText(status)) {
column = Math.abs(column - 1);
if (column == 0) {
document.newPage();
System.out.println("inserting new page with size :" + document.getPageSize());
}
ct.setSimpleColumn(
COLUMNS_COORDS[column][0], COLUMNS_COORDS[column][1],
COLUMNS_COORDS[column][2], COLUMNS_COORDS[column][3]);
yLine = COLUMNS_COORDS[column][3];
System.out.println("correcting yLine to: " + yLine);
} else {
ct.addElement(table);
}
ct.setYLine(yLine);
System.out.println("before adding: " + ct.getYLine());
status = ct.go(false);
System.out.println("after adding: " + ct.getYLine());
System.out.println("--------------------------------");
}
document.close();
在这里,你可以看到结果: http://d.pr/f/NEmx
望着生成的PDF我承担的第一页,一切工作了罚款。
但在第二页上,你可以看到这个问题(S):
- 文本#31没有被完全显示(第一行+索引被切断/不可见区域)
- 文本#46没有被完全显示出来(前三行+索引被切断/不可见区域)
第3页一切似乎又是好的。 我真的失去了这里。
- UPDATE(2013年3月14日) -
现在我已经分析了PDF的内容。 问题不在于内容显示在不可见的区域,但内容是不存在于PDF格式在所有。 内容的缺失部分恰好这将有适合上一列/页的一个。 所以它看起来像ColumnText.go(真)之前操作()由addElement方法传递的对象。 有人可以证实这一点? 如果是这样的:我能做些什么呢?
-端UPDATE(2013年3月14日) -
期待你的回复
问候,斯文