Personalizza i numeri di pagina durante l'aggiunta del sommario
In questa esercitazione, esploreremo come personalizzare i numeri di pagina aggiungendo un sommario (TOC) utilizzando Aspose.PDF per .NET. Forniremo una guida passo passo, insieme a un esempio di codice, per aiutarti a raggiungere questo obiettivo.
Passaggio 1: caricamento di un file PDF esistente
Innanzitutto, dobbiamo caricare un file PDF esistente. Per questo tutorial utilizzeremo il file “42824.pdf” situato nella directory “LA TUA DIRECTORY DOCUMENTI”. Sostituisci questo percorso di directory con il percorso effettivo della directory dei documenti.
string dataDir = "YOUR DOCUMENT DIRECTORY";
string inFile = dataDir + "42824.pdf";
string outFile = dataDir + "42824_out.pdf";
Document doc = new Document(inFile);
Passaggio 2: aggiunta di una pagina di sommario
Successivamente, dobbiamo aggiungere una nuova pagina all’inizio del documento che funga da pagina del sommario. Possiamo raggiungere questo obiettivo utilizzando il fileInsert()
metodo delPages
raccolta delDocument
oggetto.
Aspose.Pdf.Page tocPage = doc.Pages.Insert(1);
Passaggio 3: creazione di un oggetto TOC
Per creare un oggetto TOC, dobbiamo prima creare un fileTocInfo
oggetto e impostarne le proprietà. In questo tutorial, imposteremo il titolo del sommario su “Sommario” e il prefisso del numero di pagina su “P”.
TocInfo tocInfo = new TocInfo();
TextFragment title = new TextFragment("Table Of Contents");
title.TextState.FontSize = 20;
title.TextState.FontStyle = FontStyles.Bold;
tocInfo.Title = title;
tocInfo.PageNumbersPrefix = "P";
tocPage.TocInfo = tocInfo;
Passaggio 4: creazione delle voci del sommario
Per creare voci di sommario, dobbiamo scorrere tutte le pagine del documento, ad eccezione della pagina del sommario, e creare un oggetto intestazione per ciascuna pagina. Possiamo quindi aggiungere l’oggetto intestazione alla pagina TOC e specificarne la pagina di destinazione.
for (int i = 1; i < doc.Pages.Count; i++)
{
// Crea oggetto Intestazione
Aspose.Pdf.Heading heading2 = new Aspose.Pdf.Heading(1);
TextSegment segment2 = new TextSegment();
heading2.TocPage = tocPage;
heading2.Segments.Add(segment2);
// Specificare la pagina di destinazione per l'oggetto intestazione
heading2.DestinationPage = doc.Pages[i + 1];
// Pagina di destinazione
heading2.Top = doc.Pages[i + 1].Rect.Height;
// Coordinata di destinazione
segment2.Text = "Page " + i.ToString();
// Aggiungi intestazione alla pagina contenente il sommario
tocPage.Paragraphs.Add(heading2);
}
Passaggio 5: salvataggio del documento aggiornato
Infine, dobbiamo salvare il documento aggiornato in un nuovo file. Possiamo raggiungere questo obiettivo utilizzando il fileSave()
metodo delDocument
oggetto.
doc.Save(outFile);
Esempio di codice sorgente per personalizzare i numeri di pagina durante l’aggiunta del sommario utilizzando Aspose.PDF per .NET
string dataDir = "YOUR DOCUMENT DIRECTORY";
string inFile = dataDir + "42824.pdf";
string outFile = dataDir + "42824_out.pdf";
// Carica un file PDF esistente
Document doc = new Document(inFile);
// Ottieni l'accesso alla prima pagina del file PDF
Aspose.Pdf.Page tocPage = doc.Pages.Insert(1);
// Crea un oggetto per rappresentare le informazioni del sommario
TocInfo tocInfo = new TocInfo();
TextFragment title = new TextFragment("Table Of Contents");
title.TextState.FontSize = 20;
title.TextState.FontStyle = FontStyles.Bold;
// Imposta il titolo per il sommario
tocInfo.Title = title;
tocInfo.PageNumbersPrefix = "P";
tocPage.TocInfo = tocInfo;
for (int i = 1; i<doc.Pages.Count; i++)
{
// Crea oggetto Intestazione
Aspose.Pdf.Heading heading2 = new Aspose.Pdf.Heading(1);
TextSegment segment2 = new TextSegment();
heading2.TocPage = tocPage;
heading2.Segments.Add(segment2);
// Specificare la pagina di destinazione per l'oggetto intestazione
heading2.DestinationPage = doc.Pages[i + 1];
// Pagina di destinazione
heading2.Top = doc.Pages[i + 1].Rect.Height;
// Coordinata di destinazione
segment2.Text = "Page " + i.ToString();
// Aggiungi intestazione alla pagina contenente il sommario
tocPage.Paragraphs.Add(heading2);
}
// Salva il documento aggiornato
doc.Save(outFile);
Conclusione
In questo tutorial, abbiamo fornito una guida passo passo su come personalizzare i numeri di pagina aggiungendo un sommario utilizzando Aspose.PDF per .NET. Abbiamo anche fornito un esempio di codice che puoi utilizzare come riferimento quando implementi questa funzionalità nel tuo
Domande frequenti
D: Cos’è un sommario (TOC) in un documento PDF?
R: Un sommario (TOC) in un documento PDF è un aiuto alla navigazione che fornisce un elenco organizzato di sezioni o capitoli del documento insieme ai numeri di pagina corrispondenti. Consente ai lettori di navigare rapidamente verso sezioni specifiche all’interno del documento.
D: Perché dovrei personalizzare i numeri di pagina in un sommario?
R: La personalizzazione dei numeri di pagina in un sommario può essere utile quando desideri utilizzare un formato di numerazione delle pagine specifico o includere informazioni aggiuntive insieme ai numeri di pagina. Ti consente di creare un sommario più personalizzato e informativo.
D: Posso includere collegamenti ipertestuali nel sommario per collegarmi a sezioni o pagine specifiche all’interno del documento PDF?
R: Sì, Aspose.PDF per .NET ti consente di creare collegamenti ipertestuali nel sommario che collegano a sezioni o pagine specifiche all’interno del documento PDF. Ciò migliora l’interattività e la navigazione del documento PDF.
D: Aspose.PDF per .NET è compatibile con gli standard PDF/A?
R: Sì, Aspose.PDF per .NET supporta gli standard PDF/A, inclusi PDF/A-1, PDF/A-2 e PDF/A-3. Consente di creare documenti PDF conformi ai requisiti di archiviazione e conservazione a lungo termine.
D: Posso aggiungere ulteriore formattazione alle voci del sommario, ad esempio stili o colori dei caratteri?
R: Sì, puoi aggiungere ulteriore formattazione alle voci del sommario, come stili di carattere, colori e dimensioni dei caratteri, utilizzando Aspose.PDF per .NET. Ciò ti consente di personalizzare l’aspetto del sommario in base alle tue esigenze.