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_ |