我使用The Flying Saucer Project将HTML文件转换为PDF格式。这是包含重复信息的文档 - 前提及其地址,我们称之为元素。在文档的最后我需要创建一个索引。每个索引条目都应该有一个页码,指向添加元素的页面。可以放在一个页面上的元素数量会有所不同。
如何创建文档索引?或者,当图书馆将特定类型的HTML元素添加到PDF文档时,如何收到通知?
答案 0 :(得分:7)
试试这个:
在CSS中
ol.toc a::after { content: leader('.') target-counter(attr(href), page);}
在HTML中
<h1>Table of Contents</h1>
<ol class='toc'>
<li><a href=\"#chapter1\">Loomings</a></li>
<li><a href=\"#chapter2\">The Carpet-Bag</a></li>
<li><a href=\"#chapter3\">The Spouter-Inn</a></li>
</ol>
<div id="chapter1">Loomings</div>
答案 1 :(得分:1)
我找到了可能的答案。你必须开始玩org.xhtmlrenderer.render.BlockBox
课程。方法public void layout(LayoutContext c, int contentStart)
用于正确放置PDF文档中的任何HTML元素。此方法迭代一次元素几次。在最后一次迭代之后,设置了有效的页码。
如果您要标记要编制索引的元素,例如使用类属性,则可以使用以下代码获取页码:
String cssClass = getElement().getAttribute("class");
if(!cssClass.equals("index")) {
int pageNumber = c.getRootLayer().getPages().size();
/* ... */
}