页面事件相关
- 接口:IPdfPageEvent
 定义了页面变化触发的函数
- 类:PdfPageEventHelper
 继承接口IPdfPageEvent,函数全部是虚函数,根据需要重写函数。
- 属性 PdfWriter.PageEvent
 设置IPdfPageEvent接口对象
页面事件触发时机
- OnOpenDocument(PdfWriter writer, Document document)
 触发时机:document.Open() 被调用后,第一页创建之前。
- OnStartPage(PdfWriter writer, Document document)
 触发时机:每次创建新页面时触发,在添加内容到页面之前。
- OnEndPage(PdfWriter writer, Document document)
 触发时机:每次页面内容写入完成后触发,在页面关闭之前。
- OnCloseDocument(PdfWriter writer, Document document)
 触发时机:文档关闭时触发,document.Close() 被调用后。
- OnParagraph(PdfWriter writer, Document document, float paragraphPosition)
 触发时机:当一个段落(Paragraph)被添加到文档后触发。
- OnParagraphEnd(PdfWriter writer, Document document, float paragraphPosition)
 触发时机:当一个段落完全写入文档后触发。
- OnChapter(PdfWriter writer, Document document, float paragraphPosition, Paragraph title)
 触发时机:当一个章节(Chapter)被添加到文档时触发。
- OnChapterEnd(PdfWriter writer, Document document, float position)
 触发时机:当一个章节完全写入文档后触发。
- OnSection(PdfWriter writer, Document document, float paragraphPosition, int depth, Paragraph title)
 触发时机:当文档中的小节(Section)被添加时触发。
- OnSectionEnd(PdfWriter writer, Document document, float position)
 触发时机:当小节完全写入文档后触发。
常用用途
设置页眉,页脚,添加水印等
示例
新建类继承PdfPageEventHelper,重写OnEndPage方法
 每当一个页面结束时,底部中间显示AAA AAA
 BaseFont对象的GetWidthPoint方法可以依据文本内容,字体大小获取文本的宽度
public class NewPageEvent : PdfPageEventHelper
{public override void OnEndPage(PdfWriter writer, Document document){  PdfContentByte cb = writer.DirectContent;BaseFont bf = BaseFont.CreateFont(BaseFont.HELVETICA, BaseFont.CP1252, false);var bottomCenterContent = "AAA AAA";cb.BeginText(); cb.SetFontAndSize(bf, 10);cb.SetTextMatrix(document.PageSize.Width / 2 - bf.GetWidthPoint(bottomCenterContent, 10) / 2, 10);//居中显示cb.ShowText(bottomCenterContent);cb.EndText();}
}
新建对象NewPageEvent进行赋值
var writer = PdfWriter.GetInstance(doc, new FileStream(fileName, FileMode.Create));
writer.PageEvent = new NewPageEvent();//赋值 自定义页面事件
doc.Open();
doc.Add(new Paragraph("你好,世界!", BoldFont));
