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),这些值指示哪些上述技术可用于特定打印机。 许多打印机支持其中一种以上技术。
作为 的 属性PrintTicket的值TrueTypeFontMode,该值指示打印机以特定方式处理 TrueType 字体。
未知值永远不会在 对象的属性PrintCapabilities中使用。
切勿将 PrintTicket 属性设置为 Unknown。 如果其他 PrintTicket 某个生成应用程序创建了一个 PrintTicket 文档 ,该文档将 TrueType 字体处理功能设置为无法识别的选项 (即 打印架构中未定义的选项,则 PrintTicket 应用程序中使用该文档构造的对象将具有 未知 作为 属性的值 TrueTypeFontMode 。
PrintTicket尽管 无法继承 和 PrintCapabilities 类,但可以扩展打印架构,以识别 在 或 PrintCapabilities 类中PrintTicket未考虑的打印设备功能。 有关详细信息,请参阅 如何:扩展打印架构和创建新的打印系统类。