|
| Filled (const char *filename, float point_size=12, FT_UInt resolution=100) |
|
| Filled (FT_Face face, float point_size=12, FT_UInt resolution=100) |
|
virtual | ~Filled (void) |
|
VertexInfoList & | extraVertices (void) |
|
| Polygonal (const char *filename, float point_size=12, FT_UInt resolution=100) |
|
| Polygonal (FT_Face face, float point_size=12, FT_UInt resolution=100) |
|
virtual | ~Polygonal (void) |
|
void | setTessellationSteps (unsigned int tessellation_steps) |
|
unsigned int | tessellationSteps (void) const |
|
void | setCharacterRotationX (GLfloat character_rotation_x) |
|
void | setCharacterRotationY (GLfloat character_rotation_y) |
|
void | setCharacterRotationZ (GLfloat character_rotation_z) |
|
GLfloat | characterRotationX (void) const |
|
GLfloat | characterRotationY (void) const |
|
GLfloat | characterRotationZ (void) const |
|
void | setColorTess (ColorTess *color_tess) |
|
ColorTess * | colorTess (void) const |
|
void | setTextureTess (TextureTess *texture_tess) |
|
TextureTess * | textureTess (void) const |
|
double | height (void) const |
|
BBox | measure (unsigned char c) |
|
BBox | measure (const char *s) |
|
| Face (const char *filename, float point_size=12, FT_UInt resolution=100) |
|
| Face (FT_Face face, float point_size=12, FT_UInt resolution=100) |
|
virtual | ~Face (void) |
|
bool | isValid (void) const |
|
bool | addAuxiliaryFace (const char *filename) |
|
bool | addAuxiliaryFace (FT_Face face) |
|
void | setCompileMode (enum GlyphCompileMode compile_mode) |
|
enum GlyphCompileMode | compileMode (void) const |
|
void | setPointSize (float point_size) |
|
float | pointSize (void) |
|
void | setResolution (FT_UInt resolution) |
|
FT_UInt | resolution (void) |
|
void | setAdvance (bool advance) |
|
bool | advance (void) const |
|
void | setForegroundColor (GLfloat red=0.0, GLfloat green=0.0, GLfloat blue=0.0, GLfloat alpha=1.0) |
|
void | setForegroundColor (const GLfloat foreground_color[4]) |
|
GLfloat | foregroundRed (void) const |
|
GLfloat | foregroundGreen (void) const |
|
GLfloat | foregroundBlue (void) const |
|
GLfloat | foregroundAlpha (void) const |
|
void | setBackgroundColor (GLfloat red=1.0, GLfloat green=1.0, GLfloat blue=1.0, GLfloat alpha=0.0) |
|
void | setBackgroundColor (const GLfloat background_color[4]) |
|
GLfloat | backgroundRed (void) const |
|
GLfloat | backgroundGreen (void) const |
|
GLfloat | backgroundBlue (void) const |
|
GLfloat | backgroundAlpha (void) const |
|
void | setCharacterRotationReference (unsigned char c) |
|
void | setStringRotation (GLfloat string_rotation) |
|
GLfloat | stringRotation (void) const |
|
void | setHorizontalJustification (enum HorizontalJustification horizontal_justification) |
|
enum HorizontalJustification | horizontalJustification (void) const |
|
void | setVerticalJustification (enum VerticalJustification vertical_justification) |
|
enum VerticalJustification | verticaljustification (void) const |
|
void | setCharacterDisplayLists (const DisplayLists &character_display_lists) |
|
DisplayLists & | characterDisplayLists (void) |
|
virtual BBox | measureRaw (const char *s) |
|
GLuint | compile (const char *s) |
|
GLuint | compile (unsigned char c) |
|
void | draw (const char *s) |
|
void | draw (unsigned char c) |
|
void | draw (GLfloat x, GLfloat y, unsigned char c) |
|
void | draw (GLfloat x, GLfloat y, GLfloat z, unsigned char c) |
|
void | draw (GLfloat x, GLfloat y, const char *s) |
|
void | draw (GLfloat x, GLfloat y, GLfloat z, const char *s) |
|
int | ascender (void) |
|
int | descender (void) |
|
Render text as a filled polygons.
Each glyph is drawn as a filled polygon. The contours are extracted from the font file through FreeType. FreeType is used to scale the contours to the given size. Then the GLU tessellation routines are used to tessellate the contours into polygons (well, triangles). By default, these are drawn in GL_FILL polygon mode, but any other polygon mode can be specified.
Usually, the polygons are drawn only in the foreground color, however, you may supply ColorTess and TextureTess objects which can alter the color or texture coordinates of each vertex individually. You can also use the per-glyph display list functionality to alter the attributes of each glyph.
The only complexity to this style is selecting the point size. Since the glyphs are drawn as polygons, they are subject to the viewing and modeling transformations. The point size is nominally chosen to be the same as a raster image generated at the given resolution. Some experimentation with point size and resolution may be necessary to achieve the desired results.
Definition at line 1489 of file moOGLFT.h.