ITextSharp 中的页眉和页脚

Header and Footer in ITextSharp

我知道这个问题已被问过一千次,但我还没有找到直接的答案。我对 ITextSharp 比较陌生,所以请像和小孩说话一样解释。如何向我正在创建的文档添加纯文本页眉和页脚?

我正在使用以下代码创建一个简单的 pdf 文档:

void Button1Click(object sender, EventArgs e)
    {

            Document doc = new Document(iTextSharp.text.PageSize.LEDGER, 10, 10, 42, 35);
            PdfWriter wri = PdfWriter.GetInstance(doc, new FileStream(@"File Path", FileMode.Create));

            doc.Open();
            Paragraph par1 = new Paragraph("Hello World!");
            doc.Add(par1);

            //Code to add header/footer

            doc.Close();

            MessageBox.Show("Your PDF has been created!");
    }

我对如何添加页眉和页脚做了很多研究,但它们都与复杂的页面事件有关。有没有更简单的方法?如果没有,你能一步一步地引导我完成这个过程吗?我真的很感激你们能提供的任何帮助。谢谢!

您正在这样创建 Document

Document doc = new Document(iTextSharp.text.PageSize.LEDGER, 10, 10, 42, 35);

这意味着您的上边距为 42 个用户单位,下边距为 35 个用户单位。您可以使用此边距在页面事件中添加额外内容。

官方网站有大量示例和全面的问答部分。所有示例和答案均已标记。如果单击 header 标签,您可以找到大量示例。

正如其他人在评论中指出的那样,您需要创建一个 PdfPageEvent 实现。最简单的方法是扩展 PdfPageEventHelper class。

class MyHeaderFooterEvent : PdfPageEventHelper {
  Font FONT = new Font(Font.FontFamily.HELVETICA, 18, Font.BOLD);

  public override void OnEndPage(PdfWriter writer, Document document) {
    PdfContentByte canvas = writer.DirectContent;
    ColumnText.ShowTextAligned(
      canvas, Element.ALIGN_LEFT,
      new Phrase("Header", FONT), 10, 810, 0
    );
    ColumnText.ShowTextAligned(
      canvas, Element.ALIGN_LEFT,
      new Phrase("Footer", FONT), 10, 10, 0
    );
  }
}

重要信息:

  • 禁止在OnStartPage()活动中添加内容。在 iTextSharp 移至新页面之前将所有内容添加到页面后,添加 header 和页脚。更具体地说:在 OnEndPage() 事件中添加内容。
  • 禁止向传递给事件的Document object 添加内容。此 object 只能用于 read-only 目的。

如果你检查 MyHeaderFooterEvent class 中的 OnEndPage() 方法,你会看到我们从作者那里得到了 DirectContent 并且我们向这个 canvas 使用 ShowTextAligned 方法。还有许多其他添加内容的方法,但您明确要求使用最简单的方法。这种方式有其局限性,但很简单。

我使用了几个 hard-coded 值:我使用 10 作为 header 和页脚的 x 值。那是因为您定义了 10 个用户单位的左边距。 header 和页脚与您添加到页面的实际内容左对齐。我使用 810 作为 header 的 y 值,因为您正在创建一个上边距为 42 的 A4 页面。页面的顶部 y 坐标是 842 . top y top margin 的坐标是842 - 42 = 800 我加了10个用户单位这样你的header 就不会粘在实际内容上了。在你的情况下,页面底部 y 坐标为 0,页边距底部 y 坐标为 35。我使用 10 作为页脚的基线。

您创建了 wri,并在创建此 PdfWriter 实例后立即打开了 Document 实例。要使页面事件生效,您应该在打开 Document 之前添加以下 link:

wri.PageEvent = new MyHeaderFooterEvent();

现在每次主进程完成页面时都会调用 OnEndPage() 方法。

重要提示:你在错误的地方添加了//Code to add header/footer。 iTextSharp 将尝试尽快刷新页面的内容。如果您添加代码以在 添加内容后添加 header/footer ,则无法返回以向已刷新的页面添加 header 和页脚到输出流。