TrueTypeFontMode 列舉
定義
重要
部分資訊涉及發行前產品,在發行之前可能會有大幅修改。 Microsoft 對此處提供的資訊,不做任何明確或隱含的瑕疵擔保。
指定印表機如何處理格式化為 TrueType 字型的文字。
public enum class TrueTypeFontMode
public enum TrueTypeFontMode
type TrueTypeFontMode =
Public Enum TrueTypeFontMode
- 繼承
欄位
Automatic | 1 | 印表機驅動程式將決定處理 TrueType 字型的最佳方式。 |
DownloadAsNativeTrueTypeFont | 4 | 印表機驅動程式會下載 TrueType 字型。 |
DownloadAsOutlineFont | 2 | 印表機驅動程式會將 TrueType 字型下載為描邊字。 |
DownloadAsRasterFont | 3 | 印表機驅動程式會為其所需要的各種 TrueType 字型大小建立點陣字型,並將它們全部下載。 |
RenderAsBitmap | 5 | 印表機驅動程式會將每個文字區域下載為圖形。 |
Unknown | 0 | 功能 (其選項由這個列舉表示) 會設定為未定義的選項。 列印結構描述 \(英文\) 中未定義的選項。 |
範例
下列範例示範如何測試印表機的功能,並設定列印作業以利用它們。
// ---------------------- 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()
備註
TrueType 字型是 向量 字型,指示列印機驅動程式和螢幕驅動程式如何繪製字母的圖形並填入。 向量字型與 點陣 字型對比,這隻是清單。 點陣字型針對每個可用字型大小的每個字母都有清單,而清單會針對字母中的每個像素決定是否列印。
您可以將向量字型放大或縮減為幾乎任何點大小;不過,向量字型可能會變慢列印,因為它們佔用大量的印表機記憶體。 此外,某些印表機不支援 TrueType 字型。
較新的印表機通常會執行下列動作來避免這些問題。
將 TrueType 字型轉換成大綱字型,這是泛型向量字型。 許多不支援 TrueType 字型的印表機都支援大綱字型。
建立看起來像 TrueType 字型的暫存點陣字型。 印表機必須為每個檔使用的字型大小建立個別的暫存點陣字型。 因此,如果列印作業使用許多字型大小,印表機使用的記憶體總計可能會大於 TrueType 字型所使用的總記憶體。
將檔中的每個文字區域視為圖形。 如果裝置需要列印包含非常少文字的檔,下載文字做為圖形可能會使用比下載字型少的印表機記憶體。
針對下列用途,請使用此類型的值:
做為 集合的成員 TrueTypeFontModeCapability ,這是的 PrintCapabilities屬性,這些值表示特定印表機可使用哪些上述技術。 許多印表機都支援其中一種以上的技術。
做為 TrueTypeFontMode 的 PrintTicket屬性值,值會指示印表機以特定方式處理 TrueType 字型。
未知的值永遠不會用在 對象的屬性PrintCapabilities中。
您不應該將 PrintTicket 屬性設定為 Unknown。 如果有些其他 PrintTicket 產生應用程式已建立 PrintTicket 檔 ,將 TrueType 字型處理功能設定為無法辨識的選項 (也就是說,在 列印架構中未定義的選項,則 PrintTicket 以該檔建構的應用程式中的物件將會有 Unknown 做為 屬性的值 TrueTypeFontMode 。
PrintTicket雖然 無法繼承 和 PrintCapabilities 類別,但您可以擴充列印架構,以辨識未在 或 PrintCapabilities 類別中考慮的PrintTicket列印裝置功能。 如需詳細資訊,請參閱 如何:擴充列印架構和建立新的列印系統類別。