---最近在用itext写pdf报告,期间遇到目录生成的问题,而目录生成我认为最关键的是获取章节的页码问题。下面分别介绍这两种方法。除了这两种方法之外,还可以参考我的另一篇博客:ITEXT 目录生成的第三种方法
---前言:为了能唯一定位每个章节的页码,章节都是通过图片贴在PDF上的,即正文里的目录章节内容是图片格式。
---方法一:
-------1、先生成不带目录的PDF文件,命名为a.pdf。假设此时目录应该在第3页,分别从a.pdf中截取pdf文件,分别命名为a-start.pdf、a-end.pdf。
-------2、遍历a.pdf获取目录章节的页码。命名为a-middle.pdf。
-------3、合并a-start.pdf、a-middle.pdf、a-end.pdf三个PDF。
-------复杂度:O(M*N) M为a.pdf页数、N为目录中章节的数目。
---方法二:
-------1、先生成不带目录的PDF文件,并用Map记录目录中章节出现的页码,命名为a.pdf。假设此时目录应该在第3页,分别从a.pdf中截取pdf文件,分别命名为a-start.pdf、a-end.pdf。
-------2、直接从Map集合中获取目录章节的页码。命名为a-middle.pdf。
-------复杂度:O(N) M为a.pdf页数、N为目录中章节的数目。
-------分析:第二种方法本质上利用空间换时间来减少时间复杂度。具体源码详见itext生成目录源码