1

我使用 XMLWorker (5.5.6) 将包含阿拉伯字符的 XHTML 页面转换为 PDF。一切正常,但“page-break-before”不起作用!这是我的html页面:

<!DOCTYPE html>
<html>
    <head>
        <title>Déclaration</title>
        <style type="text/css" >
            table {
                page-break-before: always;
            }
        </style>
    </head>
<body style="font-family: Noto Naskh Arabic">
<p style="page-break-before: always;text-align: center; font-size: 24px; font-family: Noto Naskh Arabic">الجمهورية</p>
<div style="page-break-before: always;text-align: center; font-size: 18px; font-family: Verdana" >REPUBLIQUE </div>
<div dir="rtl" style="page-break-before: always;text-align: center; font-size: 24px; font-family: Noto Naskh Arabic" >تصريــــح    بالممتلكـــــات</div>
<p style="font-family: Verdana">DECLARATION </p>

<table width="100%" style="page-break-before: always" >
	<tr><td>Code Willaya </td><td></td><td>رمز الولاية</td></tr>
	<tr><td>Code de la commune </td><td></td><td>رمز البلدية</td></tr>
</table>

还有使用的 Java 代码http://developers.itextpdf.com/2078

4

1 回答 1

4

page-break-before仅当 XML 工作程序生成的元素直接添加到 中时才支持样式属性Document,而不是像您的示例中那样将它们添加到表格单元格中。不幸的是,仅在表格单元格内支持 RTL。

但是,由于示例本身添加了元素,因此可以对其进行改进以正确解释分页符标记,只需增强原始循环

PdfPTable table = new PdfPTable(1);
PdfPCell cell = new PdfPCell();
cell.setRunDirection(PdfWriter.RUN_DIRECTION_RTL);
for (Element e : elements) {
    cell.addElement(e);
}
table.addCell(cell);
document.add(table);

像这样:

PdfPTable table = new PdfPTable(1);
PdfPCell cell = new PdfPCell();
cell.setRunDirection(PdfWriter.RUN_DIRECTION_RTL);
for (Element e : elements) {
    if (e == Chunk.NEXTPAGE)
    {
        table.addCell(cell);
        document.add(table);
        document.newPage();
        table = new PdfPTable(1);
        cell = new PdfPCell();
    }
    else
    {
        cell.addElement(e);
    }
}
table.addCell(cell);
document.add(table);

(您可能应该添加一些检查以防止在此处添加空表。)


顺便说一句,为了让这个例子完全处理你的例子,我不得不注释掉你的标题元素。但这可能是您的 XMLWorker 版本 5.5.6 和我在这里使用的版本 5.5.11-SNAPSHOT 之间的差异。

于 2017-02-23T12:17:18.723 回答