2012-05-07 25 views
3

itextsharp pdfファイルのフッタにページ番号を追加します.html(asp.net repeater)からpdfを生成します。また、HTMLコンテンツを解析するためにXMLWorkerHelperを使用しています。多くを検索しましたが、これを実現するのに役立つものは何も見つかりません。pdf文書を追加する(itextsharp)

+1

うーん、奇妙な。どのように正確に検索しましたか?私は[次のリンク](http://www.google.com/#hl=en&sclient=psy-ab&q=itextsharp+add+page+number&oq=itextsharp+add+page+numbers&aq=f&aqi=g1&aql=&gs_l)にアクセスしたので、 = hp.3..0.438.7461.0.7578.27.15.0.12.12.0.158.1445.11j4.15.0 ... 0.0.xJrtHtJSBd0&pbx = 1&bav = on.2、または.r_gc.r_pw.r_qf。、cf.osb&fp = d0f8cd49a0fc8cd2&biw = 1440&bih = 795)私は相当量の興味深いポインタを得ました。 –

+0

その場で文書を作成する場合は、ページ番号を追加する例がありますが、ページ内のHTMLからpdf文書を作成しています。何もしません。このrepeater.RenderControlプロパティによって、 xhtmlworkerhelp class.Shortly pdfドキュメントはxhtmlworkerhelpによって作成されています。私はドキュメントの詳細に関与しません。私が何をしているのか分かりますか? – slayer35

答えて

11

iTextSharpでPDFを開き、ページ番号を自分で追加する必要があります。私はこれのようなことをしばらくやりました、ここにあなたのスタートを与えるかもしれない機能があります。 この機能は現在のページを左下に追加するため、必要に応じて別の場所に配置する必要があります。

このような何かが動作するはず
public static byte[] AddPageNumbers(byte[] pdf) 
{ 
MemoryStream ms = new MemoryStream(); 
// we create a reader for a certain document 
PdfReader reader = new PdfReader(pdf); 
// we retrieve the total number of pages 
int n = reader.NumberOfPages; 
// we retrieve the size of the first page 
Rectangle psize = reader.GetPageSize(1); 

// step 1: creation of a document-object 
Document document = new Document(psize, 50, 50, 50, 50); 
// step 2: we create a writer that listens to the document 
PdfWriter writer = PdfWriter.GetInstance(document, ms); 
// step 3: we open the document 

document.Open(); 
// step 4: we add content 
PdfContentByte cb = writer.DirectContent; 

int p = 0; 
Console.WriteLine("There are " + n + " pages in the document."); 
for (int page = 1; page <= reader.NumberOfPages; page++) 
{ 
    document.NewPage(); 
    p++; 

    PdfImportedPage importedPage = writer.GetImportedPage(reader, page); 
    cb.AddTemplate(importedPage, 0, 0); 

    BaseFont bf = BaseFont.CreateFont(BaseFont.HELVETICA, BaseFont.CP1252, BaseFont.NOT_EMBEDDED); 
    cb.BeginText(); 
    cb.SetFontAndSize(bf, 10); 
    cb.ShowTextAligned(PdfContentByte.ALIGN_LEFT, +p + "/" + n, 7, 44, 0); 
    cb.EndText(); 
} 
// step 5: we close the document 
document.Close(); 
return ms.ToArray(); 
} 
+0

ありがとう、それは私のために働く – slayer35

+3

どのように私は飛んで私のバイト配列にPDFを生成した私の変換することができますか? –

+0

すばらしい答え!私の場合、ms.Write(pdf、0、pdf.Length)は必要ではなく、ファイルが破損しています。 – Pinch

1

var sourceFileList = new List<string>(); 

//add files to merge 

int sourceIndex = 0; 
PdfReader reader = new PdfReader(sourceFileList[sourceIndex]); 
int sourceFilePageCount = reader.NumberOfPages; 

Document doc = new Document(reader.GetPageSizeWithRotation(1)); 
PdfWriter writer = PdfWriter.GetInstance(doc, new FileStream(destinationFileName, FileMode.Create)); 
doc.Open(); 

PdfImportedPage page; 
PdfContentByte contentByte = writer.DirectContent;     

int rotation; 
while (sourceIndex < sourceFileList.Count) 
{ 
    int pageIndex = 0; 
    while (pageIndex < sourceFilePageCount) 
    { 
     pageIndex++; 

     doc.SetPageSize(reader.GetPageSizeWithRotation(pageIndex)); 
     doc.NewPage(); 

     page = writer.GetImportedPage(reader, pageIndex); 
     rotation = reader.GetPageRotation(pageIndex); 

     if (rotation.Equals(90 | 270)) 
      contentByte.AddTemplate(page, 0, -1f, 1f, 0, 0, reader.GetPageSizeWithRotation(pageIndex).Height); 
     else 
      contentByte.AddTemplate(page, 1f, 0, 0, 1f, 0, 0); 
    } 

    sourceIndex++; 
    if (sourceIndex < sourceFileList.Count) 
    { 
     reader = new PdfReader(sourceFileList[sourceIndex]); 
     sourceFilePageCount = reader.NumberOfPages; 
    } 
} 

doc.Close(); 
関連する問題