1. NAME▲
XmbDrawText, XwcDrawText, Xutf8DrawText - draw text using multiple font sets
2. SYNTAX ▲
void XmbDrawText(Display *display, Drawable d, GC gc, int x, int y, XmbTextItem *items, int nitems); void XwcDrawText(Display *display, Drawable d, GC gc, int x, int y, XwcTextItem *items, int nitems); void Xutf8DrawText(Display *display, Drawable d, GC gc, int x, int y, XmbTextItem *items, int nitems);
3. ARGUMENTS ▲
d 1i Specifies the drawable.
display 1i Specifies the connection to the X server.
gc 1i Specifies the GC.
items 1i Specifies an array of text items.
nitems 1i Specifies the number of text items in the array.
x 1i
y 1i Specify the x and y coordinates\*(Xy.
4. DESCRIPTION ▲
The .ZN XmbDrawText , .ZN XwcDrawText and .ZN Xutf8DrawText functions allow complex spacing and font set shifts between text strings. Each text item is processed in turn, with the origin of a text element advanced in the primary draw direction by the escapement of the previous text item. A text item delta specifies an additional escapement of the text item drawing origin in the primary draw direction. A font_set member other than .ZN None in an item causes the font set to be used for this and subsequent text items in the text_items list. Leading text items with a font_set member set to .ZN None will not be drawn.
.ZN XmbDrawText , .ZN XwcDrawText and .ZN Xutf8DrawText do not perform any context-dependent rendering between text segments. Clients may compute the drawing metrics by passing each text segment to .ZN XmbTextExtents , .ZN XwcTextExtents , .ZN Xutf8TextExtents or .ZN XmbTextPerCharExtents , .ZN XwcTextPerCharExtents . .ZN Xutf8TextPerCharExtents . When the .ZN XFontSet has missing charsets, each unavailable character is drawn with the default string returned by .ZN XCreateFontSet . The behavior for an invalid codepoint is undefined.
The function .ZN Xutf8DrawText is an extension introduced by The XFree86 Project, Inc. in their 4.0.2 release. Its presence is indicated by the macro .ZN X_HAVE_UTF8_STRING .
5. STRUCTURES ▲
The .ZN XmbTextItem structure contains: .TA .5i 2.5i .5i 2.5i typedef struct { char *chars; /* pointer to string */ int nchars; /* number of bytes */ int delta; /* pixel delta between strings */ XFontSet font_set; /* fonts, None means don't change */ } XmbTextItem; .De The .ZN XwcTextItem structure contains: .TA .5i 2.5i .5i 2.5i typedef struct { wchar_t *chars; /* pointer to wide char string */ int nchars; /* number of wide characters */ int delta; /* pixel delta between strings */ XFontSet font_set; /* fonts, None means don't change */ } XwcTextItem; .De
6. SEE ALSO ▲
XDrawImageString(3), XDrawString(3), XDrawText(3), XmbDrawImageString(3), XmbDrawString(3)
\*(xL