Collation Sabit listesi
Tanım
Önemli
Bazı bilgiler ürünün ön sürümüyle ilgilidir ve sürüm öncesinde önemli değişiklikler yapılmış olabilir. Burada verilen bilgilerle ilgili olarak Microsoft açık veya zımni hiçbir garanti vermez.
Yazıcının, çok sayfalı yazdırma işinin birden çok kopyasını yazdırdığında çıkışı harmanlayıp harmanlamayacağını belirtir.
public enum class Collation
public enum Collation
type Collation =
Public Enum Collation
- Devralma
Alanlar
Collated | 1 | Harmanlanmış çıkış. |
Uncollated | 2 | Harmanlanmamış çıkış. |
Unknown | 0 | Özellik (seçenekleri bu numaralandırma ile temsil edilir) Yazdırma Şemasında tanımlanmayan bir seçeneğe ayarlanır. |
Örnekler
Aşağıdaki örnekte, yazıcının özelliklerini test etme ve yazdırma işini bunlardan yararlanacak şekilde yapılandırma adımları gösterilmektedir. .
// ---------------------- 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()
Açıklamalar
Standart bir yazıcı genellikle ilk kopyanın her sayfasını, ardından ikinci kopyanın her sayfasını yazdırarak çıkışı harmanlar ve bu şekilde devam eder. Standart yazıcı harmanlamadığında, ilk sayfanın her kopyasını, ardından ikinci sayfanın her kopyasını yazdırır ve bu şekilde devam eder.
Bazı yazıcılar özel olarak harmanlama bölmeleri ile donatılmıştır. Bu özel olarak donatılmış yazıcılar için baskı sırası standart yazıcılarınkinden farklı olabilir; ancak sonuç aynıdır: çok sayfalı yazdırma işinin her kopyası, el ile sıralama olmadan tüm sayfalarını düzgün sırada içerir.
Bu türün değerlerini öncelikle aşağıdaki amaçlar için kullanın.
Bu değerler, bir özelliği olan koleksiyonun CollationCapabilityPrintCapabilitiesüyeleri olarak yazıcının desteklediği çıkış türünü gösterir. (Birçok yazıcı her iki türü de destekler.)
değeri PrintTicketözelliğinin Collation değeri olarak, değeri yazıcıya harmanlama yapılıp yapılmayacağını belirler.
Bilinmeyen değeri hiçbir zaman nesnelerin özelliklerinde PrintCapabilities kullanılmaz.
Bir özelliği hiçbir zaman Bilinmiyor olarak ayarlamamalısınızPrintTicket. Başka PrintTicket bir üretici uygulama harmanlama özelliğini tanınmayan harmanlama seçeneğine ayarlayan bir PrintTicket belgesi oluşturduysa, uygulamanızda bu belgeyle oluşturulan nesnenin PrintTicket özelliğin değeri CollationBilinmeyen olur.
ve PrintCapabilities sınıfları devralınamasa daPrintTicket, veya PrintCapabilities sınıflarında hesaba bağlanmayan yazdırma cihazı özelliklerini tanımak için Yazdırma Şeması'nıPrintTicket genişletebilirsiniz. Daha fazla bilgi için bkz . Nasıl yapılır: Yazdırma Şemasını Genişletme ve Yeni Yazdırma Sistemi Sınıfları Oluşturma.