1 // Copyright 2016 PDFium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4 
5 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com
6 
7 #ifndef CORE_FPDFDOC_CPDF_VARIABLETEXT_H_
8 #define CORE_FPDFDOC_CPDF_VARIABLETEXT_H_
9 
10 #include <memory>
11 
12 #include "core/fpdfdoc/cpvt_arraytemplate.h"
13 #include "core/fpdfdoc/cpvt_floatrect.h"
14 #include "core/fpdfdoc/cpvt_line.h"
15 #include "core/fpdfdoc/cpvt_lineinfo.h"
16 #include "core/fpdfdoc/cpvt_wordplace.h"
17 #include "core/fpdfdoc/cpvt_wordrange.h"
18 #include "core/fxcrt/fx_coordinates.h"
19 #include "core/fxcrt/fx_string.h"
20 #include "core/fxcrt/fx_system.h"
21 #include "core/fxge/fx_font.h"
22 
23 class CPVT_Word;
24 class CSection;
25 class IPVT_FontMap;
26 struct CPVT_SecProps;
27 struct CPVT_Section;
28 struct CPVT_SectionInfo;
29 
30 struct CPVT_WordInfo;
31 struct CPVT_WordProps;
32 
33 #define VARIABLETEXT_HALF 0.5f
34 
35 class CPDF_VariableText {
36  public:
37   enum class ScriptType { Normal, Super, Sub };
38 
39   class Iterator {
40    public:
41     explicit Iterator(CPDF_VariableText* pVT);
42     ~Iterator();
43 
44     bool NextWord();
45     bool PrevWord();
46     bool NextLine();
47     bool PrevLine();
48     bool NextSection();
49     bool PrevSection();
50     bool SetWord(const CPVT_Word& word);
51     bool GetWord(CPVT_Word& word) const;
52     bool GetLine(CPVT_Line& line) const;
53     bool GetSection(CPVT_Section& section) const;
54     bool SetSection(const CPVT_Section& section);
55     void SetAt(int32_t nWordIndex);
56     void SetAt(const CPVT_WordPlace& place);
GetAt()57     const CPVT_WordPlace& GetAt() const { return m_CurPos; }
58 
59    private:
60     CPVT_WordPlace m_CurPos;
61     CPDF_VariableText* const m_pVT;
62   };
63 
64   class Provider {
65    public:
66     explicit Provider(IPVT_FontMap* pFontMap);
67     virtual ~Provider();
68 
69     virtual int32_t GetCharWidth(int32_t nFontIndex, uint16_t word);
70     virtual int32_t GetTypeAscent(int32_t nFontIndex);
71     virtual int32_t GetTypeDescent(int32_t nFontIndex);
72     virtual int32_t GetWordFontIndex(uint16_t word,
73                                      int32_t charset,
74                                      int32_t nFontIndex);
75     virtual bool IsLatinWord(uint16_t word);
76     virtual int32_t GetDefaultFontIndex();
77 
78    private:
79     IPVT_FontMap* const m_pFontMap;
80   };
81 
82   CPDF_VariableText();
83   ~CPDF_VariableText();
84 
85   void SetProvider(CPDF_VariableText::Provider* pProvider);
86   CPDF_VariableText::Iterator* GetIterator();
87 
88   void SetContentRect(const CPVT_FloatRect& rect);
89   CFX_FloatRect GetContentRect() const;
90   void SetPlateRect(const CFX_FloatRect& rect);
91   const CFX_FloatRect& GetPlateRect() const;
92 
SetAlignment(int32_t nFormat)93   void SetAlignment(int32_t nFormat) { m_nAlignment = nFormat; }
SetPasswordChar(uint16_t wSubWord)94   void SetPasswordChar(uint16_t wSubWord) { m_wSubWord = wSubWord; }
SetLimitChar(int32_t nLimitChar)95   void SetLimitChar(int32_t nLimitChar) { m_nLimitChar = nLimitChar; }
SetCharSpace(FX_FLOAT fCharSpace)96   void SetCharSpace(FX_FLOAT fCharSpace) { m_fCharSpace = fCharSpace; }
SetMultiLine(bool bMultiLine)97   void SetMultiLine(bool bMultiLine) { m_bMultiLine = bMultiLine; }
SetAutoReturn(bool bAuto)98   void SetAutoReturn(bool bAuto) { m_bLimitWidth = bAuto; }
SetFontSize(FX_FLOAT fFontSize)99   void SetFontSize(FX_FLOAT fFontSize) { m_fFontSize = fFontSize; }
SetCharArray(int32_t nCharArray)100   void SetCharArray(int32_t nCharArray) { m_nCharArray = nCharArray; }
SetAutoFontSize(bool bAuto)101   void SetAutoFontSize(bool bAuto) { m_bAutoFontSize = bAuto; }
102   void Initialize();
103 
IsValid()104   bool IsValid() const { return m_bInitial; }
105 
106   void RearrangeAll();
107   void RearrangePart(const CPVT_WordRange& PlaceRange);
108   void ResetAll();
109   void SetText(const CFX_WideString& text);
110   CPVT_WordPlace InsertWord(const CPVT_WordPlace& place,
111                             uint16_t word,
112                             int32_t charset,
113                             const CPVT_WordProps* pWordProps);
114   CPVT_WordPlace InsertSection(const CPVT_WordPlace& place,
115                                const CPVT_SecProps* pSecProps,
116                                const CPVT_WordProps* pWordProps);
117   CPVT_WordPlace InsertText(const CPVT_WordPlace& place, const FX_WCHAR* text);
118   CPVT_WordPlace DeleteWords(const CPVT_WordRange& PlaceRange);
119   CPVT_WordPlace DeleteWord(const CPVT_WordPlace& place);
120   CPVT_WordPlace BackSpaceWord(const CPVT_WordPlace& place);
121 
122   int32_t GetTotalWords() const;
GetFontSize()123   FX_FLOAT GetFontSize() const { return m_fFontSize; }
GetAlignment()124   int32_t GetAlignment() const { return m_nAlignment; }
GetPasswordChar()125   uint16_t GetPasswordChar() const { return GetSubWord(); }
GetCharArray()126   int32_t GetCharArray() const { return m_nCharArray; }
GetLimitChar()127   int32_t GetLimitChar() const { return m_nLimitChar; }
IsMultiLine()128   bool IsMultiLine() const { return m_bMultiLine; }
GetHorzScale()129   int32_t GetHorzScale() const { return m_nHorzScale; }
GetCharSpace()130   FX_FLOAT GetCharSpace() const { return m_fCharSpace; }
131   CPVT_WordPlace GetBeginWordPlace() const;
132   CPVT_WordPlace GetEndWordPlace() const;
133   CPVT_WordPlace GetPrevWordPlace(const CPVT_WordPlace& place) const;
134   CPVT_WordPlace GetNextWordPlace(const CPVT_WordPlace& place) const;
135   CPVT_WordPlace SearchWordPlace(const CFX_PointF& point) const;
136   CPVT_WordPlace GetUpWordPlace(const CPVT_WordPlace& place,
137                                 const CFX_PointF& point) const;
138   CPVT_WordPlace GetDownWordPlace(const CPVT_WordPlace& place,
139                                   const CFX_PointF& point) const;
140   CPVT_WordPlace GetLineBeginPlace(const CPVT_WordPlace& place) const;
141   CPVT_WordPlace GetLineEndPlace(const CPVT_WordPlace& place) const;
142   CPVT_WordPlace GetSectionBeginPlace(const CPVT_WordPlace& place) const;
143   CPVT_WordPlace GetSectionEndPlace(const CPVT_WordPlace& place) const;
144   void UpdateWordPlace(CPVT_WordPlace& place) const;
145   CPVT_WordPlace AdjustLineHeader(const CPVT_WordPlace& place,
146                                   bool bPrevOrNext) const;
147   int32_t WordPlaceToWordIndex(const CPVT_WordPlace& place) const;
148   CPVT_WordPlace WordIndexToWordPlace(int32_t index) const;
149 
GetSubWord()150   uint16_t GetSubWord() const { return m_wSubWord; }
151 
GetPlateWidth()152   FX_FLOAT GetPlateWidth() const { return m_rcPlate.right - m_rcPlate.left; }
GetPlateHeight()153   FX_FLOAT GetPlateHeight() const { return m_rcPlate.top - m_rcPlate.bottom; }
154   CFX_SizeF GetPlateSize() const;
155   CFX_PointF GetBTPoint() const;
156   CFX_PointF GetETPoint() const;
157 
158   CFX_PointF InToOut(const CFX_PointF& point) const;
159   CFX_PointF OutToIn(const CFX_PointF& point) const;
160   CFX_FloatRect InToOut(const CPVT_FloatRect& rect) const;
161   CPVT_FloatRect OutToIn(const CFX_FloatRect& rect) const;
162 
163  private:
164   friend class CTypeset;
165   friend class CSection;
166 
167   int32_t GetCharWidth(int32_t nFontIndex, uint16_t Word, uint16_t SubWord);
168   int32_t GetTypeAscent(int32_t nFontIndex);
169   int32_t GetTypeDescent(int32_t nFontIndex);
170   int32_t GetWordFontIndex(uint16_t word, int32_t charset, int32_t nFontIndex);
171   int32_t GetDefaultFontIndex();
172   bool IsLatinWord(uint16_t word);
173 
174   CPVT_WordPlace AddSection(const CPVT_WordPlace& place,
175                             const CPVT_SectionInfo& secinfo);
176   CPVT_WordPlace AddLine(const CPVT_WordPlace& place,
177                          const CPVT_LineInfo& lineinfo);
178   CPVT_WordPlace AddWord(const CPVT_WordPlace& place,
179                          const CPVT_WordInfo& wordinfo);
180   bool GetWordInfo(const CPVT_WordPlace& place, CPVT_WordInfo& wordinfo);
181   bool SetWordInfo(const CPVT_WordPlace& place, const CPVT_WordInfo& wordinfo);
182   bool GetLineInfo(const CPVT_WordPlace& place, CPVT_LineInfo& lineinfo);
183   bool GetSectionInfo(const CPVT_WordPlace& place, CPVT_SectionInfo& secinfo);
184   FX_FLOAT GetWordFontSize(const CPVT_WordInfo& WordInfo);
185   FX_FLOAT GetWordWidth(int32_t nFontIndex,
186                         uint16_t Word,
187                         uint16_t SubWord,
188                         FX_FLOAT fCharSpace,
189                         int32_t nHorzScale,
190                         FX_FLOAT fFontSize,
191                         FX_FLOAT fWordTail);
192   FX_FLOAT GetWordWidth(const CPVT_WordInfo& WordInfo);
193   FX_FLOAT GetWordAscent(const CPVT_WordInfo& WordInfo, FX_FLOAT fFontSize);
194   FX_FLOAT GetWordDescent(const CPVT_WordInfo& WordInfo, FX_FLOAT fFontSize);
195   FX_FLOAT GetWordAscent(const CPVT_WordInfo& WordInfo);
196   FX_FLOAT GetWordDescent(const CPVT_WordInfo& WordInfo);
197   FX_FLOAT GetLineAscent(const CPVT_SectionInfo& SecInfo);
198   FX_FLOAT GetLineDescent(const CPVT_SectionInfo& SecInfo);
199   FX_FLOAT GetFontAscent(int32_t nFontIndex, FX_FLOAT fFontSize);
200   FX_FLOAT GetFontDescent(int32_t nFontIndex, FX_FLOAT fFontSize);
201   int32_t GetWordFontIndex(const CPVT_WordInfo& WordInfo);
202   FX_FLOAT GetCharSpace(const CPVT_WordInfo& WordInfo);
203   int32_t GetHorzScale(const CPVT_WordInfo& WordInfo);
204   FX_FLOAT GetLineLeading(const CPVT_SectionInfo& SecInfo);
205   FX_FLOAT GetLineIndent(const CPVT_SectionInfo& SecInfo);
206   int32_t GetAlignment(const CPVT_SectionInfo& SecInfo);
207 
208   void ClearSectionRightWords(const CPVT_WordPlace& place);
209 
210   bool ClearEmptySection(const CPVT_WordPlace& place);
211   void ClearEmptySections(const CPVT_WordRange& PlaceRange);
212   void LinkLatterSection(const CPVT_WordPlace& place);
213   void ClearWords(const CPVT_WordRange& PlaceRange);
214   CPVT_WordPlace ClearLeftWord(const CPVT_WordPlace& place);
215   CPVT_WordPlace ClearRightWord(const CPVT_WordPlace& place);
216 
217   CPVT_FloatRect Rearrange(const CPVT_WordRange& PlaceRange);
218   FX_FLOAT GetAutoFontSize();
219   bool IsBigger(FX_FLOAT fFontSize) const;
220   CPVT_FloatRect RearrangeSections(const CPVT_WordRange& PlaceRange);
221 
222   void ResetSectionArray();
223 
224   CPVT_ArrayTemplate<CSection*> m_SectionArray;
225   int32_t m_nLimitChar;
226   int32_t m_nCharArray;
227   bool m_bMultiLine;
228   bool m_bLimitWidth;
229   bool m_bAutoFontSize;
230   int32_t m_nAlignment;
231   FX_FLOAT m_fLineLeading;
232   FX_FLOAT m_fCharSpace;
233   int32_t m_nHorzScale;
234   uint16_t m_wSubWord;
235   FX_FLOAT m_fFontSize;
236   bool m_bInitial;
237   CPDF_VariableText::Provider* m_pVTProvider;
238   std::unique_ptr<CPDF_VariableText::Iterator> m_pVTIterator;
239   CFX_FloatRect m_rcPlate;
240   CPVT_FloatRect m_rcContent;
241 };
242 
243 #endif  // CORE_FPDFDOC_CPDF_VARIABLETEXT_H_
244