情報: 太字と斜体のテキストのテキストのエクステントを計算します。

文書翻訳 文書翻訳
文書番号: 74298 - 対象製品
この資料は、アーカイブされました。これは "現状のまま" で提供され、更新されることはありません。
すべて展開する | すべて折りたたむ

概要

GetTextExtent() は、文字列の範囲の計算に使用できます。 返さ、調整が必要、フォントのスタイルによって異なります。 斜体または太字のフォントが要求され、[なし] には、グラフィックス デバイス インターフェイス (GDI) 既存ラスターまたはベクター フォントを使用してそれらのスタイルをシミュレートする可能性があります。

詳細

GDI でシミュレートされた太字や斜体フォント両方は overhangs を含めます。 張り出しは、 GetTextMetrics 関数の呼び出しで取得した TEXTMETRIC 構造体で指定します。 次に適切な行の斜体または太字のテキストの範囲を計算の方法を示します:
   dwExtent = GetTextExtent(hDC, lpString, nCount);
   GetTextMetrics(hDC, &tm);
   xExtent = LOWORD(dwExtent) - tm.tmOverhang;
				
斜体テキストの配置の例は、下に表示されます。 次の文字を斜体できない場合は、張り出しいない GetTextExtent 関数から返されたアドバンス幅から減算する必要があります。 張り出し必要がある同じスタイルの文字の配置を次の場合にのみを減算することがあります。
                                        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、テキストの出力を 2 回、1 ピクセルずつ、2 番目の出力をオフセット 1 ピクセルずつ各文字の幅を効果的に増やすことで太字のフォントを synthesizes ための張り出し GDI で合成太字の文字は 1 です。 太字のテキストのアドバンス幅の計算は、斜体のテキストの方法に似ています。 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 SDK 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 kbinfo kbmt KB74298 KbMtja
機械翻訳の免責
重要: このサポート技術情報 (以下「KB」) は、翻訳者による翻訳の代わりに、マイクロソフト機械翻訳システムによって翻訳されたものです。マイクロソフトは、お客様に、マイクロソフトが提供している全ての KB を日本語でご利用いただけるように、翻訳者による翻訳 KB に加え機械翻訳 KB も提供しています。しかしながら、機械翻訳の品質は翻訳者による翻訳ほど十分ではありません。誤訳や、文法、言葉使い、その他、たとえば日本語を母国語としない方が日本語を話すときに間違えるようなミスを含んでいる可能性があります。マイクロソフトは、機械翻訳の品質、及び KB の内容の誤訳やお客様が KB を利用されたことによって生じた直接または間接的な問題や損害については、いかなる責任も負わないものとします。マイクロソフトは、機械翻訳システムの改善を継続的に行っています。
英語版 KB:74298
Microsoft Knowledge Base の免責: Microsoft Knowledge Baseに含まれている情報は、いかなる保証もない現状ベースで提供されるものです。Microsoft Corporation及びその関連会社は、市場性および特定の目的への適合性を含めて、明示的にも黙示的にも、一切の保証をいたしません。さらに、Microsoft Corporation及びその関連会社は、本文書に含まれている情報の使用及び使用結果につき、正確性、真実性等、いかなる表明・保証も行ないません。Microsoft Corporation、その関連会社及びこれらの権限ある代理人による口頭または書面による一切の情報提供またはアドバイスは、保証を意味するものではなく、かつ上記免責条項の範囲を狭めるものではありません。Microsoft Corporation、その関連会社 及びこれらの者の供給者は、直接的、間接的、偶発的、結果的損害、逸失利益、懲罰的損害、または特別損害を含む全ての損害に対して、状況のいかんを問わず一切責任を負いません。(Microsoft Corporation、その関連会社 またはこれらの者の供給者がかかる損害の発生可能性を了知している場合を含みます。) 結果的損害または偶発的損害に対する責任の免除または制限を認めていない地域においては、上記制限が適用されない場合があります。なお、本文書においては、文書の体裁上の都合により製品名の表記において商標登録表示、その他の商標表示を省略している場合がありますので、予めご了解ください。

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