| // Copyright 2016 PDFium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com |
| |
| #ifndef CORE_FPDFDOC_CPDF_ANNOT_H_ |
| #define CORE_FPDFDOC_CPDF_ANNOT_H_ |
| |
| #include <map> |
| #include <memory> |
| |
| #include "core/fxcrt/fx_coordinates.h" |
| #include "core/fxcrt/fx_string.h" |
| #include "core/fxcrt/fx_system.h" |
| #include "core/fxcrt/maybe_owned.h" |
| #include "core/fxcrt/unowned_ptr.h" |
| |
| class CFX_RenderDevice; |
| class CPDF_Array; |
| class CPDF_Dictionary; |
| class CPDF_Document; |
| class CPDF_Form; |
| class CPDF_Page; |
| class CPDF_RenderContext; |
| class CPDF_RenderOptions; |
| class CPDF_Stream; |
| |
| class CPDF_Annot { |
| public: |
| enum AppearanceMode { Normal, Rollover, Down }; |
| enum class Subtype { |
| UNKNOWN = 0, |
| TEXT, |
| LINK, |
| FREETEXT, |
| LINE, |
| SQUARE, |
| CIRCLE, |
| POLYGON, |
| POLYLINE, |
| HIGHLIGHT, |
| UNDERLINE, |
| SQUIGGLY, |
| STRIKEOUT, |
| STAMP, |
| CARET, |
| INK, |
| POPUP, |
| FILEATTACHMENT, |
| SOUND, |
| MOVIE, |
| WIDGET, |
| SCREEN, |
| PRINTERMARK, |
| TRAPNET, |
| WATERMARK, |
| THREED, |
| RICHMEDIA, |
| XFAWIDGET, |
| REDACT |
| }; |
| |
| static CPDF_Annot::Subtype StringToAnnotSubtype(const ByteString& sSubtype); |
| static ByteString AnnotSubtypeToString(CPDF_Annot::Subtype nSubtype); |
| static CFX_FloatRect RectFromQuadPointsArray(const CPDF_Array* pArray, |
| size_t nIndex); |
| static CFX_FloatRect BoundingRectFromQuadPoints( |
| const CPDF_Dictionary* pAnnotDict); |
| static CFX_FloatRect RectFromQuadPoints(const CPDF_Dictionary* pAnnotDict, |
| size_t nIndex); |
| static size_t QuadPointCount(const CPDF_Array* pArray); |
| |
| // The second constructor does not take ownership of the dictionary. |
| CPDF_Annot(RetainPtr<CPDF_Dictionary> pDict, CPDF_Document* pDocument); |
| CPDF_Annot(CPDF_Dictionary* pDict, CPDF_Document* pDocument); |
| ~CPDF_Annot(); |
| |
| CPDF_Annot::Subtype GetSubtype() const; |
| uint32_t GetFlags() const; |
| CFX_FloatRect GetRect() const; |
| CPDF_Document* GetDocument() const { return m_pDocument.Get(); } |
| const CPDF_Dictionary* GetAnnotDict() const { return m_pAnnotDict.Get(); } |
| CPDF_Dictionary* GetAnnotDict() { return m_pAnnotDict.Get(); } |
| |
| bool IsHidden() const; |
| |
| bool DrawAppearance(CPDF_Page* pPage, |
| CFX_RenderDevice* pDevice, |
| const CFX_Matrix& mtUser2Device, |
| AppearanceMode mode, |
| const CPDF_RenderOptions* pOptions); |
| bool DrawInContext(const CPDF_Page* pPage, |
| CPDF_RenderContext* pContext, |
| const CFX_Matrix* pUser2Device, |
| AppearanceMode mode); |
| |
| void ClearCachedAP(); |
| void DrawBorder(CFX_RenderDevice* pDevice, |
| const CFX_Matrix* pUser2Device, |
| const CPDF_RenderOptions* pOptions); |
| CPDF_Form* GetAPForm(const CPDF_Page* pPage, AppearanceMode mode); |
| void SetOpenState(bool bOpenState) { m_bOpenState = bOpenState; } |
| CPDF_Annot* GetPopupAnnot() const { return m_pPopupAnnot.Get(); } |
| void SetPopupAnnot(CPDF_Annot* pAnnot) { m_pPopupAnnot = pAnnot; } |
| |
| private: |
| void Init(); |
| void GenerateAPIfNeeded(); |
| bool ShouldGenerateAP() const; |
| bool ShouldDrawAnnotation() const; |
| |
| CFX_FloatRect RectForDrawing() const; |
| |
| RetainPtr<CPDF_Dictionary> const m_pAnnotDict; |
| UnownedPtr<CPDF_Document> const m_pDocument; |
| CPDF_Annot::Subtype m_nSubtype; |
| std::map<CPDF_Stream*, std::unique_ptr<CPDF_Form>> m_APMap; |
| // If non-null, then this is not a popup annotation. |
| UnownedPtr<CPDF_Annot> m_pPopupAnnot; |
| // |m_bOpenState| is only set for popup annotations. |
| bool m_bOpenState = false; |
| bool m_bHasGeneratedAP; |
| bool m_bIsTextMarkupAnnotation; |
| }; |
| |
| // Get the AP in an annotation dict for a given appearance mode. |
| // If |eMode| is not Normal and there is not AP for that mode, falls back to |
| // the Normal AP. |
| CPDF_Stream* GetAnnotAP(CPDF_Dictionary* pAnnotDict, |
| CPDF_Annot::AppearanceMode eMode); |
| |
| // Get the AP in an annotation dict for a given appearance mode. |
| // No fallbacks to Normal like in GetAnnotAP. |
| CPDF_Stream* GetAnnotAPNoFallback(CPDF_Dictionary* pAnnotDict, |
| CPDF_Annot::AppearanceMode eMode); |
| |
| #endif // CORE_FPDFDOC_CPDF_ANNOT_H_ |