From 26f63bfa197e82a6d3a3f298c603f1878891b8f8 Mon Sep 17 00:00:00 2001 From: Kent Mein Date: Fri, 21 Jan 2005 05:15:33 +0000 Subject: Added bFTGL to extern and updated the Makefiles. I'm guessing there will need to be tweaks but it seems to work on my linux box. I haven't touched any of the other build systems so those will need to be done. We probably don't need all of this stuff but I figured better to add a little too much then to little. Kent --- extern/bFTGL/src/FTBufferGlyph.cpp | 59 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 59 insertions(+) create mode 100755 extern/bFTGL/src/FTBufferGlyph.cpp (limited to 'extern/bFTGL/src/FTBufferGlyph.cpp') diff --git a/extern/bFTGL/src/FTBufferGlyph.cpp b/extern/bFTGL/src/FTBufferGlyph.cpp new file mode 100755 index 00000000000..27310103152 --- /dev/null +++ b/extern/bFTGL/src/FTBufferGlyph.cpp @@ -0,0 +1,59 @@ +#include "FTBufferGlyph.h" + +FTBufferGlyph::FTBufferGlyph( FT_GlyphSlot glyph, unsigned char* b) +: FTGlyph( glyph), + destWidth(0), + destHeight(0), + data(0), + buffer(b) +{ + err = FT_Render_Glyph( glyph, FT_RENDER_MODE_NORMAL); + if( err || ft_glyph_format_bitmap != glyph->format) + { + return; + } + + FT_Bitmap bitmap = glyph->bitmap; + + unsigned int srcWidth = bitmap.width; + unsigned int srcHeight = bitmap.rows; + unsigned int srcPitch = bitmap.pitch; + + destWidth = srcWidth; + destHeight = srcHeight; + destPitch = srcPitch; + + if( destWidth && destHeight) + { + data = new unsigned char[destPitch * destHeight]; + unsigned char* dest = data + (( destHeight - 1) * destPitch); + + unsigned char* src = bitmap.buffer; + + for( unsigned int y = 0; y < srcHeight; ++y) + { + memcpy( dest, src, srcPitch); + dest -= destPitch; + src += srcPitch; + } + } + + pos.x = glyph->bitmap_left; + pos.y = srcHeight - glyph->bitmap_top; +} + + +FTBufferGlyph::~FTBufferGlyph() +{ + delete [] data; +} + + +float FTBufferGlyph::Render( const FTPoint& pen) +{ + if( data && buffer) + { + } + + return advance; +} -- cgit v1.2.3