Index: core/fxge/ge/cfx_renderdevice.cpp |
diff --git a/core/fxge/ge/cfx_renderdevice.cpp b/core/fxge/ge/cfx_renderdevice.cpp |
index ad05ef743b1778a8f7304861247e8116f5f66156..11f0087f92e4a182a79cd8f3f50b6832a67866ee 100644 |
--- a/core/fxge/ge/cfx_renderdevice.cpp |
+++ b/core/fxge/ge/cfx_renderdevice.cpp |
@@ -9,7 +9,6 @@ |
#include "core/fxcrt/include/fx_safe_types.h" |
#include "core/fxge/include/cfx_autofontcache.h" |
#include "core/fxge/include/cfx_facecache.h" |
-#include "core/fxge/include/cfx_fontcache.h" |
#include "core/fxge/include/cfx_fxgedevice.h" |
#include "core/fxge/include/cfx_graphstatedata.h" |
#include "core/fxge/include/cfx_pathdata.h" |
@@ -824,7 +823,6 @@ bool CFX_RenderDevice::SetBitsWithMask(const CFX_DIBSource* pBitmap, |
FX_BOOL CFX_RenderDevice::DrawNormalText(int nChars, |
const FXTEXT_CHARPOS* pCharPos, |
CFX_Font* pFont, |
- CFX_FontCache* pCache, |
FX_FLOAT font_size, |
const CFX_Matrix* pText2Device, |
uint32_t fill_color, |
@@ -833,9 +831,8 @@ FX_BOOL CFX_RenderDevice::DrawNormalText(int nChars, |
if (m_DeviceClass != FXDC_DISPLAY) { |
if (!(text_flags & FXTEXT_PRINTGRAPHICTEXT)) { |
if (ShouldDrawDeviceText(pFont, text_flags) && |
- m_pDeviceDriver->DrawDeviceText(nChars, pCharPos, pFont, pCache, |
- pText2Device, font_size, |
- fill_color)) { |
+ m_pDeviceDriver->DrawDeviceText(nChars, pCharPos, pFont, pText2Device, |
+ font_size, fill_color)) { |
return TRUE; |
} |
} |
@@ -843,8 +840,8 @@ FX_BOOL CFX_RenderDevice::DrawNormalText(int nChars, |
return FALSE; |
} else if (!(text_flags & FXTEXT_NO_NATIVETEXT)) { |
if (ShouldDrawDeviceText(pFont, text_flags) && |
- m_pDeviceDriver->DrawDeviceText(nChars, pCharPos, pFont, pCache, |
- pText2Device, font_size, fill_color)) { |
+ m_pDeviceDriver->DrawDeviceText(nChars, pCharPos, pFont, pText2Device, |
+ font_size, fill_color)) { |
return TRUE; |
} |
} |
@@ -862,9 +859,8 @@ FX_BOOL CFX_RenderDevice::DrawNormalText(int nChars, |
(pFont->GetSubstFont()->m_SubstFlags & FXFONT_SUBST_GLYPHPATH)) { |
int nPathFlags = |
(text_flags & FXTEXT_NOSMOOTH) == 0 ? 0 : FXFILL_NOPATHSMOOTH; |
- return DrawTextPath(nChars, pCharPos, pFont, pCache, font_size, |
- pText2Device, nullptr, nullptr, fill_color, 0, |
- nullptr, nPathFlags); |
+ return DrawTextPath(nChars, pCharPos, pFont, font_size, pText2Device, |
+ nullptr, nullptr, fill_color, 0, nullptr, nPathFlags); |
} |
} |
int anti_alias = FXFT_RENDER_MODE_MONO; |
@@ -895,10 +891,6 @@ FX_BOOL CFX_RenderDevice::DrawNormalText(int nChars, |
} |
} |
} |
- if (!pCache) |
- pCache = CFX_GEModule::Get()->GetFontCache(); |
- CFX_FaceCache* pFaceCache = pCache->GetCachedFace(pFont); |
- CFX_AutoFontCache autoFontCache(pCache, pFont); |
std::vector<FXTEXT_GLYPHPOS> glyphs(nChars); |
CFX_Matrix matrixCTM = GetCTM(); |
FX_FLOAT scale_x = FXSYS_fabs(matrixCTM.a); |
@@ -922,12 +914,12 @@ FX_BOOL CFX_RenderDevice::DrawNormalText(int nChars, |
charpos.m_AdjustMatrix[0], charpos.m_AdjustMatrix[1], |
charpos.m_AdjustMatrix[2], charpos.m_AdjustMatrix[3], 0, 0); |
new_matrix.Concat(deviceCtm); |
- glyph.m_pGlyph = pFaceCache->LoadGlyphBitmap( |
- pFont, charpos.m_GlyphIndex, charpos.m_bFontStyle, &new_matrix, |
+ glyph.m_pGlyph = pFont->LoadGlyphBitmap( |
+ charpos.m_GlyphIndex, charpos.m_bFontStyle, &new_matrix, |
charpos.m_FontCharWidth, anti_alias, nativetext_flags); |
} else { |
- glyph.m_pGlyph = pFaceCache->LoadGlyphBitmap( |
- pFont, charpos.m_GlyphIndex, charpos.m_bFontStyle, &deviceCtm, |
+ glyph.m_pGlyph = pFont->LoadGlyphBitmap( |
+ charpos.m_GlyphIndex, charpos.m_bFontStyle, &deviceCtm, |
charpos.m_FontCharWidth, anti_alias, nativetext_flags); |
} |
} |
@@ -1048,7 +1040,6 @@ FX_BOOL CFX_RenderDevice::DrawNormalText(int nChars, |
FX_BOOL CFX_RenderDevice::DrawTextPath(int nChars, |
const FXTEXT_CHARPOS* pCharPos, |
CFX_Font* pFont, |
- CFX_FontCache* pCache, |
FX_FLOAT font_size, |
const CFX_Matrix* pText2User, |
const CFX_Matrix* pUser2Device, |
@@ -1057,10 +1048,6 @@ FX_BOOL CFX_RenderDevice::DrawTextPath(int nChars, |
FX_ARGB stroke_color, |
CFX_PathData* pClippingPath, |
int nFlag) { |
- if (!pCache) |
- pCache = CFX_GEModule::Get()->GetFontCache(); |
- CFX_FaceCache* pFaceCache = pCache->GetCachedFace(pFont); |
- CFX_AutoFontCache autoFontCache(pCache, pFont); |
for (int iChar = 0; iChar < nChars; iChar++) { |
const FXTEXT_CHARPOS& charpos = pCharPos[iChar]; |
CFX_Matrix matrix; |
@@ -1070,8 +1057,8 @@ FX_BOOL CFX_RenderDevice::DrawTextPath(int nChars, |
} |
matrix.Concat(font_size, 0, 0, font_size, charpos.m_OriginX, |
charpos.m_OriginY); |
- const CFX_PathData* pPath = pFaceCache->LoadGlyphPath( |
- pFont, charpos.m_GlyphIndex, charpos.m_FontCharWidth); |
+ const CFX_PathData* pPath = |
+ pFont->LoadGlyphPath(charpos.m_GlyphIndex, charpos.m_FontCharWidth); |
if (!pPath) |
continue; |
matrix.Concat(*pText2User); |