資訊: 計算文字範圍的粗體和斜體文字

文章翻譯 文章翻譯
文章編號: 74298 - 檢視此文章適用的產品。
本文已封存。本文係以「現狀」提供且不會再更新。
全部展開 | 全部摺疊

結論

GetTextExtent() 用於計算範圍的字串。傳回值可能需要進行調整字型的樣式而定。時要求斜體或粗體的字型都可以使用圖形裝置介面 (GDI) 可能會模擬使用現有的點陣或向量字型的那些樣式。

其他相關資訊

GDI 模擬粗體和斜體字型都包括 overhangs。overhang TEXTMETRIC 結構取得藉由呼叫 GetTextMetrics 函式中指定。計算範圍的斜體或粗體文字行的適當的方法如下所示:
   dwExtent = GetTextExtent(hDC, lpString, nCount);
   GetTextMetrics(hDC, &tm);
   xExtent = LOWORD(dwExtent) - tm.tmOverhang;
				
列出下面是斜體文字的對齊方式的範例。如果下一個字元不是斜體,overhang 應該不減去從由 GetTextExtent 函式傳回的前進距離寬度。overhang 需要只當文字對齊字元的下一個具有相同樣式減去。
                                        GetTextExtent yields
                                        this as the extent:

                                              ||
       /   /                                  \/ 
      /   /           /   / /   /         /   /|   |
     /---/           /   / /   /         /   / |   |
    /   /           /---/ /---/         /---/  |---|
   /   /           /   / /   /         /   /   |   |
       -----      /   / /   /         /   /    |   |
         ^            /\                      /\ 
      Overhang        ||                      ||
               Because the next        Start the nonitalic H
               character is italic,    here because it does not
               start the next          slant and would partially
               character within the    overwrite the previous
               overhang of the         italic character.
               current character
				
GDI 合成粗體字元 overhang 通常是 1 因為 GDI synthesizes 粗體的字型以兩次輸出文字、 移轉一個像素的第二個輸出、 有效地增加一個像素的每個字元的寬度。計算的粗體文字前進距離寬度很類似斜體文字的方法。GetTextExtent 函式永遠會傳回範圍的文字加上粗體文字的 1。因此減去 tmOverhang(1),適當的前進距離被達成。
        ||   ||
        ||   ||
        ||===||
        ||   ||
        ||   ||
              ---<= This line represents the "extra" overhang of 1.
                /\ 
                ||
             GetTextExtent yields
             this as the extent of the
             bold H.
				
注意: 這篇文章僅適用於點陣和 Vectory 字型。函式永遠傳回前進距離寬度的 ABC 寬度結構所描述的 TrueType 字型的字串的 GetTextExtent() 系列。如需有關 ABC 前進距離寬度的詳細資訊,請參閱 GetCharABCWidths() 函式文件。

屬性

文章編號: 74298 - 上次校閱: 2014年2月27日 - 版次: 3.2
這篇文章中的資訊適用於:
  • Microsoft Windows Software Development Kit 3.1
  • Microsoft Win32 Application Programming Interface?應用於:
    • Microsoft Windows NT Server 3.5
    • Microsoft Windows NT Server 3.51
    • Microsoft Windows NT Server 4.0 Standard Edition
    • Microsoft Windows NT Workstation 3.5
    • Microsoft Windows NT Workstation 3.51
    • Microsoft Windows NT Workstation 4.0 Developer Edition
關鍵字:?
kbnosurvey kbarchive kbmt kbinfo KB74298 KbMtzh
機器翻譯
重要:本文是以 Microsoft 機器翻譯軟體翻譯而成,而非使用人工翻譯而成。Microsoft 同時提供使用者人工翻譯及機器翻譯兩個版本的文章,讓使用者可以依其使用語言使用知識庫中的所有文章。但是,機器翻譯的文章可能不盡完美。這些文章中也可能出現拼字、語意或文法上的錯誤,就像外國人在使用本國語言時可能發生的錯誤。Microsoft 不為內容的翻譯錯誤或客戶對該內容的使用所產生的任何錯誤或損害負責。Microsoft也同時將不斷地就機器翻譯軟體進行更新。
按一下這裡查看此文章的英文版本:74298
Microsoft及(或)其供應商不就任何在本伺服器上發表的文字資料及其相關圖表資訊的恰當性作任何承諾。所有文字資料及其相關圖表均以「現狀」供應,不負任何擔保責任。Microsoft及(或)其供應商謹此聲明,不負任何對與此資訊有關之擔保責任,包括關於適售性、適用於某一特定用途、權利或不侵權的明示或默示擔保責任。Microsoft及(或)其供應商無論如何不對因或與使用本伺服器上資訊或與資訊的實行有關而引起的契約、過失或其他侵權行為之訴訟中的特別的、間接的、衍生性的損害或任何因使用而喪失所導致的之損害、資料或利潤負任何責任。

提供意見

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com