Welcome to mirror list, hosted at ThFree Co, Russian Federation.

FTGLBufferFont.h « include « bFTGL « extern - git.blender.org/blender.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
blob: 2f74b5cdef91371e60fe968331fbdf10b63623bd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
#ifndef     __FTGLBufferFont__
#define     __FTGLBufferFont__


#include "FTFont.h"
#include "FTGL.h"


class FTGlyph;


/**
 * FTGLBufferFont is a specialisation of the FTFont class for handling
 * Pixmap (Grey Scale) fonts
 *
 * @see     FTFont
 */
class FTGL_EXPORT FTGLBufferFont : public FTFont
{
    public:
        /**
         * Open and read a font file. Sets Error flag.
         *
         * @param fontname  font file name.
         */
        FTGLBufferFont( const char* fontname);
        
        /**
         * Open and read a font from a buffer in memory. Sets Error flag.
         *
         * @param pBufferBytes  the in-memory buffer
         * @param bufferSizeInBytes  the length of the buffer in bytes
         */
        FTGLBufferFont( const unsigned char *pBufferBytes, size_t bufferSizeInBytes);
        
        
        void SetClientBuffer( unsigned char* b)
        {
            buffer = b;
        }
        
        
        /**
         * Destructor
         */
        ~FTGLBufferFont();
        
        /**
         * Renders a string of characters
         * 
         * @param string    'C' style string to be output.   
         */
        void Render( const char* string);
        
        /**
         * Renders a string of characters
         * 
         * @param string    wchar_t string to be output.     
         */
        void Render( const wchar_t* string);

    private:
        /**
         * Construct a FTBufferGlyph.
         *
         * @param g The glyph index NOT the char code.
         * @return  An FTBufferGlyph or <code>null</code> on failure.
         */
        inline virtual FTGlyph* MakeGlyph( unsigned int g);
        
        unsigned char* buffer;
};


#endif  //  __FTGLBufferFont__