1. NAME▲
XTextExtents, XTextExtents16, XQueryTextExtents, XQueryTextExtents16 - compute or query text extents
2. SYNTAX ▲
int XTextExtents(XFontStruct *font_struct, char *string, int nchars, int *direction_return, int *font_ascent_return, int *font_descent_return, XCharStruct *overall_return); int XTextExtents16(XFontStruct *font_struct, XChar2b *string, int nchars, int *direction_return, int *font_ascent_return, int *font_descent_return, XCharStruct *overall_return); int XQueryTextExtents(Display *display, XID font_ID, char *string, int nchars, int *direction_return, int *font_ascent_return, int *font_descent_return, XCharStruct *overall_return); int XQueryTextExtents16(Display *display, XID font_ID, XChar2b *string, int nchars, int *direction_return, int *font_ascent_return, int *font_descent_return, XCharStruct *overall_return);
3. ARGUMENTS ▲
direction_return 1i Returns the value of the direction hint .Pn ( FontLeftToRight or .ZN FontRightToLeft ).
display 1i Specifies the connection to the X server.
font_ID 1i Specifies either the font ID or the .ZN GContext ID that contains the font.
font_ascent_return 1i Returns the font ascent.
font_descent_return 1i Returns the font descent.
font_struct 1i Specifies the .ZN XFontStruct structure.
nchars 1i Specifies the number of characters in the character string.
string 1i Specifies the character string.
overall_return 1i Returns the overall size in the specified .ZN XCharStruct structure.
4. DESCRIPTION ▲
The .ZN XTextExtents and .ZN XTextExtents16 functions perform the size computation locally and, thereby, avoid the round-trip overhead of .ZN XQueryTextExtents and .ZN XQueryTextExtents16 . Both functions return an .ZN XCharStruct structure, whose members are set to the values as follows.
The ascent member is set to the maximum of the ascent metrics of all characters in the string. The descent member is set to the maximum of the descent metrics. The width member is set to the sum of the character-width metrics of all characters in the string. For each character in the string, let W be the sum of the character-width metrics of all characters preceding it in the string. Let L be the left-side-bearing metric of the character plus W. Let R be the right-side-bearing metric of the character plus W. The lbearing member is set to the minimum L of all characters in the string. The rbearing member is set to the maximum R.
For fonts defined with linear indexing rather than 2-byte matrix indexing, each .ZN XChar2b structure is interpreted as a 16-bit number with byte1 as the most significant byte. If the font has no defined default character, undefined characters in the string are taken to have all zero metrics.
The .ZN XQueryTextExtents and .ZN XQueryTextExtents16 functions return the bounding box of the specified 8-bit and 16-bit character string in the specified font or the font contained in the specified GC. These functions query the X server and, therefore, suffer the round-trip overhead that is avoided by .ZN XTextExtents and .ZN XTextExtents16 . Both functions return a .ZN XCharStruct structure, whose members are set to the values as follows.
The ascent member is set to the maximum of the ascent metrics of all characters in the string. The descent member is set to the maximum of the descent metrics. The width member is set to the sum of the character-width metrics of all characters in the string. For each character in the string, let W be the sum of the character-width metrics of all characters preceding it in the string. Let L be the left-side-bearing metric of the character plus W. Let R be the right-side-bearing metric of the character plus W. The lbearing member is set to the minimum L of all characters in the string. The rbearing member is set to the maximum R.
For fonts defined with linear indexing rather than 2-byte matrix indexing, each .ZN XChar2b structure is interpreted as a 16-bit number with byte1 as the most significant byte. If the font has no defined default character, undefined characters in the string are taken to have all zero metrics.
Characters with all zero metrics are ignored. If the font has no defined default_char, the undefined characters in the string are also ignored.
.ZN XQueryTextExtents and .ZN XQueryTextExtents16 can generate .ZN BadFont and .ZN BadGC errors.
5. DIAGNOSTICS ▲
- .ZN BadFont
A value for a Font or GContext argument does not name a defined Font. - .ZN BadGC
A value for a GContext argument does not name a defined GContext.
6. SEE ALSO ▲
XLoadFont(3), XTextWidth(3)
\*(xL