PrintQueue.AddJob Metod

Definition

Infogar ett nytt utskriftsjobb i kön.

Överlagringar

Name Description
AddJob(String, String, Boolean, PrintTicket)

Infogar ett nytt utskriftsjobb för ett XPS-dokument (XML Paper Specification) i kön, ger det det angivna namnet och inställningarna och anger om det ska verifieras eller inte.

AddJob(String, PrintTicket)

Infogar ett nytt utskriftsjobb för ett XPS-dokument (XML Paper Specification) i kön och ger det det angivna namnet och inställningarna.

AddJob(String, String, Boolean)

Infogar ett nytt utskriftsjobb för ett XPS-dokument (XML Paper Specification) i kön, ger det det angivna namnet och anger om det ska verifieras eller inte.

AddJob()

Infogar ett nytt (allmänt namngivet) utskriftsjobb, vars innehåll är en Byte matris, i kön.

AddJob(String)

Infogar ett nytt utskriftsjobb, vars innehåll är en Byte matris, i kön.

Kommentarer

Om inte kön är pausad eller i ett feltillstånd skrivs jobbet ut när det når toppen av kön, så det här är en utskriftsfunktion.

Andra sätt att skriva ut i Windows Presentation Foundation (WPF) är metoden PrintDialog.PrintDocument, som kan användas med eller utan att öppna dialogrutan, och metoden många Write och WriteAsync i XpsDocumentWriter.

AddJob(String, String, Boolean, PrintTicket)

Infogar ett nytt utskriftsjobb för ett XPS-dokument (XML Paper Specification) i kön, ger det det angivna namnet och inställningarna och anger om det ska verifieras eller inte.

public:
 System::Printing::PrintSystemJobInfo ^ AddJob(System::String ^ jobName, System::String ^ documentPath, bool fastCopy, System::Printing::PrintTicket ^ printTicket);
public System.Printing.PrintSystemJobInfo AddJob(string jobName, string documentPath, bool fastCopy, System.Printing.PrintTicket printTicket);
member this.AddJob : string * string * bool * System.Printing.PrintTicket -> System.Printing.PrintSystemJobInfo
Public Function AddJob (jobName As String, documentPath As String, fastCopy As Boolean, printTicket As PrintTicket) As PrintSystemJobInfo

Parametrar

jobName
String

Sökvägen och namnet på dokumentet som skrivs ut.

documentPath
String

Sökvägen och namnet på dokumentet som skrivs ut.

fastCopy
Boolean

trueför att snabbt buffra utan feedback om sid-för-sida-förlopp och utan att verifiera att filen är giltig XPS; annars . false

printTicket
PrintTicket

Inställningarna för utskriftsjobbet.

Returer

En PrintSystemJobInfo som representerar utskriftsjobbet och dess status.

Kommentarer

Mer information finns i AddJob(String, String, Boolean).

Gäller för

AddJob(String, PrintTicket)

Infogar ett nytt utskriftsjobb för ett XPS-dokument (XML Paper Specification) i kön och ger det det angivna namnet och inställningarna.

public:
 System::Printing::PrintSystemJobInfo ^ AddJob(System::String ^ jobName, System::Printing::PrintTicket ^ printTicket);
public System.Printing.PrintSystemJobInfo AddJob(string jobName, System.Printing.PrintTicket printTicket);
member this.AddJob : string * System.Printing.PrintTicket -> System.Printing.PrintSystemJobInfo
Public Function AddJob (jobName As String, printTicket As PrintTicket) As PrintSystemJobInfo

Parametrar

jobName
String

Sökvägen och namnet på dokumentet som skrivs ut.

printTicket
PrintTicket

Inställningarna för utskriftsjobbet.

Returer

En PrintSystemJobInfo som representerar utskriftsjobbet och dess status.

Kommentarer

Mer information finns i AddJob(String).

Gäller för

AddJob(String, String, Boolean)

Infogar ett nytt utskriftsjobb för ett XPS-dokument (XML Paper Specification) i kön, ger det det angivna namnet och anger om det ska verifieras eller inte.

public:
 System::Printing::PrintSystemJobInfo ^ AddJob(System::String ^ jobName, System::String ^ documentPath, bool fastCopy);
public System.Printing.PrintSystemJobInfo AddJob(string jobName, string documentPath, bool fastCopy);
member this.AddJob : string * string * bool -> System.Printing.PrintSystemJobInfo
Public Function AddJob (jobName As String, documentPath As String, fastCopy As Boolean) As PrintSystemJobInfo

Parametrar

jobName
String

Namnet på utskriftsjobbet.

documentPath
String

Sökvägen och namnet på dokumentet som skrivs ut.

fastCopy
Boolean

trueför att snabbt buffra utan feedback om sid-för-sida-förlopp och utan att verifiera att filen är giltig XPS; annars . false

Returer

En PrintSystemJobInfo som representerar utskriftsjobbet och dess status.

Exempel

I följande exempel visas hur du använder AddJob(String, String, Boolean) för att batchutskrift av alla XPS-filer (XML Paper Specification) i en katalog.

class Program
{
    [System.MTAThreadAttribute()] // Added for clarity, but this line is redundant because MTA is the default.
    static void Main(string[] args)
    {
        // Create the secondary thread and pass the printing method for 
        // the constructor's ThreadStart delegate parameter. The BatchXPSPrinter
        // class is defined below.
        Thread printingThread = new Thread(BatchXPSPrinter.PrintXPS);

        // Set the thread that will use PrintQueue.AddJob to single threading.
        printingThread.SetApartmentState(ApartmentState.STA);

        // Start the printing thread. The method passed to the Thread 
        // constructor will execute.
        printingThread.Start();
    }
}

public class BatchXPSPrinter
{
    public static void PrintXPS()
    {
        // Create print server and print queue.
        LocalPrintServer localPrintServer = new LocalPrintServer();
        PrintQueue defaultPrintQueue = LocalPrintServer.GetDefaultPrintQueue();

        // Prompt user to identify the directory, and then create the directory object.
        Console.Write("Enter the directory containing the XPS files: ");
        String directoryPath = Console.ReadLine();
        DirectoryInfo dir = new DirectoryInfo(directoryPath);

        // If the user mistyped, end the thread and return to the Main thread.
        if (!dir.Exists)
        {
            Console.WriteLine("There is no such directory.");
        }
        else
        {
            // If there are no XPS files in the directory, end the thread 
            // and return to the Main thread.
            if (dir.GetFiles("*.xps").Length == 0)
            {
                Console.WriteLine("There are no XPS files in the directory.");
            }
            else
            {
                Console.WriteLine("\nJobs will now be added to the print queue.");
                Console.WriteLine("If the queue is not paused and the printer is working, jobs will begin printing.");

                // Batch process all XPS files in the directory.
                foreach (FileInfo f in dir.GetFiles("*.xps"))
                {
                    String nextFile = directoryPath + "\\" + f.Name;
                    Console.WriteLine("Adding {0} to queue.", nextFile);

                    try
                    {
                        // Print the Xps file while providing XPS validation and progress notifications.
                        PrintSystemJobInfo xpsPrintJob = defaultPrintQueue.AddJob(f.Name, nextFile, false);
                    }
                    catch (PrintJobException e)
                    {
                        Console.WriteLine("\n\t{0} could not be added to the print queue.", f.Name);
                        if (e.InnerException.Message == "File contains corrupted data.")
                        {
                            Console.WriteLine("\tIt is not a valid XPS file. Use the isXPS Conformance Tool to debug it.");
                        }
                        Console.WriteLine("\tContinuing with next XPS file.\n");
                    }
                }
            }
        }

        Console.WriteLine("Press Enter to end program.");
        Console.ReadLine();
    }
}
Friend Class Program
    <System.MTAThreadAttribute()>
    Shared Sub Main(ByVal args() As String) ' Added for clarity, but this line is redundant because MTA is the default.
        ' Create the secondary thread and pass the printing method for 
        ' the constructor's ThreadStart delegate parameter. The BatchXPSPrinter
        ' class is defined below.
        Dim printingThread As New Thread(AddressOf BatchXPSPrinter.PrintXPS)

        ' Set the thread that will use PrintQueue.AddJob to single threading.
        printingThread.SetApartmentState(ApartmentState.STA)

        ' Start the printing thread. The method passed to the Thread 
        ' constructor will execute.
        printingThread.Start()

    End Sub

End Class

Public Class BatchXPSPrinter
    Public Shared Sub PrintXPS()
        ' Create print server and print queue.
        Dim localPrintServer As New LocalPrintServer()
        Dim defaultPrintQueue As PrintQueue = LocalPrintServer.GetDefaultPrintQueue()

        ' Prompt user to identify the directory, and then create the directory object.
        Console.Write("Enter the directory containing the XPS files: ")
        Dim directoryPath As String = Console.ReadLine()
        Dim dir As New DirectoryInfo(directoryPath)

        ' If the user mistyped, end the thread and return to the Main thread.
        If Not dir.Exists Then
            Console.WriteLine("There is no such directory.")
        Else
            ' If there are no XPS files in the directory, end the thread 
            ' and return to the Main thread.
            If dir.GetFiles("*.xps").Length = 0 Then
                Console.WriteLine("There are no XPS files in the directory.")
            Else
                Console.WriteLine(vbLf & "Jobs will now be added to the print queue.")
                Console.WriteLine("If the queue is not paused and the printer is working, jobs will begin printing.")

                ' Batch process all XPS files in the directory.
                For Each f As FileInfo In dir.GetFiles("*.xps")
                    Dim nextFile As String = directoryPath & "\" & f.Name
                    Console.WriteLine("Adding {0} to queue.", nextFile)

                    Try
                        ' Print the Xps file while providing XPS validation and progress notifications.
                        Dim xpsPrintJob As PrintSystemJobInfo = defaultPrintQueue.AddJob(f.Name, nextFile, False)
                    Catch e As PrintJobException
                        Console.WriteLine(vbLf & vbTab & "{0} could not be added to the print queue.", f.Name)
                        If e.InnerException.Message = "File contains corrupted data." Then
                            Console.WriteLine(vbTab & "It is not a valid XPS file. Use the isXPS Conformance Tool to debug it.")
                        End If
                        Console.WriteLine(vbTab & "Continuing with next XPS file." & vbLf)
                    End Try

                Next f ' end for each XPS file

            End If 'end if there are no XPS files in the directory

        End If 'end if the directory does not exist

        Console.WriteLine("Press Enter to end program.")
        Console.ReadLine()

    End Sub

End Class

Kommentarer

Om fastCopy är truemåste skrivaren vara en utskriftsöversikt. Om det inte AddJob(String, String, Boolean) är det utlöser metoden ett undantag.

Om fastCopy är false, är det inte nödvändigt att använda en XPSDrv-skrivare. XPS-filen som läggs till i kön konverteras till skrivarens sidbeskrivningsspråk, till exempel PCL eller Postscript. Men den här typen av utskrift gör ett anrop till Komponentobjektmodell (COM). Anropet till COM kräver att den anropande tråden har en entrådad lägenhet (STA) i stället för flertrådad lägenhet (MTA), vilket är standardvärdet. Det finns två sätt att göra detta:

  • Det enklaste sättet är att lägga till STAThreadAttribute (det vill: "[System.STAThreadAttribute()]") precis ovanför den första raden i programmets Main metod (vanligtvis "static void Main(string[] args)").

  • Om du behöver trådens Main lägenhetstillstånd för att vara MTA, kan du inhysa samtalet till AddJob(String, String, Boolean) i en separat tråd vars lägenhetstillstånd är inställt på STA med SetApartmentState. Exemplet nedan illustrerar den här andra tekniken.

Note

Du kan inte tillämpa på STAThreadAttribute någon annan metod än Main och du kan inte använda SetApartmentState för tråden Main .

Andra sätt att skriva ut i Windows Presentation Foundation (WPF) är metoden PrintDialog.PrintDocument, som kan användas med eller utan att öppna dialogrutan, och metoden många Write och WriteAsync i XpsDocumentWriter.

Se även

Gäller för

AddJob()

Infogar ett nytt (allmänt namngivet) utskriftsjobb, vars innehåll är en Byte matris, i kön.

public:
 System::Printing::PrintSystemJobInfo ^ AddJob();
public System.Printing.PrintSystemJobInfo AddJob();
member this.AddJob : unit -> System.Printing.PrintSystemJobInfo
Public Function AddJob () As PrintSystemJobInfo

Returer

En PrintSystemJobInfo som representerar utskriftsjobbet och dess status.

Exempel

I följande exempel visas hur du använder AddJob() för att skicka en Byte matris till en utskriftskö. Den här koden fungerar bara med skrivare som kan identifiera och skriva ut oformaterad text. Vissa av dem kan inte.

// Create the printer server and print queue objects
LocalPrintServer localPrintServer = new LocalPrintServer();
PrintQueue defaultPrintQueue = LocalPrintServer.GetDefaultPrintQueue();

// Call AddJob
PrintSystemJobInfo myPrintJob = defaultPrintQueue.AddJob();

// Write a Byte buffer to the JobStream and close the stream
Stream myStream = myPrintJob.JobStream;
Byte[] myByteBuffer = UnicodeEncoding.Unicode.GetBytes("This is a test string for the print job stream.");
myStream.Write(myByteBuffer, 0, myByteBuffer.Length);
myStream.Close();
' Create the printer server and print queue objects
Dim localPrintServer As New LocalPrintServer()
Dim defaultPrintQueue As PrintQueue = LocalPrintServer.GetDefaultPrintQueue()

' Call AddJob
Dim myPrintJob As PrintSystemJobInfo = defaultPrintQueue.AddJob()

' Write a Byte buffer to the JobStream and close the stream
Dim myStream As Stream = myPrintJob.JobStream
Dim myByteBuffer() As Byte = UnicodeEncoding.Unicode.GetBytes("This is a test string for the print job stream.")
myStream.Write(myByteBuffer, 0, myByteBuffer.Length)
myStream.Close()

Kommentarer

Använd den här metoden för att skriva enhetsspecifik information till en spoolfil som inte inkluderas automatiskt av Microsoft Windows-bufferten. Du behöver naturligtvis veta om spoolfilen är ENHANCED Metafile (EMF) eller XML Paper Specification (XPS). Om du föredrar att arbeta med API:et Stream kan du använda PrintQueueStream klassen i stället för den här metoden.

AddJob När metoden har anropats måste du skriva en Byte matris till JobStream egenskapen PrintSystemJobInfo för den som returneras av AddJob eller så skapas inget utskriftsjobb. Den här matrisen skriver ut om skrivaren fungerar och inte pausas.

Caution

Om den JobStream inte är stängd med Close före slutet av tråden som AddJob anropas, genereras en InvalidOperationException när tråden slutar eftersom spooler-tråden inte kan få kontroll över Stream objektet.

I utskriftsköens grafiska användargränssnitt (GUI) har jobbet namnet "Utskriftssystemdokument". Om du vill ge jobbet ett annat namn använder du överlagringen AddJob(String) .

Andra sätt att skriva ut i Windows Presentation Foundation (WPF) är metoden PrintDialog.PrintDocument, som kan användas med eller utan att öppna dialogrutan, och metoden många Write och WriteAsync i XpsDocumentWriter.

Gäller för

AddJob(String)

Infogar ett nytt utskriftsjobb, vars innehåll är en Byte matris, i kön.

public:
 System::Printing::PrintSystemJobInfo ^ AddJob(System::String ^ jobName);
public System.Printing.PrintSystemJobInfo AddJob(string jobName);
member this.AddJob : string -> System.Printing.PrintSystemJobInfo
Public Function AddJob (jobName As String) As PrintSystemJobInfo

Parametrar

jobName
String

Namnet på utskriftsjobbet.

Returer

En PrintSystemJobInfo som representerar utskriftsjobbet och dess status.

Exempel

I följande exempel visas hur du använder AddJob(String) för att läsa en fil i en Byte matris och skicka matrisen till en utskriftskö. Den här koden förutsätter att det finns en fil som heter test.txt i roten på C:-enheten. Den här koden fungerar bara med skrivare som kan identifiera och skriva ut oformaterad text. Vissa av dem kan inte.

// Create the printer server and print queue objects
LocalPrintServer localPrintServer2 = new LocalPrintServer();
PrintQueue defaultPrintQueue2 = LocalPrintServer.GetDefaultPrintQueue();

// Call AddJob 
PrintSystemJobInfo anotherPrintJob = defaultPrintQueue2.AddJob("MyJob");

// Read a file into a StreamReader
StreamReader myStreamReader = new StreamReader("C:\\test.txt");

// Write a Byte buffer to the JobStream and close the stream
Stream anotherStream = anotherPrintJob.JobStream;
Byte[] anotherByteBuffer = UnicodeEncoding.Unicode.GetBytes(myStreamReader.ReadToEnd());
anotherStream.Write(anotherByteBuffer, 0, anotherByteBuffer.Length);
anotherStream.Close();
' Create the printer server and print queue objects
Dim localPrintServer2 As New LocalPrintServer()
Dim defaultPrintQueue2 As PrintQueue = LocalPrintServer.GetDefaultPrintQueue()

' Call AddJob 
Dim anotherPrintJob As PrintSystemJobInfo = defaultPrintQueue2.AddJob("MyJob")

' Read a file into a StreamReader
Dim myStreamReader As New StreamReader("C:\test.txt")

' Write a Byte buffer to the JobStream and close the stream
Dim anotherStream As Stream = anotherPrintJob.JobStream
Dim anotherByteBuffer() As Byte = UnicodeEncoding.Unicode.GetBytes(myStreamReader.ReadToEnd())
anotherStream.Write(anotherByteBuffer, 0, anotherByteBuffer.Length)
anotherStream.Close()

Kommentarer

Använd den här metoden för att skriva enhetsspecifik information till en spoolfil som inte inkluderas automatiskt av Microsoft Windows-bufferten. Du behöver naturligtvis veta om spoolfilen är ENHANCED Metafile (EMF) eller XML Paper Specification (XPS). Om du föredrar att arbeta med API:et Stream kan du använda PrintQueueStream klassen i stället för den här metoden.

AddJob När metoden har anropats måste du skriva en Byte matris till JobStream egenskapen PrintSystemJobInfo för den som returneras av AddJob eller så skapas inget utskriftsjobb. Den här matrisen skriver ut om skrivaren fungerar och inte pausas.

Caution

Om den JobStream inte är stängd med Close före slutet av tråden som AddJob anropas, genereras en InvalidOperationException när tråden slutar eftersom spooler-tråden inte kan få kontroll över Stream objektet.

Andra sätt att skriva ut i Windows Presentation Foundation (WPF) är metoden PrintDialog.PrintDocument, som kan användas med eller utan att öppna dialogrutan, och metoden många Write och WriteAsync i XpsDocumentWriter.

Gäller för