GetCharABCWidthsA-Funktion (wingdi.h)
Die GetCharABCWidths--Funktion ruft die Breite in logischen Einheiten von aufeinander folgenden Zeichen in einem angegebenen Bereich von der aktuellen TrueType-Schriftart ab. Diese Funktion ist nur mit TrueType-Schriftarten erfolgreich.
Syntax
BOOL GetCharABCWidthsA(
[in] HDC hdc,
[in] UINT wFirst,
[in] UINT wLast,
[out] LPABC lpABC
);
Parameter
[in] hdc
Ein Handle für den Gerätekontext.
[in] wFirst
Das erste Zeichen in der Gruppe aufeinander folgender Zeichen aus der aktuellen Schriftart.
[in] wLast
Das letzte Zeichen in der Gruppe aufeinander folgender Zeichen aus der aktuellen Schriftart.
[out] lpABC
Ein Zeiger auf ein Array von ABC Strukturen, die die Zeichenbreiten in logischen Einheiten empfangen. Dieses Array muss mindestens so viele ABC- Strukturen enthalten, wie es Zeichen im Bereich gibt, der durch die parameter uFirstChar und uLastChar- angegeben wird.
Rückgabewert
Wenn die Funktion erfolgreich ist, ist der Rückgabewert ungleich Null
Wenn die Funktion fehlschlägt, ist der Rückgabewert null.
Bemerkungen
Der TrueType-Rasterizer stellt ABC-Zeichenabstand bereit, nachdem eine bestimmte Punktgröße ausgewählt wurde. Ein Abstand ist der Abstand, der der aktuellen Position hinzugefügt wird, bevor die Glyphe platziert wird. B-Abstand ist die Breite des schwarzen Teils der Glyphe. C-Abstand ist der Abstand, der der aktuellen Position hinzugefügt wird, um Leerraum rechts neben der Glyphe bereitzustellen. Die erweiterte Gesamtbreite wird durch A+B+C angegeben.
Wenn die GetCharABCWidths Funktion negative A- oder C-Breiten für ein Zeichen abruft, enthält dieses Zeichen Unterhänge oder Überhänge.
Um die ABC-Breite in Schriftartenentwurfseinheiten zu konvertieren, sollte eine Anwendung den wert verwenden, der im otmEMSquare Member einer OUTLINETEXTMETRIC- Struktur gespeichert ist. Dieser Wert kann abgerufen werden, indem die GetOutlineTextMetrics--Funktion aufgerufen wird.
Die ABC-Breite des Standardzeichens wird für Zeichen außerhalb des Bereichs der aktuell ausgewählten Schriftart verwendet.
Um die Zeichenbreiten in Nicht-TrueType-Schriftarten abzurufen, sollten Anwendungen die GetCharWidth--Funktion verwenden.
Anmerkung
The wingdi.h header defines GetCharABCWidths as an alias that automatically selects the ANSI or Unicode version of this function based on the definition of the UNICODE preprocessor constant. Das Mischen der Verwendung des codierungsneutralen Alias mit Code, der nicht codierungsneutral ist, kann zu Nichtübereinstimmungen führen, die zu Kompilierungs- oder Laufzeitfehlern führen. Weitere Informationen finden Sie unter Konventionen für Funktionsprototypen.
Anforderungen
Anforderung | Wert |
---|---|
mindestens unterstützte Client- | Windows 2000 Professional [nur Desktop-Apps] |
mindestens unterstützte Server- | Windows 2000 Server [nur Desktop-Apps] |
Zielplattform- | Fenster |
Header- | wingdi.h (enthalten Windows.h) |
Library | Gdi32.lib |
DLL- | Gdi32.dll |
Siehe auch
Schriftart- und Textfunktionen