al_get_glyph_advance man page
al_get_glyph_advance — Allegro 5 API
#include <allegro5/allegro_font.h> int al_get_glyph_advance(const ALLEGRO_FONT *f, int codepoint1, int codepoint2)
This function returns by how much the x position should be advanced for left to right text drawing when the glyph that corresponds to codepoint1 has been drawn, and the glyph that corresponds to codepoint2 will be the next to be drawn. This takes into consideration the horizontal advance width of the glyph that corresponds with codepoint1 as well as the kerning between the glyphs of codepoint1 and codepoint2.
Kerning is the process of adjusting the spacing between glyphs in a font, to obtain a more visually pleasing result. Kerning adjusts the space between two individual glyphs with an offset determined by the author of the font.
If you pass ALLEGRO_NO_KERNING as codepoint1 then al_get_glyph_advance will return 0. this cn be useful when drawing the first character of a string in a loop.
Pass ALLEGRO_NO_KERNING as codepoint2 to get the horizontal advance width of the glyph that corresponds to codepoint1 without taking any kerning into consideration. This can be used, for example, when drawing the last character of a string in a loop.
This function will return zero if the glyph of codepoint1 is not present in the
font. If the glyph of codepoint2 is not present in the font, the horizontal advance width of the glyph that corresponds to codepoint1 without taking any kerning into consideration is returned.
When drawing a string one glyph at the time from the left to the right with kerning, the x position of the glyph should be incremented by the result of al_get_glyph_advance(3) applied to the previous glyph drawn and the next glyph to draw.
Note that the return value of this function is a recommended advance for optimal readability for left to right text determined by the author of the font. However, if you like, you may want to draw the glyphs of the font narrower or wider to each other than what al_get_glyph_advance(3) returns for style or effect.
In the figure below is an example of what the result of al_get_glyph_advance may be like for two glypphs
l of the same font that has kerning for the "Al" pair, without and with the ALLEGRO_NO_KERNING flag.
al_get_glyph_advance(font, 'A', 'l', 0) ___|___ / \ ------------- /\ -| / \ | /____\ | / \ | / \ \_ ------------- al_get_glyph_advance(font, 'A', 'l', ALLEGRO_NO_KERNING) ____|____ / \ --------------- /\ -| / \ | /____\ | / \ | / \ \_ ---------------
al_draw_glyph(3), al_get_glyph_width(3), al_get_glyph_dimensions(3).
al_draw_glyph(3), al_get_glyph_dimensions(3), al_get_glyph_width(3).