页面事件相关
- 接口: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));