Chromium Code Reviews| Index: xfa/fgas/font/fgas_font.h |
| diff --git a/xfa/fgas/font/fgas_font.h b/xfa/fgas/font/fgas_font.h |
| index 980538d612261b464a16a6af730a2f4d0ecb23b2..881669d07e96f96a0fb4afdfe0466a11f70f4e03 100644 |
| --- a/xfa/fgas/font/fgas_font.h |
| +++ b/xfa/fgas/font/fgas_font.h |
| @@ -16,8 +16,8 @@ |
| #endif // _FXM_PLATFORM_ == _FXM_PLATFORM_WINDOWS_ |
| class CFX_FontSourceEnum_File; |
| +class CFX_GEFont; |
| class CXFA_PDFFontMgr; |
| -class IFX_Font; |
| class IFX_FontMgr; |
| #define FX_FONTSTYLE_Normal 0x00 |
| @@ -29,70 +29,6 @@ class IFX_FontMgr; |
| #define FX_FONTSTYLE_Bold 0x40000 |
| #define FX_FONTSTYLE_BoldItalic (FX_FONTSTYLE_Bold | FX_FONTSTYLE_Italic) |
| #define FX_FONTSTYLE_ExactMatch 0x80000000 |
| -#define FX_FONTDECORATION_Underline 0x00000001 |
| -#define FX_FONTDECORATION_Strikeout 0x00000002 |
| -#define FX_FONTDECORATION_Overline 0x00000004 |
| -#define FX_FONTDECORATION_Emphasis 0x00000008 |
| -#define FX_FONTDECORATION_Superscript 0x00000010 |
| -#define FX_FONTDECORATION_Subscript 0x00000020 |
| -#define FX_FONTDECORATION_SmallCapital 0x00000040 |
| -#define FX_FONTDECORATION_Capital 0x00000080 |
| -#define FX_FONTDECORATION_Lowercase 0x000000C0 |
| -#define FX_FONTDECORATION_Raised 0x00000100 |
| -#define FX_FONTDECORATION_Sunken 0x00000200 |
| -#define FX_FONTDECORATION_Shadow 0x00000400 |
| -#define FX_FONTDECORATION_BoundingShape 0x20000000 |
| -#define FX_FONTDECORATION_Hide 0x40000000 |
| -#define FX_FONTDECORATION_StrokeFill 0x80000000 |
| -#define FX_BOUNDINGSHAPE_None 0 |
| -#define FX_BOUNDINGSHAPE_Circle 1 |
| -#define FX_BOUNDINGSHAPE_Square 2 |
| -#define FX_BOUNDINGSHAPE_Triangle 3 |
| -#define FX_BOUNDINGSHAPE_Diamond 4 |
| - |
| -class IFX_Font { |
| - public: |
| - static IFX_Font* LoadFont(const FX_WCHAR* pszFontFamily, |
| - uint32_t dwFontStyles, |
| - uint16_t wCodePage, |
| - IFX_FontMgr* pFontMgr); |
| - static IFX_Font* LoadFont(const uint8_t* pBuffer, |
| - int32_t iLength, |
| - IFX_FontMgr* pFontMgr); |
| - static IFX_Font* LoadFont(const FX_WCHAR* pszFileName, IFX_FontMgr* pFontMgr); |
| - static IFX_Font* LoadFont(IFX_Stream* pFontStream, |
| - IFX_FontMgr* pFontMgr, |
| - FX_BOOL bSaveStream = FALSE); |
| - static IFX_Font* LoadFont(CFX_Font* pExtFont, |
| - IFX_FontMgr* pFontMgr, |
| - FX_BOOL bTakeOver = FALSE); |
| - virtual ~IFX_Font() {} |
| - virtual void Release() = 0; |
| - virtual IFX_Font* Retain() = 0; |
| - virtual IFX_Font* Derive(uint32_t dwFontStyles, uint16_t wCodePage = 0) = 0; |
| - virtual void GetFamilyName(CFX_WideString& wsFamily) const = 0; |
| - virtual uint32_t GetFontStyles() const = 0; |
| - virtual uint8_t GetCharSet() const = 0; |
| - virtual FX_BOOL GetCharWidth(FX_WCHAR wUnicode, |
| - int32_t& iWidth, |
| - FX_BOOL bCharCode = FALSE) = 0; |
| - virtual int32_t GetGlyphIndex(FX_WCHAR wUnicode, |
| - FX_BOOL bCharCode = FALSE) = 0; |
| - virtual int32_t GetAscent() const = 0; |
| - virtual int32_t GetDescent() const = 0; |
| - virtual FX_BOOL GetCharBBox(FX_WCHAR wUnicode, |
| - CFX_Rect& bbox, |
| - FX_BOOL bCharCode = FALSE) = 0; |
| - virtual FX_BOOL GetBBox(CFX_Rect& bbox) = 0; |
| - virtual int32_t GetItalicAngle() const = 0; |
| - virtual void Reset() = 0; |
| - virtual IFX_Font* GetSubstFont(int32_t iGlyphIndex) const = 0; |
| - virtual void* GetDevFont() const = 0; |
| - virtual void SetFontProvider(CXFA_PDFFontMgr* pProvider) = 0; |
| -#if _FXM_PLATFORM_ != _FXM_PLATFORM_WINDOWS_ |
| - virtual void SetLogicalFontStyle(uint32_t dwLogFontStyle) = 0; |
| -#endif |
| -}; |
| #if _FXM_PLATFORM_ == _FXM_PLATFORM_WINDOWS_ |
| struct FX_FONTMATCHPARAMS { |
| @@ -149,37 +85,37 @@ class IFX_FontMgr { |
| static IFX_FontMgr* Create(FX_LPEnumAllFonts pEnumerator); |
| virtual ~IFX_FontMgr() {} |
| virtual void Release() = 0; |
| - virtual IFX_Font* GetDefFontByCodePage( |
| + virtual CFX_GEFont* GetDefFontByCodePage( |
| uint16_t wCodePage, |
| uint32_t dwFontStyles, |
| const FX_WCHAR* pszFontFamily = NULL) = 0; |
| - virtual IFX_Font* GetDefFontByCharset( |
| + virtual CFX_GEFont* GetDefFontByCharset( |
| uint8_t nCharset, |
| uint32_t dwFontStyles, |
| const FX_WCHAR* pszFontFamily = NULL) = 0; |
| - virtual IFX_Font* GetDefFontByUnicode( |
| + virtual CFX_GEFont* GetDefFontByUnicode( |
| FX_WCHAR wUnicode, |
| uint32_t dwFontStyles, |
| const FX_WCHAR* pszFontFamily = NULL) = 0; |
| - virtual IFX_Font* GetDefFontByLanguage( |
| + virtual CFX_GEFont* GetDefFontByLanguage( |
| uint16_t wLanguage, |
| uint32_t dwFontStyles, |
| const FX_WCHAR* pszFontFamily = NULL) = 0; |
| - virtual IFX_Font* LoadFont(const FX_WCHAR* pszFontFamily, |
| - uint32_t dwFontStyles, |
| - uint16_t wCodePage = 0xFFFF) = 0; |
| - virtual IFX_Font* LoadFont(const uint8_t* pBuffer, int32_t iLength) = 0; |
| - virtual IFX_Font* LoadFont(const FX_WCHAR* pszFileName) = 0; |
| - virtual IFX_Font* LoadFont(IFX_Stream* pFontStream, |
| - const FX_WCHAR* pszFontAlias = NULL, |
| - uint32_t dwFontStyles = 0, |
| - uint16_t wCodePage = 0, |
| - FX_BOOL bSaveStream = FALSE) = 0; |
| - virtual IFX_Font* LoadFont(IFX_Font* pSrcFont, |
| - uint32_t dwFontStyles, |
| - uint16_t wCodePage = 0xFFFF) = 0; |
| + virtual CFX_GEFont* LoadFont(const FX_WCHAR* pszFontFamily, |
| + uint32_t dwFontStyles, |
| + uint16_t wCodePage = 0xFFFF) = 0; |
| + virtual CFX_GEFont* LoadFont(const uint8_t* pBuffer, int32_t iLength) = 0; |
| + virtual CFX_GEFont* LoadFont(const FX_WCHAR* pszFileName) = 0; |
| + virtual CFX_GEFont* LoadFont(IFX_Stream* pFontStream, |
| + const FX_WCHAR* pszFontAlias = NULL, |
| + uint32_t dwFontStyles = 0, |
| + uint16_t wCodePage = 0, |
| + FX_BOOL bSaveStream = FALSE) = 0; |
| + virtual CFX_GEFont* LoadFont(CFX_GEFont* pSrcFont, |
| + uint32_t dwFontStyles, |
| + uint16_t wCodePage = 0xFFFF) = 0; |
| virtual void ClearFontCache() = 0; |
| - virtual void RemoveFont(IFX_Font* pFont) = 0; |
| + virtual void RemoveFont(CFX_GEFont* pFont) = 0; |
| }; |
| #else // _FXM_PLATFORM_ == _FXM_PLATFORM_WINDOWS_ |
| @@ -189,53 +125,57 @@ class IFX_FontMgr { |
| static IFX_FontMgr* Create(CFX_FontSourceEnum_File* pFontEnum); |
| virtual ~IFX_FontMgr() {} |
| virtual void Release() = 0; |
| - virtual IFX_Font* GetDefFontByCodePage( |
| + virtual CFX_GEFont* GetDefFontByCodePage( |
|
dsinclair
2016/06/02 17:37:38
This version of the class looks very similar to th
Lei Zhang
2016/06/07 01:17:16
I have a follow up CL.
|
| uint16_t wCodePage, |
| uint32_t dwFontStyles, |
| const FX_WCHAR* pszFontFamily = NULL) = 0; |
| - virtual IFX_Font* GetDefFontByCharset( |
| + virtual CFX_GEFont* GetDefFontByCharset( |
| uint8_t nCharset, |
| uint32_t dwFontStyles, |
| const FX_WCHAR* pszFontFamily = NULL) = 0; |
| - virtual IFX_Font* GetDefFontByUnicode( |
| + virtual CFX_GEFont* GetDefFontByUnicode( |
| FX_WCHAR wUnicode, |
| uint32_t dwFontStyles, |
| const FX_WCHAR* pszFontFamily = NULL) = 0; |
| - virtual IFX_Font* GetDefFontByLanguage( |
| + virtual CFX_GEFont* GetDefFontByLanguage( |
| uint16_t wLanguage, |
| uint32_t dwFontStyles, |
| const FX_WCHAR* pszFontFamily = NULL) = 0; |
| - virtual IFX_Font* GetFontByCodePage(uint16_t wCodePage, |
| - uint32_t dwFontStyles, |
| - const FX_WCHAR* pszFontFamily = NULL) = 0; |
| - inline IFX_Font* LoadFont(const FX_WCHAR* pszFontFamily, |
| - uint32_t dwFontStyles, |
| - uint16_t wCodePage) { |
| + virtual CFX_GEFont* GetFontByCodePage( |
| + uint16_t wCodePage, |
| + uint32_t dwFontStyles, |
| + const FX_WCHAR* pszFontFamily = NULL) = 0; |
| + inline CFX_GEFont* LoadFont(const FX_WCHAR* pszFontFamily, |
| + uint32_t dwFontStyles, |
| + uint16_t wCodePage) { |
| return GetFontByCodePage(wCodePage, dwFontStyles, pszFontFamily); |
| } |
| - virtual IFX_Font* GetFontByCharset(uint8_t nCharset, |
| - uint32_t dwFontStyles, |
| - const FX_WCHAR* pszFontFamily = NULL) = 0; |
| - virtual IFX_Font* GetFontByUnicode(FX_WCHAR wUnicode, |
| - uint32_t dwFontStyles, |
| - const FX_WCHAR* pszFontFamily = NULL) = 0; |
| - virtual IFX_Font* GetFontByLanguage(uint16_t wLanguage, |
| - uint32_t dwFontStyles, |
| - const FX_WCHAR* pszFontFamily = NULL) = 0; |
| - virtual IFX_Font* LoadFont(const uint8_t* pBuffer, |
| - int32_t iLength, |
| - int32_t iFaceIndex, |
| - int32_t* pFaceCount = NULL) = 0; |
| - virtual IFX_Font* LoadFont(const FX_WCHAR* pszFileName, |
| - int32_t iFaceIndex, |
| - int32_t* pFaceCount = NULL) = 0; |
| - virtual IFX_Font* LoadFont(IFX_Stream* pFontStream, |
| - int32_t iFaceIndex, |
| - int32_t* pFaceCount = NULL, |
| - FX_BOOL bSaveStream = FALSE) = 0; |
| + virtual CFX_GEFont* GetFontByCharset( |
| + uint8_t nCharset, |
| + uint32_t dwFontStyles, |
| + const FX_WCHAR* pszFontFamily = NULL) = 0; |
| + virtual CFX_GEFont* GetFontByUnicode( |
| + FX_WCHAR wUnicode, |
| + uint32_t dwFontStyles, |
| + const FX_WCHAR* pszFontFamily = NULL) = 0; |
| + virtual CFX_GEFont* GetFontByLanguage( |
| + uint16_t wLanguage, |
| + uint32_t dwFontStyles, |
| + const FX_WCHAR* pszFontFamily = NULL) = 0; |
| + virtual CFX_GEFont* LoadFont(const uint8_t* pBuffer, |
| + int32_t iLength, |
| + int32_t iFaceIndex, |
| + int32_t* pFaceCount = NULL) = 0; |
| + virtual CFX_GEFont* LoadFont(const FX_WCHAR* pszFileName, |
| + int32_t iFaceIndex, |
| + int32_t* pFaceCount = NULL) = 0; |
| + virtual CFX_GEFont* LoadFont(IFX_Stream* pFontStream, |
| + int32_t iFaceIndex, |
| + int32_t* pFaceCount = NULL, |
| + FX_BOOL bSaveStream = FALSE) = 0; |
| virtual void ClearFontCache() = 0; |
| - virtual void RemoveFont(IFX_Font* pFont) = 0; |
| + virtual void RemoveFont(CFX_GEFont* pFont) = 0; |
| }; |
| #endif // _FXM_PLATFORM_ == _FXM_PLATFORM_WINDOWS_ |