Chromium Code Reviews| Index: core/fpdfapi/fpdf_page/cpdf_textstate.cpp |
| diff --git a/core/fpdfapi/fpdf_page/cpdf_textstate.cpp b/core/fpdfapi/fpdf_page/cpdf_textstate.cpp |
| index ae758766645a3dd8829c66f68f859ae3db09b5fc..425cbb91a3ff9222cac809a9f291f4fa54124339 100644 |
| --- a/core/fpdfapi/fpdf_page/cpdf_textstate.cpp |
| +++ b/core/fpdfapi/fpdf_page/cpdf_textstate.cpp |
| @@ -9,40 +9,81 @@ |
| #include "core/fpdfapi/fpdf_page/pageint.h" |
| #include "core/fpdfapi/fpdf_parser/include/cpdf_document.h" |
| +CPDF_TextState::CPDF_TextState() {} |
| +CPDF_TextState::~CPDF_TextState() {} |
| + |
| +void CPDF_TextState::New() { |
|
dsinclair
2016/08/30 13:36:10
Can we call this Initialize()? Or, something other
Tom Sepez
2016/08/30 16:59:48
The way I'm thinking about these is that they are
|
| + m_Ref.New(); |
| +} |
| + |
| +CPDF_Font* CPDF_TextState::GetFont() const { |
| + return m_Ref.GetObject()->m_pFont; |
| +} |
| + |
| void CPDF_TextState::SetFont(CPDF_Font* pFont) { |
| - CPDF_TextStateData* pStateData = GetPrivateCopy(); |
| - if (pStateData) { |
| - CPDF_Document* pDoc = pStateData->m_pDocument; |
| - CPDF_DocPageData* pPageData = pDoc ? pDoc->GetPageData() : nullptr; |
| - if (pPageData && pStateData->m_pFont && !pPageData->IsForceClear()) { |
| - pPageData->ReleaseFont(pStateData->m_pFont->GetFontDict()); |
| - } |
| - pStateData->m_pDocument = pFont ? pFont->m_pDocument : nullptr; |
| - pStateData->m_pFont = pFont; |
| - } |
| + m_Ref.GetPrivateCopy()->SetFont(pFont); |
| +} |
| + |
| +FX_FLOAT CPDF_TextState::GetFontSize() const { |
| + return m_Ref.GetObject()->m_FontSize; |
| +} |
| + |
| +void CPDF_TextState::SetFontSize(FX_FLOAT size) { |
| + m_Ref.GetPrivateCopy()->m_FontSize = size; |
| +} |
| + |
| +const FX_FLOAT* CPDF_TextState::GetMatrix() const { |
| + return m_Ref.GetObject()->m_Matrix; |
| +} |
| + |
| +FX_FLOAT* CPDF_TextState::GetMutableMatrix() { |
| + return m_Ref.GetPrivateCopy()->m_Matrix; |
| +} |
| + |
| +FX_FLOAT CPDF_TextState::GetCharSpace() const { |
| + return m_Ref.GetObject()->m_CharSpace; |
| +} |
| + |
| +void CPDF_TextState::SetCharSpace(FX_FLOAT sp) { |
| + m_Ref.GetPrivateCopy()->m_CharSpace = sp; |
| +} |
| + |
| +FX_FLOAT CPDF_TextState::GetWordSpace() const { |
| + return m_Ref.GetObject()->m_WordSpace; |
| +} |
| + |
| +void CPDF_TextState::SetWordSpace(FX_FLOAT sp) { |
| + m_Ref.GetPrivateCopy()->m_WordSpace = sp; |
| } |
| FX_FLOAT CPDF_TextState::GetFontSizeV() const { |
| - const FX_FLOAT* pMatrix = GetMatrix(); |
| - FX_FLOAT unit = FXSYS_sqrt2(pMatrix[1], pMatrix[3]); |
| - FX_FLOAT size = unit * GetFontSize(); |
| - return (FX_FLOAT)FXSYS_fabs(size); |
| + return m_Ref.GetObject()->GetFontSizeV(); |
| } |
| FX_FLOAT CPDF_TextState::GetFontSizeH() const { |
| - const FX_FLOAT* pMatrix = GetMatrix(); |
| - FX_FLOAT unit = FXSYS_sqrt2(pMatrix[0], pMatrix[2]); |
| - FX_FLOAT size = unit * GetFontSize(); |
| - return (FX_FLOAT)FXSYS_fabs(size); |
| + return m_Ref.GetObject()->GetFontSizeH(); |
| } |
| FX_FLOAT CPDF_TextState::GetBaselineAngle() const { |
| - const FX_FLOAT* m_Matrix = GetMatrix(); |
| - return FXSYS_atan2(m_Matrix[2], m_Matrix[0]); |
| + return m_Ref.GetObject()->GetBaselineAngle(); |
| } |
| FX_FLOAT CPDF_TextState::GetShearAngle() const { |
| - const FX_FLOAT* m_Matrix = GetMatrix(); |
| - FX_FLOAT shear_angle = FXSYS_atan2(m_Matrix[1], m_Matrix[3]); |
| - return GetBaselineAngle() + shear_angle; |
| + return m_Ref.GetObject()->GetShearAngle(); |
| +} |
| + |
| +TextRenderingMode CPDF_TextState::GetTextMode() const { |
| + return m_Ref.GetObject()->m_TextMode; |
| +} |
| + |
| +void CPDF_TextState::SetTextMode(TextRenderingMode mode) { |
| + m_Ref.GetPrivateCopy()->m_TextMode = mode; |
| +} |
| + |
| +const FX_FLOAT* CPDF_TextState::GetCTM() const { |
| + return m_Ref.GetObject()->m_CTM; |
| +} |
| + |
| +FX_FLOAT* CPDF_TextState::GetMutableCTM() { |
| + return m_Ref.GetPrivateCopy()->m_CTM; |
| } |