diff options
author | Lei Zhang <thestig@chromium.org> | 2018-01-16 21:32:26 +0000 |
---|---|---|
committer | Chromium commit bot <commit-bot@chromium.org> | 2018-01-16 21:32:26 +0000 |
commit | e80576173df7488964e588f5ac52f9af4b046021 (patch) | |
tree | 6eefe802d130f4ebeea7e6c6f66ee3b49379b92c /xfa/fde/cfde_textout.h | |
parent | 027190ec8148a2f1edc18c37eae26e896f3a309a (diff) | |
download | pdfium-e80576173df7488964e588f5ac52f9af4b046021.tar.xz |
Clean up xfa/fde/cfde_textout.h.
- Move enums/structs other than CFDE_TextOut to a separate header.
- Move CFDE_TTOLine into CFDE_TextOut.
Change-Id: I63196ebe6c02bc88d1c20ecb625505013edbfa26
Reviewed-on: https://pdfium-review.googlesource.com/22930
Reviewed-by: Ryan Harrison <rharrison@chromium.org>
Commit-Queue: Lei Zhang <thestig@chromium.org>
Diffstat (limited to 'xfa/fde/cfde_textout.h')
-rw-r--r-- | xfa/fde/cfde_textout.h | 73 |
1 files changed, 20 insertions, 53 deletions
diff --git a/xfa/fde/cfde_textout.h b/xfa/fde/cfde_textout.h index f69c0a8717..6b6878e07c 100644 --- a/xfa/fde/cfde_textout.h +++ b/xfa/fde/cfde_textout.h @@ -15,64 +15,13 @@ #include "core/fxge/cfx_defaultrenderdevice.h" #include "core/fxge/cfx_renderdevice.h" #include "core/fxge/fx_dib.h" -#include "xfa/fgas/font/cfgas_fontmgr.h" +#include "xfa/fde/cfde_data.h" class CFDE_RenderDevice; +class CFGAS_GEFont; class CFX_RenderDevice; class CFX_TxtBreak; -enum class FDE_TextAlignment : uint8_t { - kTopLeft = 0, - kCenterLeft, - kCenter, - kCenterRight -}; - -struct FDE_TextStyle { - FDE_TextStyle() - : single_line_(false), line_wrap_(false), last_line_height_(false) {} - ~FDE_TextStyle() {} - - void Reset() { - single_line_ = false; - line_wrap_ = false; - last_line_height_ = false; - } - - bool single_line_; - bool line_wrap_; - bool last_line_height_; -}; - -struct FDE_TTOPIECE { - FDE_TTOPIECE(); - FDE_TTOPIECE(const FDE_TTOPIECE& that); - ~FDE_TTOPIECE(); - - int32_t iStartChar; - int32_t iChars; - uint32_t dwCharStyles; - CFX_RectF rtPiece; -}; - -class CFDE_TTOLine { - public: - CFDE_TTOLine(); - CFDE_TTOLine(const CFDE_TTOLine& ttoLine); - ~CFDE_TTOLine(); - - bool GetNewReload() const { return m_bNewReload; } - void SetNewReload(bool reload) { m_bNewReload = reload; } - int32_t AddPiece(int32_t index, const FDE_TTOPIECE& ttoPiece); - int32_t GetSize() const; - FDE_TTOPIECE* GetPtrAt(int32_t index); - void RemoveLast(int32_t iCount); - - private: - bool m_bNewReload; - std::deque<FDE_TTOPIECE> m_pieces; -}; - class CFDE_TextOut { public: static bool DrawString(CFX_RenderDevice* device, @@ -103,6 +52,24 @@ class CFDE_TextOut { int32_t GetTotalLines() const { return m_iTotalLines; } private: + class CFDE_TTOLine { + public: + CFDE_TTOLine(); + CFDE_TTOLine(const CFDE_TTOLine& ttoLine); + ~CFDE_TTOLine(); + + bool GetNewReload() const { return m_bNewReload; } + void SetNewReload(bool reload) { m_bNewReload = reload; } + int32_t AddPiece(int32_t index, const FDE_TTOPIECE& ttoPiece); + int32_t GetSize() const; + FDE_TTOPIECE* GetPtrAt(int32_t index); + void RemoveLast(int32_t iCount); + + private: + bool m_bNewReload; + std::deque<FDE_TTOPIECE> m_pieces; + }; + bool RetrieveLineWidth(CFX_BreakType dwBreakStatus, float& fStartPos, float& fWidth, |