GetCharABCWidthsFloatW

GetCharABCWidthsFloat 関数は、現在のフォントから指定範囲の連続する文字の幅(論理単位)を取得する。(Unicode)

GetCharABCWidthsFloatW hdc, iFirst, iLast, lpABC

hdc : [intptr] デバイスコンテキストのハンドル。
iFirst : [int] ABC 幅を取得する連続文字群の最初の文字のコードポイントを指定する。
iLast : [int] ABC 幅を取得する連続文字群の最後の文字のコードポイントを指定する。この範囲は両端を含む。最後の文字が最初の文字より前にある場合はエラーが返される。
lpABC : [var] 文字幅(論理単位)を受け取る ABCFLOAT 構造体の配列へのポインタ。

(プラグイン / モジュール : gdi32.dll)

解説

GetCharABCWidthsFloat 関数は、現在のフォントから指定範囲の連続する文字の幅(論理単位)を取得する。(Unicode)

[戻り値]
関数が成功した場合、戻り値は 0 以外である。失敗した場合は 0 である。

[備考]
TrueType フォントに対してのみ幅を返す GetCharABCWidths 関数と異なり、GetCharABCWidthsFloat
関数は任意のフォントの幅を取得する。返される幅は IEEE
浮動小数点形式である。現在のワールドからデバイスへの変換が恒等でない場合、返される幅はデバイス空間で整数でも非整数値となり得る。A
スペースはグリフを配置する前に現在位置に加える距離である。B スペースはグリフの黒い部分の幅である。C
スペースはグリフの右側に空白を設けるために現在位置に加える距離である。総前進幅は A+B+C で指定される。ABC
スペースは選択されたフォントの文字ベースラインに沿って測定される。現在選択されているフォントの範囲外の文字にはデフォルト文字の ABC
幅が使用される。
> [!NOTE] > wingdi.h ヘッダは GetCharABCWidthsFloat
をエイリアスとして定義しており、UNICODE プリプロセッサ定数の有無に応じてこの関数の ANSI 版または Unicode
版が自動的に選択される。エンコーディング中立なエイリアスと非中立コードを混在させると、コンパイルまたは実行時エラーの原因となる不整合を引き起こすことがある。詳細は
[関数プロトタイプの規則](/windows/win32/intl/conventions-for-function-prototypes)
を参照。

情報

プラグイン / モジュールgdi32.dll
バージョン1.0
作成日2026/04/16
著作者IronHSP / CsWin32 bridge
URLhttps://github.com/inovia/IronHSP
備考Win32 API の gdi32.dll 関数群。CsWin32 + win32metadata から自動生成。
hsp3net 専用 (intptr / NSTRUCT / wstr を使用)。
タイプ拡張命令
グループWin32API
対応環境
  • Windows 版 HSP
hs ファイルhsphelp\win32_gdi32_gen2.hs