PrintDocument Klasa

Definicja

Definiuje obiekt wielokrotnego użytku, który wysyła dane wyjściowe do drukarki podczas drukowania z aplikacji Windows Forms.

C#
public class PrintDocument : System.ComponentModel.Component
Dziedziczenie

Przykłady

Poniższy przykład kodu wyświetla plik o nazwie C:\My Documents\MyFile.txt na drukarce domyślnej. Aby uruchomić przykład, utwórz nowy projekt Windows Forms i wklej przykładowy kod w formularzu, zastępując jego zawartość. W przypadku języka C#należy usunąć formularz Form1. Designer.cs plik. Ponadto zmień ścieżkę do pliku, który chcesz wydrukować.

Uwaga

Przykład wymaga, aby każdy wiersz mieścił się w szerokości strony.

C#
using System;
using System.IO;
using System.Drawing;
using System.Drawing.Printing;
using System.Windows.Forms;

public partial class Form1 : System.Windows.Forms.Form
{
    private System.ComponentModel.Container components;
    private System.Windows.Forms.Button printButton;
    private Font printFont;
    private StreamReader streamToPrint;

    public Form1()
    {
        // The Windows Forms Designer requires the following call.
        InitializeComponent();
    }

    // The Click event is raised when the user clicks the Print button.
    private void printButton_Click(object sender, EventArgs e)
    {
        try
        {
            streamToPrint = new StreamReader
               ("C:\\My Documents\\MyFile.txt");
            try
            {
                printFont = new Font("Arial", 10);
                PrintDocument pd = new PrintDocument();
                pd.PrintPage += new PrintPageEventHandler
                   (this.pd_PrintPage);
                pd.Print();
            }
            finally
            {
                streamToPrint.Close();
            }
        }
        catch (Exception ex)
        {
            MessageBox.Show(ex.Message);
        }
    }

    // The PrintPage event is raised for each page to be printed.
    private void pd_PrintPage(object sender, PrintPageEventArgs ev)
    {
        float linesPerPage = 0;
        float yPos = 0;
        int count = 0;
        float leftMargin = ev.MarginBounds.Left;
        float topMargin = ev.MarginBounds.Top;
        string line = null;

        // Calculate the number of lines per page.
        linesPerPage = ev.MarginBounds.Height /
           printFont.GetHeight(ev.Graphics);

        // Print each line of the file.
        while (count < linesPerPage &&
           ((line = streamToPrint.ReadLine()) != null))
        {
            yPos = topMargin + (count *
               printFont.GetHeight(ev.Graphics));
            ev.Graphics.DrawString(line, printFont, Brushes.Black,
               leftMargin, yPos, new StringFormat());
            count++;
        }

        // If more lines exist, print another page.
        if (line != null)
            ev.HasMorePages = true;
        else
            ev.HasMorePages = false;
    }

    // The Windows Forms Designer requires the following procedure.
    private void InitializeComponent()
    {
        this.components = new System.ComponentModel.Container();
        this.printButton = new System.Windows.Forms.Button();

        this.ClientSize = new System.Drawing.Size(504, 381);
        this.Text = "Print Example";

        printButton.ImageAlign =
           System.Drawing.ContentAlignment.MiddleLeft;
        printButton.Location = new System.Drawing.Point(32, 110);
        printButton.FlatStyle = System.Windows.Forms.FlatStyle.Flat;
        printButton.TabIndex = 0;
        printButton.Text = "Print the file.";
        printButton.Size = new System.Drawing.Size(136, 40);
        printButton.Click += new System.EventHandler(printButton_Click);

        this.Controls.Add(printButton);
    }
}

Uwagi

Zazwyczaj należy utworzyć wystąpienie PrintDocument klasy, ustawić właściwości, takie jak DocumentName i PrinterSettings, i wywołać Print metodę , aby rozpocząć proces drukowania. PrintPage Obsłuż zdarzenie, w którym określisz dane wyjściowe do wydrukowania, przy użyciu GraphicsGraphics właściwości PrintPageEventArgs.

Aby uzyskać więcej informacji na temat drukowania z aplikacji Formularz systemu Windows, zobacz Windows Forms Obsługa drukowania. Jeśli chcesz wydrukować z aplikacji Windows Presentation Foundation, zobacz System.Printing przestrzeń nazw.

Uwaga

W programach .NET 6 i nowszych pakiet System.Drawing.Common, który zawiera ten typ, jest obsługiwany tylko w systemach operacyjnych Windows. Użycie tego typu w aplikacjach międzyplatformowych powoduje ostrzeżenia w czasie kompilacji i wyjątki czasu wykonywania. Aby uzyskać więcej informacji, zobacz System.Drawing.Common only supported on Windows (Obsługiwane tylko w systemie Windows).

Konstruktory

PrintDocument()

Inicjuje nowe wystąpienie klasy PrintDocument.

Właściwości

CanRaiseEvents

Pobiera wartość wskazującą, czy składnik może zgłosić zdarzenie.

(Odziedziczone po Component)
Container

Pobiera element IContainer zawierający element Component.

(Odziedziczone po Component)
DefaultPageSettings

Pobiera lub ustawia ustawienia strony, które są używane jako wartości domyślne dla wszystkich stron do wydrukowania.

DesignMode

Pobiera wartość wskazującą, czy Component element jest obecnie w trybie projektowania.

(Odziedziczone po Component)
DocumentName

Pobiera lub ustawia nazwę dokumentu do wyświetlenia (na przykład w oknie dialogowym stanu wydruku lub w kolejce drukarki) podczas drukowania dokumentu.

Events

Pobiera listę programów obsługi zdarzeń dołączonych do tego Componentelementu .

(Odziedziczone po Component)
OriginAtMargins

Pobiera lub ustawia wartość wskazującą, czy pozycja obiektu graficznego skojarzonego ze stroną znajduje się tuż wewnątrz marginesów określonych przez użytkownika, czy w lewym górnym rogu obszaru wydruku strony.

PrintController

Pobiera lub ustawia kontroler wydruku, który prowadzi proces drukowania.

PrinterSettings

Pobiera lub ustawia drukarkę, która drukuje dokument.

Site

Pobiera lub ustawia ISite element .Component

(Odziedziczone po Component)

Metody

CreateObjRef(Type)

Tworzy obiekt zawierający wszystkie istotne informacje wymagane do wygenerowania serwera proxy używanego do komunikowania się z obiektem zdalnym.

(Odziedziczone po MarshalByRefObject)
Dispose()

Zwalnia wszelkie zasoby używane przez element Component.

(Odziedziczone po Component)
Dispose(Boolean)

Zwalnia zasoby niezarządzane używane przez element Component i opcjonalnie zwalnia zasoby zarządzane.

(Odziedziczone po Component)
Equals(Object)

Określa, czy dany obiekt jest taki sam, jak bieżący obiekt.

(Odziedziczone po Object)
GetHashCode()

Służy jako domyślna funkcja skrótu.

(Odziedziczone po Object)
GetLifetimeService()
Przestarzałe.

Pobiera bieżący obiekt usługi okresu istnienia, który kontroluje zasady okresu istnienia dla tego wystąpienia.

(Odziedziczone po MarshalByRefObject)
GetService(Type)

Zwraca obiekt reprezentujący usługę dostarczaną przez Component obiekt lub przez obiekt Container.

(Odziedziczone po Component)
GetType()

Type Pobiera bieżące wystąpienie.

(Odziedziczone po Object)
InitializeLifetimeService()
Przestarzałe.

Uzyskuje obiekt usługi okresu istnienia, aby kontrolować zasady okresu istnienia dla tego wystąpienia.

(Odziedziczone po MarshalByRefObject)
MemberwiseClone()

Tworzy płytkią kopię bieżącego Objectelementu .

(Odziedziczone po Object)
MemberwiseClone(Boolean)

Tworzy płytkią kopię bieżącego MarshalByRefObject obiektu.

(Odziedziczone po MarshalByRefObject)
OnBeginPrint(PrintEventArgs)

BeginPrint Zgłasza zdarzenie. Jest wywoływana po wywołaniu Print() metody i przed wyświetleniem pierwszej strony dokumentu.

OnEndPrint(PrintEventArgs)

EndPrint Zgłasza zdarzenie. Jest wywoływana po wydrukowaniu ostatniej strony dokumentu.

OnPrintPage(PrintPageEventArgs)

PrintPage Zgłasza zdarzenie. Jest wywoływana przed wydrukowaniem strony.

OnQueryPageSettings(QueryPageSettingsEventArgs)

QueryPageSettings Zgłasza zdarzenie. Jest wywoływana bezpośrednio przed każdym PrintPage zdarzeniem.

Print()

Uruchamia proces drukowania dokumentu.

ToString()

Zawiera informacje o dokumencie wydruku w postaci ciągu.

Zdarzenia

BeginPrint

Występuje, gdy Print() metoda jest wywoływana i przed wyświetleniem pierwszej strony dokumentu.

Disposed

Występuje, gdy składnik jest usuwany przez wywołanie Dispose() metody .

(Odziedziczone po Component)
EndPrint

Występuje po wydrukowaniu ostatniej strony dokumentu.

PrintPage

Występuje, gdy dane wyjściowe do wydrukowania bieżącej strony są potrzebne.

QueryPageSettings

Występuje bezpośrednio przed każdym PrintPage zdarzeniem.

Dotyczy

Produkt Wersje
.NET Framework 1.1, 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
Windows Desktop 3.0, 3.1, 5, 6, 7, 8, 9

Zobacz też