Planet
navi homePPSaboutscreenshotsdownloaddevelopmentforum

source: orxonox.OLD/trunk/src/lib/graphics/text_engine/font.h @ 5344

Last change on this file since 5344 was 5344, checked in by bensch, 19 years ago

orxonox/trunk: new Way to load and unload Text

File size: 3.4 KB
Line 
1/*!
2 * @file font.h
3 * brief Definition of the FONT-loading class
4 *
5 * !! IMPORTANT !! When using ttf fonts clear the license issues prior to
6 * adding them to orxonox. This is really important, because we do not want
7 * to offend anyone.
8 */
9
10#ifndef _FONT_H
11#define _FONT_H
12
13#include "base_object.h"
14
15#include "glincl.h"
16
17
18#ifdef HAVE_SDL_TTF_H
19#include <SDL_ttf.h>
20#else
21#include <SDL/SDL_ttf.h>
22#endif
23
24/* some default values */
25#define FONT_NUM_COLORS              256                        //!< number of colors.
26
27#define FONT_HIGHEST_KNOWN_CHAR      128                        //!< The highest character known to the textEngine.
28
29// FORWARD DECLARATION
30
31//! A struct for handling glyphs
32/**
33   a Glyph is one letter of a certain font
34 */
35struct Glyph
36{
37  // Glyph-specific (size and so on)
38  Uint16   character;         //!< The character
39  int      minX;              //!< The minimum distance from the origin in X
40  int      maxX;              //!< The maximum distance from the origin in X
41  int      minY;              //!< The minimum distance from the origin in Y
42  int      maxY;              //!< The maximum distance from the origin in Y
43  int      width;             //!< The width of the Glyph
44  int      height;            //!< The height of the Glyph
45  int      bearingX;          //!< How much is right of the Origin
46  int      bearingY;          //!< How much is above the Origin
47  int      advance;           //!< How big a Glyph would be in monospace-mode
48
49  // OpenGL-specific
50  //  TexCoord texCoord;      //!< A Texture Coordinate for this glyph.
51  GLuint   displayList;       //!< DiplayList to render this Glyph.
52};
53
54
55////////////
56/// FONT ///
57////////////
58//! A class to handle a Font of a certain ttf-File, Size and Color.
59class Font : public BaseObject
60{
61  friend class Text;
62
63  public:
64    Font(const char* fontFile,
65         unsigned int fontSize);
66    Font(char** xpmArray);
67    virtual ~Font();
68
69    void init();
70
71  // font
72    bool loadFont(const char* fontFile);
73    bool loadFontFromSDL_Surface(SDL_Surface* surface);
74
75    void setSize(unsigned int fontSize);
76    void setStyle(const char* renderStyle);
77
78    /** @returns a Pointer to the Array of Glyphs */
79    inline Glyph** getGlyphArray() const { return this->glyphArray; };
80    /** @returns the texture to the fast-texture */
81    inline GLuint getFastTextureID() const { return this->fastTextureID; };
82    /** @returns the default Font */
83    inline static Font* getDefaultFont() { return Font::defaultFont; };
84
85    void createAsciiImage(const char* fileName);
86    static void initDefaultFont();
87    static void removeDefaultFont();
88
89  private:
90    int getMaxHeight();
91    int getMaxAscent();
92    int getMaxDescent();
93    Glyph* getGlyphMetrics(Uint16 character);
94
95    GLuint createFastTexture();
96
97    void initGlyphs(Uint16 from, Uint16 count);
98    int findOptimalFastTextureSize();
99
100    void debug();
101
102  private:
103    static Font*  defaultFont;         //!< a default font, that is used, if other fonts were unable to be loaded.
104  // information about the Font
105    TTF_Font*     font;                //!< The font we use for this.
106    unsigned int  fontSize;            //!< The size of the font in pixels. each Font has one size.
107    int           renderStyle;         //!< The Renderstyle
108
109    Glyph**       glyphArray;          //!< An Array of all the Glyphs stored in the Array of Glyphs.
110    GLuint        fastTextureID;       //!< The fast textureID.
111};
112
113#endif /* _FONT_H */
Note: See TracBrowser for help on using the repository browser.