forked from Kitware/VTK
-
Notifications
You must be signed in to change notification settings - Fork 0
/
FTBitmapGlyph.cpp
120 lines (98 loc) · 2.34 KB
/
FTBitmapGlyph.cpp
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
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
#include "FTBitmapGlyph.h"
#ifdef FTGL_DEBUG
#include "mmgr.h"
#endif
#ifdef FTGL_USE_NAMESPACE
namespace ftgl
{
#endif
FTBitmapGlyph::FTBitmapGlyph( FT_Glyph _glyph)
: FTGlyph(),
destWidth(0),
destHeight(0),
data(0)
{
this->glyph = _glyph;
bBox = FTBBox(this->glyph);
advance = (float)(this->glyph->advance.x >> 16);
}
void FTBitmapGlyph::ConvertGlyph()
{
// This function will always fail if the glyph's format isn't scalable????
err = FT_Glyph_To_Bitmap( &glyph, ft_render_mode_mono, 0, 1);
if( err || ft_glyph_format_bitmap != this->glyph->format)
{return;}
FT_BitmapGlyph bitmap = reinterpret_cast<FT_BitmapGlyph>(this->glyph);
FT_Bitmap* source = &bitmap->bitmap;
//check the pixel mode
//ft_pixel_mode_grays
int srcWidth = source->width;
int srcHeight = source->rows;
int srcPitch = source->pitch;
// FIXME What about dest alignment?
destWidth = srcWidth;
destHeight = srcHeight;
if( destWidth && destHeight)
{
data = new unsigned char[srcPitch * destHeight];
#if 1
unsigned char *src = source->buffer;
unsigned char *src_row;
unsigned char *dest = data + ((destHeight - 1) * srcPitch);
size_t dest_step = srcPitch * 2;
for(int y = 0; y < srcHeight; ++y)
{
src_row = src;
for(int x = 0; x < srcPitch; ++x)
{
*dest++ = *src_row++;
}
src += srcPitch;
dest -= dest_step;
}
#else
for(int y = 0; y < srcHeight; ++y)
{
--destHeight;
for(int x = 0; x < srcPitch; ++x)
{
*( data + ( destHeight * srcPitch + x)) = *( source->buffer + ( y * srcPitch) + x);
}
}
#endif
destHeight = srcHeight;
}
pos.x = bitmap->left;
pos.y = srcHeight - bitmap->top;
this->glyphHasBeenConverted = 1;
}
FTBitmapGlyph::~FTBitmapGlyph()
{
if( data)
delete [] data;
}
float FTBitmapGlyph::Render( const FT_Vector& pen,
const FTGLRenderContext *context)
{
if (!this->glyphHasBeenConverted)
{
this->ConvertGlyph();
}
if( data)
{
#ifdef FTGL_SUPPORT_MANGLE_MESA
if (context && context->UseMangleMesa)
{
this->RenderMesa(pen, context);
}
else
#endif
{
this->RenderOpenGL(pen, context);
}
}
return advance;
}
#ifdef FTGL_USE_NAMESPACE
} // namespace ftgl
#endif