다음을 통해 공유


Collation 열거형

정의

여러 페이지 인쇄 작업의 여러 복사본을 인쇄할 때 프린터에서 출력을 정렬할지 여부를 지정합니다.

public enum class Collation
public enum Collation
type Collation = 
Public Enum Collation
상속
Collation

필드

Name Description
Unknown 0

이 열거형으로 표시되는 옵션인 기능은 인쇄 스키마에 정의되지 않은 옵션으로 설정됩니다.

Collated 1

데이터 정렬된 출력입니다.

Uncollated 2

데이터 정렬되지 않은 출력입니다.

예제

다음 예제에서는 프린터의 기능을 테스트하고 이를 활용하도록 인쇄 작업을 구성하는 방법을 보여 있습니다. .

// ---------------------- GetPrintTicketFromPrinter -----------------------
/// <summary>
///   Returns a PrintTicket based on the current default printer.</summary>
/// <returns>
///   A PrintTicket for the current local default printer.</returns>
PrintTicket^ GetPrintTicketFromPrinter ()
{
   PrintQueue^ printQueue = nullptr;

   LocalPrintServer^ localPrintServer = gcnew LocalPrintServer();

   // Retrieving collection of local printer on user machine
   PrintQueueCollection^ localPrinterCollection = localPrintServer->GetPrintQueues();

   System::Collections::IEnumerator^ localPrinterEnumerator = localPrinterCollection->GetEnumerator();

   if (localPrinterEnumerator->MoveNext())
   {
      // Get PrintQueue from first available printer
      printQueue = ((PrintQueue^)localPrinterEnumerator->Current);
   } else
   {
      return nullptr;
   }
   // Get default PrintTicket from printer
   PrintTicket^ printTicket = printQueue->DefaultPrintTicket;

   PrintCapabilities^ printCapabilities = printQueue->GetPrintCapabilities();

   // Modify PrintTicket
   if (printCapabilities->CollationCapability->Contains(Collation::Collated))
   {
      printTicket->Collation = Collation::Collated;
   }
   if (printCapabilities->DuplexingCapability->Contains(Duplexing::TwoSidedLongEdge))
   {
      printTicket->Duplexing = Duplexing::TwoSidedLongEdge;
   }
   if (printCapabilities->StaplingCapability->Contains(Stapling::StapleDualLeft))
   {
      printTicket->Stapling = Stapling::StapleDualLeft;
   }
   return printTicket;
};// end:GetPrintTicketFromPrinter()
// ---------------------- GetPrintTicketFromPrinter -----------------------
/// <summary>
///   Returns a PrintTicket based on the current default printer.</summary>
/// <returns>
///   A PrintTicket for the current local default printer.</returns>
private PrintTicket GetPrintTicketFromPrinter()
{
    PrintQueue printQueue = null;

    LocalPrintServer localPrintServer = new LocalPrintServer();

    // Retrieving collection of local printer on user machine
    PrintQueueCollection localPrinterCollection =
        localPrintServer.GetPrintQueues();

    System.Collections.IEnumerator localPrinterEnumerator =
        localPrinterCollection.GetEnumerator();

    if (localPrinterEnumerator.MoveNext())
    {
        // Get PrintQueue from first available printer
        printQueue = (PrintQueue)localPrinterEnumerator.Current;
    }
    else
    {
        // No printer exist, return null PrintTicket
        return null;
    }

    // Get default PrintTicket from printer
    PrintTicket printTicket = printQueue.DefaultPrintTicket;

    PrintCapabilities printCapabilities = printQueue.GetPrintCapabilities();

    // Modify PrintTicket
    if (printCapabilities.CollationCapability.Contains(Collation.Collated))
    {
        printTicket.Collation = Collation.Collated;
    }

    if ( printCapabilities.DuplexingCapability.Contains(
            Duplexing.TwoSidedLongEdge) )
    {
        printTicket.Duplexing = Duplexing.TwoSidedLongEdge;
    }

    if (printCapabilities.StaplingCapability.Contains(Stapling.StapleDualLeft))
    {
        printTicket.Stapling = Stapling.StapleDualLeft;
    }

    return printTicket;
}// end:GetPrintTicketFromPrinter()
' ---------------------- GetPrintTicketFromPrinter -----------------------
''' <summary>
'''   Returns a PrintTicket based on the current default printer.</summary>
''' <returns>
'''   A PrintTicket for the current local default printer.</returns>
Private Function GetPrintTicketFromPrinter() As PrintTicket
    Dim printQueue As PrintQueue = Nothing

    Dim localPrintServer As New LocalPrintServer()

    ' Retrieving collection of local printer on user machine
    Dim localPrinterCollection As PrintQueueCollection = localPrintServer.GetPrintQueues()

    Dim localPrinterEnumerator As System.Collections.IEnumerator = localPrinterCollection.GetEnumerator()

    If localPrinterEnumerator.MoveNext() Then
        ' Get PrintQueue from first available printer
        printQueue = CType(localPrinterEnumerator.Current, PrintQueue)
    Else
        ' No printer exist, return null PrintTicket
        Return Nothing
    End If

    ' Get default PrintTicket from printer
    Dim printTicket As PrintTicket = printQueue.DefaultPrintTicket

    Dim printCapabilities As PrintCapabilities = printQueue.GetPrintCapabilities()

    ' Modify PrintTicket
    If printCapabilities.CollationCapability.Contains(Collation.Collated) Then
        printTicket.Collation = Collation.Collated
    End If

    If printCapabilities.DuplexingCapability.Contains(Duplexing.TwoSidedLongEdge) Then
        printTicket.Duplexing = Duplexing.TwoSidedLongEdge
    End If

    If printCapabilities.StaplingCapability.Contains(Stapling.StapleDualLeft) Then
        printTicket.Stapling = Stapling.StapleDualLeft
    End If

    Return printTicket
End Function ' end:GetPrintTicketFromPrinter()

설명

표준 프린터는 일반적으로 첫 번째 복사본의 모든 페이지, 두 번째 복사본의 모든 페이지 등을 인쇄하여 출력을 정렬합니다. 표준 프린터가 정렬되지 않으면 첫 번째 페이지의 모든 복사본, 두 번째 페이지의 모든 복사본 등을 인쇄합니다.

일부 프린터에는 정렬 쓰레기통이 특별히 장착되어 있습니다. 이러한 특수 장착 프린터의 인쇄 시퀀스는 표준 프린터와 다를 수 있습니다. 그러나 결과는 동일합니다. 다중 페이지 인쇄 작업의 각 복사본에는 수동 정렬 없이 적절한 순서로 모든 페이지가 포함됩니다.

주로 다음 용도로 이 형식의 값을 사용합니다.

  • 속성인 컬렉션의 CollationCapability 멤버로서 PrintCapabilities이러한 값은 프린터에서 지원하는 출력 유형을 나타냅니다. (대부분의 프린터는 두 가지 유형을 모두 지원합니다.)

  • 값은 속성 값 CollationPrintTicket으로 프린터에 데이터 정렬 여부를 지시합니다.

알 수 없는 값은 개체의 PrintCapabilities 속성에 사용되지 않습니다.

속성을 알 수 없음으로 PrintTicket 설정해서는 안 됩니다. 일부 다른 PrintTicket 생성 애플리케이션에서 데이터 정렬 기능을 인식할 수 없는 데이터 정렬 옵션 PrintTicket 으로 설정하는 PrintTicket 문서를 만든 경우 해당 문서로 생성된 애플리케이션의 Collation 개체에 알 수 없음이 속성 값으로 포함됩니다.

PrintTicket 클래스와 PrintCapabilities 클래스를 상속할 수는 없지만 인쇄 스키마를 확장하여 또는 PrintCapabilities 클래스에서 PrintTicket 고려되지 않는 인쇄 장치 기능을 인식할 수 있습니다. 자세한 내용은 방법: 인쇄 스키마 확장 및 새 인쇄 시스템 클래스 만들기를 참조하세요.

적용 대상

추가 정보