Index: fpdfsdk/cpdfsdk_annothandlermgr.cpp |
diff --git a/fpdfsdk/cpdfsdk_annothandlermgr.cpp b/fpdfsdk/cpdfsdk_annothandlermgr.cpp |
index bca2c9baa9920499ad370bb7432278f3125d036e..7772b8c108cd42089b5be5301b40678509423877 100644 |
--- a/fpdfsdk/cpdfsdk_annothandlermgr.cpp |
+++ b/fpdfsdk/cpdfsdk_annothandlermgr.cpp |
@@ -10,6 +10,7 @@ |
#include "fpdfsdk/include/cba_annotiterator.h" |
#include "fpdfsdk/include/cpdfsdk_annot.h" |
#include "fpdfsdk/include/cpdfsdk_baannot.h" |
+#include "fpdfsdk/include/cpdfsdk_baannothandler.h" |
#include "fpdfsdk/include/cpdfsdk_bfannothandler.h" |
#include "fpdfsdk/include/cpdfsdk_datetime.h" |
#include "fpdfsdk/include/fsdk_mgr.h" |
@@ -21,43 +22,22 @@ |
#include "xfa/fxfa/include/xfa_ffwidget.h" |
#endif // PDF_ENABLE_XFA |
-CPDFSDK_AnnotHandlerMgr::CPDFSDK_AnnotHandlerMgr(CPDFDoc_Environment* pApp) { |
- m_pApp = pApp; |
- |
- CPDFSDK_BFAnnotHandler* pHandler = new CPDFSDK_BFAnnotHandler(m_pApp); |
- pHandler->SetFormFiller(m_pApp->GetIFormFiller()); |
- RegisterAnnotHandler(pHandler); |
+CPDFSDK_AnnotHandlerMgr::CPDFSDK_AnnotHandlerMgr(CPDFDoc_Environment* pApp) |
+ : m_pApp(pApp), |
+ m_pBFAnnotHandler(new CPDFSDK_BFAnnotHandler(pApp)), |
#ifdef PDF_ENABLE_XFA |
- CPDFSDK_XFAAnnotHandler* pXFAAnnotHandler = |
- new CPDFSDK_XFAAnnotHandler(m_pApp); |
- RegisterAnnotHandler(pXFAAnnotHandler); |
+ m_pXFAAnnotHandler(new CPDFSDK_XFAAnnotHandler(pApp)), |
#endif // PDF_ENABLE_XFA |
+ m_pBAAnnotHandler(new CPDFSDK_BAAnnotHandler()) { |
+ m_pBFAnnotHandler->SetFormFiller(m_pApp->GetIFormFiller()); |
} |
CPDFSDK_AnnotHandlerMgr::~CPDFSDK_AnnotHandlerMgr() {} |
-void CPDFSDK_AnnotHandlerMgr::RegisterAnnotHandler( |
- IPDFSDK_AnnotHandler* pAnnotHandler) { |
- ASSERT(!GetAnnotHandler(pAnnotHandler->GetType())); |
- |
- m_mapType2Handler[pAnnotHandler->GetType()].reset(pAnnotHandler); |
-} |
- |
-void CPDFSDK_AnnotHandlerMgr::UnRegisterAnnotHandler( |
- IPDFSDK_AnnotHandler* pAnnotHandler) { |
- m_mapType2Handler.erase(pAnnotHandler->GetType()); |
-} |
- |
CPDFSDK_Annot* CPDFSDK_AnnotHandlerMgr::NewAnnot(CPDF_Annot* pAnnot, |
CPDFSDK_PageView* pPageView) { |
ASSERT(pPageView); |
- |
- if (IPDFSDK_AnnotHandler* pAnnotHandler = |
- GetAnnotHandler(pAnnot->GetSubType())) { |
- return pAnnotHandler->NewAnnot(pAnnot, pPageView); |
- } |
- |
- return new CPDFSDK_BAAnnot(pAnnot, pPageView); |
+ return GetAnnotHandler(pAnnot->GetSubType())->NewAnnot(pAnnot, pPageView); |
} |
#ifdef PDF_ENABLE_XFA |
@@ -66,22 +46,14 @@ CPDFSDK_Annot* CPDFSDK_AnnotHandlerMgr::NewAnnot(CXFA_FFWidget* pAnnot, |
ASSERT(pAnnot); |
ASSERT(pPageView); |
- if (IPDFSDK_AnnotHandler* pAnnotHandler = |
- GetAnnotHandler(FSDK_XFAWIDGET_TYPENAME)) { |
- return pAnnotHandler->NewAnnot(pAnnot, pPageView); |
- } |
- |
- return nullptr; |
+ return GetAnnotHandler(FSDK_XFAWIDGET_TYPENAME)->NewAnnot(pAnnot, pPageView); |
} |
#endif // PDF_ENABLE_XFA |
void CPDFSDK_AnnotHandlerMgr::ReleaseAnnot(CPDFSDK_Annot* pAnnot) { |
- if (IPDFSDK_AnnotHandler* pAnnotHandler = GetAnnotHandler(pAnnot)) { |
- pAnnotHandler->OnRelease(pAnnot); |
- pAnnotHandler->ReleaseAnnot(pAnnot); |
- } else { |
- delete pAnnot; |
- } |
+ IPDFSDK_AnnotHandler* pAnnotHandler = GetAnnotHandler(pAnnot); |
dsinclair
2016/08/24 14:00:20
So, previously if we didnt' find the annotation ha
jaepark
2016/08/24 18:37:49
In BAAnnotHandler, it does the same thing as befor
|
+ pAnnotHandler->OnRelease(pAnnot); |
+ pAnnotHandler->ReleaseAnnot(pAnnot); |
} |
void CPDFSDK_AnnotHandlerMgr::Annot_OnCreate(CPDFSDK_Annot* pAnnot) { |
@@ -91,33 +63,30 @@ void CPDFSDK_AnnotHandlerMgr::Annot_OnCreate(CPDFSDK_Annot* pAnnot) { |
pPDFAnnot->GetAnnotDict()->SetAtString("M", curTime.ToPDFDateTimeString()); |
pPDFAnnot->GetAnnotDict()->SetAtNumber("F", 0); |
- if (IPDFSDK_AnnotHandler* pAnnotHandler = GetAnnotHandler(pAnnot)) |
- pAnnotHandler->OnCreate(pAnnot); |
+ GetAnnotHandler(pAnnot)->OnCreate(pAnnot); |
} |
void CPDFSDK_AnnotHandlerMgr::Annot_OnLoad(CPDFSDK_Annot* pAnnot) { |
ASSERT(pAnnot); |
- |
- if (IPDFSDK_AnnotHandler* pAnnotHandler = GetAnnotHandler(pAnnot)) |
- pAnnotHandler->OnLoad(pAnnot); |
+ GetAnnotHandler(pAnnot)->OnLoad(pAnnot); |
} |
IPDFSDK_AnnotHandler* CPDFSDK_AnnotHandlerMgr::GetAnnotHandler( |
CPDFSDK_Annot* pAnnot) const { |
- CPDF_Annot* pPDFAnnot = pAnnot->GetPDFAnnot(); |
- if (pPDFAnnot) |
- return GetAnnotHandler(pPDFAnnot->GetSubType()); |
dsinclair
2016/08/24 14:00:20
This used to operate on the internal annotation an
jaepark
2016/08/24 18:37:49
The logic of GetAnnotHandler is the same.
CPDFSDK_
|
-#ifdef PDF_ENABLE_XFA |
- if (pAnnot->GetXFAWidget()) |
- return GetAnnotHandler(FSDK_XFAWIDGET_TYPENAME); |
-#endif // PDF_ENABLE_XFA |
- return nullptr; |
+ return GetAnnotHandler(pAnnot->GetType()); |
} |
IPDFSDK_AnnotHandler* CPDFSDK_AnnotHandlerMgr::GetAnnotHandler( |
const CFX_ByteString& sType) const { |
- auto it = m_mapType2Handler.find(sType); |
- return it != m_mapType2Handler.end() ? it->second.get() : nullptr; |
+ if (sType == "Widget") |
+ return m_pBFAnnotHandler.get(); |
+ |
+#ifdef PDF_ENABLE_XFA |
+ if (sType == FSDK_XFAWIDGET_TYPENAME) |
+ return m_pXFAAnnotHandler.get(); |
+#endif // PDF_ENABLE_XFA |
+ |
+ return m_pBAAnnotHandler.get(); |
} |
void CPDFSDK_AnnotHandlerMgr::Annot_OnDraw(CPDFSDK_PageView* pPageView, |
@@ -126,17 +95,8 @@ void CPDFSDK_AnnotHandlerMgr::Annot_OnDraw(CPDFSDK_PageView* pPageView, |
CFX_Matrix* pUser2Device, |
uint32_t dwFlags) { |
ASSERT(pAnnot); |
- |
- if (IPDFSDK_AnnotHandler* pAnnotHandler = GetAnnotHandler(pAnnot)) { |
- pAnnotHandler->OnDraw(pPageView, pAnnot, pDevice, pUser2Device, dwFlags); |
- } else { |
-#ifdef PDF_ENABLE_XFA |
- if (pAnnot->IsXFAField()) |
dsinclair
2016/08/24 14:00:20
We no longer need to bail early on XFA fields?
jaepark
2016/08/24 18:37:49
We handle this in BAAnnotHandler.
|
- return; |
-#endif // PDF_ENABLE_XFA |
- static_cast<CPDFSDK_BAAnnot*>(pAnnot)->DrawAppearance( |
- pDevice, pUser2Device, CPDF_Annot::Normal, nullptr); |
- } |
+ GetAnnotHandler(pAnnot)->OnDraw(pPageView, pAnnot, pDevice, pUser2Device, |
+ dwFlags); |
} |
FX_BOOL CPDFSDK_AnnotHandlerMgr::Annot_OnLButtonDown( |
@@ -145,11 +105,8 @@ FX_BOOL CPDFSDK_AnnotHandlerMgr::Annot_OnLButtonDown( |
uint32_t nFlags, |
const CFX_FloatPoint& point) { |
ASSERT(pAnnot); |
- |
- if (IPDFSDK_AnnotHandler* pAnnotHandler = GetAnnotHandler(pAnnot)) |
- return pAnnotHandler->OnLButtonDown(pPageView, pAnnot, nFlags, point); |
- |
- return FALSE; |
+ return GetAnnotHandler(pAnnot)->OnLButtonDown(pPageView, pAnnot, nFlags, |
+ point); |
} |
FX_BOOL CPDFSDK_AnnotHandlerMgr::Annot_OnLButtonUp( |
@@ -158,11 +115,7 @@ FX_BOOL CPDFSDK_AnnotHandlerMgr::Annot_OnLButtonUp( |
uint32_t nFlags, |
const CFX_FloatPoint& point) { |
ASSERT(pAnnot); |
- |
- if (IPDFSDK_AnnotHandler* pAnnotHandler = GetAnnotHandler(pAnnot)) |
- return pAnnotHandler->OnLButtonUp(pPageView, pAnnot, nFlags, point); |
- |
- return FALSE; |
+ return GetAnnotHandler(pAnnot)->OnLButtonUp(pPageView, pAnnot, nFlags, point); |
} |
FX_BOOL CPDFSDK_AnnotHandlerMgr::Annot_OnLButtonDblClk( |
@@ -171,11 +124,8 @@ FX_BOOL CPDFSDK_AnnotHandlerMgr::Annot_OnLButtonDblClk( |
uint32_t nFlags, |
const CFX_FloatPoint& point) { |
ASSERT(pAnnot); |
- |
- if (IPDFSDK_AnnotHandler* pAnnotHandler = GetAnnotHandler(pAnnot)) |
- return pAnnotHandler->OnLButtonDblClk(pPageView, pAnnot, nFlags, point); |
- |
- return FALSE; |
+ return GetAnnotHandler(pAnnot)->OnLButtonDblClk(pPageView, pAnnot, nFlags, |
+ point); |
} |
FX_BOOL CPDFSDK_AnnotHandlerMgr::Annot_OnMouseMove( |
@@ -184,11 +134,7 @@ FX_BOOL CPDFSDK_AnnotHandlerMgr::Annot_OnMouseMove( |
uint32_t nFlags, |
const CFX_FloatPoint& point) { |
ASSERT(pAnnot); |
- |
- if (IPDFSDK_AnnotHandler* pAnnotHandler = GetAnnotHandler(pAnnot)) |
- return pAnnotHandler->OnMouseMove(pPageView, pAnnot, nFlags, point); |
- |
- return FALSE; |
+ return GetAnnotHandler(pAnnot)->OnMouseMove(pPageView, pAnnot, nFlags, point); |
} |
FX_BOOL CPDFSDK_AnnotHandlerMgr::Annot_OnMouseWheel( |
@@ -198,12 +144,8 @@ FX_BOOL CPDFSDK_AnnotHandlerMgr::Annot_OnMouseWheel( |
short zDelta, |
const CFX_FloatPoint& point) { |
ASSERT(pAnnot); |
- |
- if (IPDFSDK_AnnotHandler* pAnnotHandler = GetAnnotHandler(pAnnot)) { |
- return pAnnotHandler->OnMouseWheel(pPageView, pAnnot, nFlags, zDelta, |
- point); |
- } |
- return FALSE; |
+ return GetAnnotHandler(pAnnot)->OnMouseWheel(pPageView, pAnnot, nFlags, |
+ zDelta, point); |
} |
FX_BOOL CPDFSDK_AnnotHandlerMgr::Annot_OnRButtonDown( |
@@ -212,11 +154,8 @@ FX_BOOL CPDFSDK_AnnotHandlerMgr::Annot_OnRButtonDown( |
uint32_t nFlags, |
const CFX_FloatPoint& point) { |
ASSERT(pAnnot); |
- |
- if (IPDFSDK_AnnotHandler* pAnnotHandler = GetAnnotHandler(pAnnot)) |
- return pAnnotHandler->OnRButtonDown(pPageView, pAnnot, nFlags, point); |
- |
- return FALSE; |
+ return GetAnnotHandler(pAnnot)->OnRButtonDown(pPageView, pAnnot, nFlags, |
+ point); |
} |
FX_BOOL CPDFSDK_AnnotHandlerMgr::Annot_OnRButtonUp( |
@@ -225,61 +164,48 @@ FX_BOOL CPDFSDK_AnnotHandlerMgr::Annot_OnRButtonUp( |
uint32_t nFlags, |
const CFX_FloatPoint& point) { |
ASSERT(pAnnot); |
- |
- if (IPDFSDK_AnnotHandler* pAnnotHandler = GetAnnotHandler(pAnnot)) |
- return pAnnotHandler->OnRButtonUp(pPageView, pAnnot, nFlags, point); |
- |
- return FALSE; |
+ return GetAnnotHandler(pAnnot)->OnRButtonUp(pPageView, pAnnot, nFlags, point); |
} |
void CPDFSDK_AnnotHandlerMgr::Annot_OnMouseEnter(CPDFSDK_PageView* pPageView, |
CPDFSDK_Annot* pAnnot, |
uint32_t nFlag) { |
ASSERT(pAnnot); |
- |
- if (IPDFSDK_AnnotHandler* pAnnotHandler = GetAnnotHandler(pAnnot)) |
- pAnnotHandler->OnMouseEnter(pPageView, pAnnot, nFlag); |
+ GetAnnotHandler(pAnnot)->OnMouseEnter(pPageView, pAnnot, nFlag); |
} |
void CPDFSDK_AnnotHandlerMgr::Annot_OnMouseExit(CPDFSDK_PageView* pPageView, |
CPDFSDK_Annot* pAnnot, |
uint32_t nFlag) { |
ASSERT(pAnnot); |
- |
- if (IPDFSDK_AnnotHandler* pAnnotHandler = GetAnnotHandler(pAnnot)) |
- pAnnotHandler->OnMouseExit(pPageView, pAnnot, nFlag); |
+ GetAnnotHandler(pAnnot)->OnMouseExit(pPageView, pAnnot, nFlag); |
} |
FX_BOOL CPDFSDK_AnnotHandlerMgr::Annot_OnChar(CPDFSDK_Annot* pAnnot, |
uint32_t nChar, |
uint32_t nFlags) { |
- if (IPDFSDK_AnnotHandler* pAnnotHandler = GetAnnotHandler(pAnnot)) |
- return pAnnotHandler->OnChar(pAnnot, nChar, nFlags); |
- |
- return FALSE; |
+ return GetAnnotHandler(pAnnot)->OnChar(pAnnot, nChar, nFlags); |
} |
FX_BOOL CPDFSDK_AnnotHandlerMgr::Annot_OnKeyDown(CPDFSDK_Annot* pAnnot, |
int nKeyCode, |
int nFlag) { |
- if (!m_pApp->FFI_IsCTRLKeyDown(nFlag) && !m_pApp->FFI_IsALTKeyDown(nFlag)) { |
- CPDFSDK_PageView* pPage = pAnnot->GetPageView(); |
- CPDFSDK_Annot* pFocusAnnot = pPage->GetFocusAnnot(); |
- if (pFocusAnnot && (nKeyCode == FWL_VKEY_Tab)) { |
- CPDFSDK_Annot* pNext = |
- GetNextAnnot(pFocusAnnot, !m_pApp->FFI_IsSHIFTKeyDown(nFlag)); |
- |
- if (pNext && pNext != pFocusAnnot) { |
- CPDFSDK_Document* pDocument = pPage->GetSDKDocument(); |
- pDocument->SetFocusAnnot(pNext); |
- return TRUE; |
- } |
+ if (m_pApp->FFI_IsCTRLKeyDown(nFlag) || m_pApp->FFI_IsALTKeyDown(nFlag)) |
+ return GetAnnotHandler(pAnnot)->OnKeyDown(pAnnot, nKeyCode, nFlag); |
+ |
+ CPDFSDK_PageView* pPage = pAnnot->GetPageView(); |
+ CPDFSDK_Annot* pFocusAnnot = pPage->GetFocusAnnot(); |
+ if (pFocusAnnot && (nKeyCode == FWL_VKEY_Tab)) { |
+ CPDFSDK_Annot* pNext = |
+ GetNextAnnot(pFocusAnnot, !m_pApp->FFI_IsSHIFTKeyDown(nFlag)); |
+ |
+ if (pNext && pNext != pFocusAnnot) { |
+ CPDFSDK_Document* pDocument = pPage->GetSDKDocument(); |
+ pDocument->SetFocusAnnot(pNext); |
+ return TRUE; |
} |
} |
- if (IPDFSDK_AnnotHandler* pAnnotHandler = GetAnnotHandler(pAnnot)) |
- return pAnnotHandler->OnKeyDown(pAnnot, nKeyCode, nFlag); |
- |
return FALSE; |
} |
@@ -293,24 +219,18 @@ FX_BOOL CPDFSDK_AnnotHandlerMgr::Annot_OnSetFocus(CPDFSDK_Annot* pAnnot, |
uint32_t nFlag) { |
ASSERT(pAnnot); |
- if (IPDFSDK_AnnotHandler* pAnnotHandler = GetAnnotHandler(pAnnot)) { |
- if (pAnnotHandler->OnSetFocus(pAnnot, nFlag)) { |
- CPDFSDK_PageView* pPage = pAnnot->GetPageView(); |
- pPage->GetSDKDocument(); |
- return TRUE; |
- } |
- } |
- return FALSE; |
+ if (!GetAnnotHandler(pAnnot)->OnSetFocus(pAnnot, nFlag)) |
+ return FALSE; |
+ |
+ CPDFSDK_PageView* pPage = pAnnot->GetPageView(); |
+ pPage->GetSDKDocument(); |
+ return TRUE; |
} |
FX_BOOL CPDFSDK_AnnotHandlerMgr::Annot_OnKillFocus(CPDFSDK_Annot* pAnnot, |
uint32_t nFlag) { |
ASSERT(pAnnot); |
- |
- if (IPDFSDK_AnnotHandler* pAnnotHandler = GetAnnotHandler(pAnnot)) |
- return pAnnotHandler->OnKillFocus(pAnnot, nFlag); |
- |
- return FALSE; |
+ return GetAnnotHandler(pAnnot)->OnKillFocus(pAnnot, nFlag); |
} |
#ifdef PDF_ENABLE_XFA |
@@ -334,20 +254,17 @@ CFX_FloatRect CPDFSDK_AnnotHandlerMgr::Annot_OnGetViewBBox( |
CPDFSDK_PageView* pPageView, |
CPDFSDK_Annot* pAnnot) { |
ASSERT(pAnnot); |
- if (IPDFSDK_AnnotHandler* pAnnotHandler = GetAnnotHandler(pAnnot)) |
- return pAnnotHandler->GetViewBBox(pPageView, pAnnot); |
- |
- return pAnnot->GetRect(); |
+ return GetAnnotHandler(pAnnot)->GetViewBBox(pPageView, pAnnot); |
} |
FX_BOOL CPDFSDK_AnnotHandlerMgr::Annot_OnHitTest(CPDFSDK_PageView* pPageView, |
CPDFSDK_Annot* pAnnot, |
const CFX_FloatPoint& point) { |
ASSERT(pAnnot); |
- if (IPDFSDK_AnnotHandler* pAnnotHandler = GetAnnotHandler(pAnnot)) { |
- if (pAnnotHandler->CanAnswer(pAnnot)) |
- return pAnnotHandler->HitTest(pPageView, pAnnot, point); |
- } |
+ IPDFSDK_AnnotHandler* pAnnotHandler = GetAnnotHandler(pAnnot); |
+ if (pAnnotHandler->CanAnswer(pAnnot)) |
+ return pAnnotHandler->HitTest(pPageView, pAnnot, point); |
+ |
return FALSE; |
} |