http://www.cppblog.com/liangairan/archive/2016/09/11/214270.html
这里说一下Freetype的关键点,比较基础的在很多文章已经有说明,这里就不详细说明了。
FreeType每个字符的加载,可以影响到后面对字符图像的处理。
在这里说明一下,字符的加载有多种方式,调用函数是:
FT_Load_Char( FT_Face face,
FT_ULong char_code,
FT_Int32 load_flags );
其中的参数load_flags决定了加载后字体图像的属性。
这里只对常用的进行解释:
关闭抗锯齿:FT_LOAD_MONOCHROME(这个其实是加载1位bmp位图)
打开抗锯齿:FT_LOAD_FORCE_AUTOHINT
加载时就已经生成图像:FT_LOAD_RENDER
加载时不生成图像:FT_LOAD_NO_BITMAP(注意:这里需要在加载后调用FT_Render_Glyph)
下面是代码示例:
1 FT_Error error = 0;
2 FT_Int32 nLoadFlag = m_type.m_nFontHint == FONT_MONO ? FT_LOAD_FORCE_AUTOHINT | FT_LOAD_MONOCHROME :
FT_LOAD_FORCE_AUTOHINT | FT_LOAD_RENDER;/*FT_LOAD_NO_BITMAP*/;
3 error = FT_Load_Char(m_ftFace, wCH, nLoadFlag);
4
5 if (error)
6 {
7 error = FT_Load_Char(m_ftFace, wCH, FT_LOAD_DEFAULT);
8 }
9
if (error)
{
return NULL;
}
//加粗
FT_Pos xBold = 32;
FT_Pos yBold = 32;
if (m_bBold)
{
if (m_ftFace->glyph->format == FT_GLYPH_FORMAT_OUTLINE)
{
FT_BBox oldBox;
FT_Outline_Get_CBox(&m_ftSlot->outline , &oldBox);
error = FT_Outline_Embolden(&m_ftSlot->outline, xBold);
FT_BBox newBox;
FT_Outline_Get_CBox(&m_ftSlot->outline , &newBox);
xBold = (newBox.xMax - newBox.xMin) - (oldBox.xMax - oldBox.xMin);
yBold = (newBox.yMax - newBox.yMin) - (oldBox.yMax - oldBox.yMin);
}
else if (m_ftFace->glyph->format == FT_GLYPH_FORMAT_BITMAP)
{
FT_Library ftLibrary = FTFaceMgr::GetInstance()->GetFTLibrary();
error = FT_Bitmap_Embolden( ftLibrary, &m_ftSlot->bitmap, xBold, yBold );
}
}
//斜体
if (m_bItailc)
{
if (m_ftFace->glyph->format == FT_GLYPH_FORMAT_OUTLINE)
FT_Outline_Transform(&m_ftSlot->outline, &m_matItailc);
}
//FT_Error error = FT_Render_Glyph(m_ftSlot, FT_RENDER_MODE_MONO);
if (m_ftFace->glyph->format != FT_GLYPH_FORMAT_BITMAP)}
{
error = FT_Render_Glyph(m_ftSlot, FT_RENDER_MODE_NORMAL);
}
在这里可以看到:
如果是加载时已经是FT_LOAD_RENDER,那么m_ftFace->glyph->format就是FT_GLYPH_FORMAT_BITMAP;
否则就是FT_GLYPH_FORMAT_OUTLINE。
这时候加粗和斜体都可以在代码中看到如果实现。
2 FT_Int32 nLoadFlag = m_type.m_nFontHint == FONT_MONO ? FT_LOAD_FORCE_AUTOHINT | FT_LOAD_MONOCHROME :
FT_LOAD_FORCE_AUTOHINT | FT_LOAD_RENDER;/*FT_LOAD_NO_BITMAP*/;
3 error = FT_Load_Char(m_ftFace, wCH, nLoadFlag);
4
5 if (error)
6 {
7 error = FT_Load_Char(m_ftFace, wCH, FT_LOAD_DEFAULT);
8 }
9
if (error)
{
return NULL;
}
//加粗
FT_Pos xBold = 32;
FT_Pos yBold = 32;
if (m_bBold)
{
if (m_ftFace->glyph->format == FT_GLYPH_FORMAT_OUTLINE)
{
FT_BBox oldBox;
FT_Outline_Get_CBox(&m_ftSlot->outline , &oldBox);
error = FT_Outline_Embolden(&m_ftSlot->outline, xBold);
FT_BBox newBox;
FT_Outline_Get_CBox(&m_ftSlot->outline , &newBox);
xBold = (newBox.xMax - newBox.xMin) - (oldBox.xMax - oldBox.xMin);
yBold = (newBox.yMax - newBox.yMin) - (oldBox.yMax - oldBox.yMin);
}
else if (m_ftFace->glyph->format == FT_GLYPH_FORMAT_BITMAP)
{
FT_Library ftLibrary = FTFaceMgr::GetInstance()->GetFTLibrary();
error = FT_Bitmap_Embolden( ftLibrary, &m_ftSlot->bitmap, xBold, yBold );
}
}
//斜体
if (m_bItailc)
{
if (m_ftFace->glyph->format == FT_GLYPH_FORMAT_OUTLINE)
FT_Outline_Transform(&m_ftSlot->outline, &m_matItailc);
}
//FT_Error error = FT_Render_Glyph(m_ftSlot, FT_RENDER_MODE_MONO);
if (m_ftFace->glyph->format != FT_GLYPH_FORMAT_BITMAP)}
{
error = FT_Render_Glyph(m_ftSlot, FT_RENDER_MODE_NORMAL);
}
在这里可以看到:
如果是加载时已经是FT_LOAD_RENDER,那么m_ftFace->glyph->format就是FT_GLYPH_FORMAT_BITMAP;
否则就是FT_GLYPH_FORMAT_OUTLINE。
这时候加粗和斜体都可以在代码中看到如果实现。