PageInfo

PageInfo class

Représente des informations sur une page de document particulière.

Pour en savoir plus, visitez leLe rendu article documentaire.

public class PageInfo

Propriétés

NomLa description
Colored { get; }Retoursvrai si la page contient du contenu coloré.
HeightInPoints { get; }Obtient la hauteur de la page en points.
Landscape { get; }Retoursvrai si l’orientation de la page spécifiée dans le document pour cette page est paysage.
PaperSize { get; }Obtient le format du papier sous forme d’énumération.
PaperTray { get; }Obtient le bac à papier (bac) pour cette page comme spécifié dans le document. La valeur est spécifique à l’implémentation (imprimante).
SizeInPoints { get; }Obtient la taille de la page en points.
WidthInPoints { get; }Obtient la largeur de la page en points.

Méthodes

NomLa description
GetDotNetPaperSize(PaperSizeCollection)Obtient lePaperSize objet adapté à l’impression la page représentée par ceciPageInfo .
GetSizeInPixels(float, float)Calcule la taille de la page en pixels pour un facteur de zoom et une résolution spécifiés.
GetSizeInPixels(float, float, float)Calcule la taille de la page en pixels pour un facteur de zoom et une résolution spécifiés.
GetSpecifiedPrinterPaperSource(PaperSourceCollection, PaperSource)Obtient lePaperSource objet adapté à l’impression la page représentée par ceciPageInfo .

Remarques

La largeur et la hauteur de la page renvoyées par cet objet représentent la taille “finale” de la page, par exemple elles sont déjà pivotées dans la bonne orientation.

Exemples

Montre comment imprimer les informations sur la taille et l’orientation de chaque page d’un document Word.

Document doc = new Document(MyDir + "Rendering.docx");

// La première section comporte 2 pages. Nous attribuerons à chacun un bac à papier d'imprimante différent,
// dont le numéro correspondra à une sorte de source papier. Ces sources et leurs types varient
// en fonction du pilote d'imprimante installé.
PrinterSettings.PaperSourceCollection paperSources = new PrinterSettings().PaperSources;

doc.FirstSection.PageSetup.FirstPageTray = paperSources[0].RawKind;
doc.FirstSection.PageSetup.OtherPagesTray = paperSources[1].RawKind;

Console.WriteLine("Document \"{0}\" contains {1} pages.", doc.OriginalFileName, doc.PageCount);

float scale = 1.0f;
float dpi = 96;

for (int i = 0; i < doc.PageCount; i++)
{
    // Chaque page possède un objet PageInfo, dont l'index est le numéro de la page respective.
    PageInfo pageInfo = doc.GetPageInfo(i);

    // Imprime l'orientation et les dimensions de la page.
    Console.WriteLine($"Page {i + 1}:");
    Console.WriteLine($"\tOrientation:\t{(pageInfo.Landscape ? "Landscape" : "Portrait")}");
    Console.WriteLine($"\tPaper size:\t\t{pageInfo.PaperSize} ({pageInfo.WidthInPoints:F0}x{pageInfo.HeightInPoints:F0}pt)");
    Console.WriteLine($"\tSize in points:\t{pageInfo.SizeInPoints}");
    Console.WriteLine($"\tSize in pixels:\t{pageInfo.GetSizeInPixels(1.0f, 96)} at {scale * 100}% scale, {dpi} dpi");

    // Imprime les informations du bac source.
    Console.WriteLine($"\tTray:\t{pageInfo.PaperTray}");
    PaperSource source = pageInfo.GetSpecifiedPrinterPaperSource(paperSources, paperSources[0]);
    Console.WriteLine($"\tSuitable print source:\t{source.SourceName}, kind: {source.Kind}");
}

Voir également