| Index: xfa/fwl/basewidget/fwl_caretimp.cpp
|
| diff --git a/xfa/fwl/basewidget/fwl_caretimp.cpp b/xfa/fwl/basewidget/fwl_caretimp.cpp
|
| index c67c0c4291ecbff66b20ff4c395c5a1f1801d931..dbe8e50bc2c4c41572b2f3e1f5038327f46c4924 100644
|
| --- a/xfa/fwl/basewidget/fwl_caretimp.cpp
|
| +++ b/xfa/fwl/basewidget/fwl_caretimp.cpp
|
| @@ -38,7 +38,7 @@ FWL_Error IFWL_Caret::SetColor(CFX_Color crFill) {
|
| CFWL_CaretImp::CFWL_CaretImp(const CFWL_WidgetImpProperties& properties,
|
| IFWL_Widget* pOuter)
|
| : CFWL_WidgetImp(properties, pOuter),
|
| - m_hTimer(nullptr),
|
| + m_pTimerInfo(nullptr),
|
| m_dwElapse(400),
|
| m_bSetColor(FALSE) {
|
| m_pTimer = new CFWL_CaretTimer(this);
|
| @@ -67,9 +67,9 @@ FWL_Error CFWL_CaretImp::Initialize() {
|
| }
|
|
|
| FWL_Error CFWL_CaretImp::Finalize() {
|
| - if (m_hTimer) {
|
| - FWL_StopTimer(m_hTimer);
|
| - m_hTimer = NULL;
|
| + if (m_pTimerInfo) {
|
| + m_pTimerInfo->StopTimer();
|
| + m_pTimerInfo = nullptr;
|
| }
|
| delete m_pDelegate;
|
| m_pDelegate = nullptr;
|
| @@ -89,12 +89,12 @@ FWL_Error CFWL_CaretImp::DrawWidget(CFX_Graphics* pGraphics,
|
| }
|
|
|
| void CFWL_CaretImp::ShowCaret(FX_BOOL bFlag) {
|
| - if (m_hTimer) {
|
| - FWL_StopTimer(m_hTimer);
|
| - m_hTimer = nullptr;
|
| + if (m_pTimerInfo) {
|
| + m_pTimerInfo->StopTimer();
|
| + m_pTimerInfo = nullptr;
|
| }
|
| if (bFlag)
|
| - m_hTimer = FWL_StartTimer(m_pTimer, m_dwElapse);
|
| + m_pTimerInfo = m_pTimer->StartTimer(m_dwElapse, true);
|
|
|
| SetStates(FWL_WGTSTATE_Invisible, !bFlag);
|
| }
|
| @@ -138,17 +138,14 @@ void CFWL_CaretImp::DrawCaretBK(CFX_Graphics* pGraphics,
|
| CFWL_CaretImp::CFWL_CaretTimer::CFWL_CaretTimer(CFWL_CaretImp* pCaret)
|
| : m_pCaret(pCaret) {}
|
|
|
| -int32_t CFWL_CaretImp::CFWL_CaretTimer::Run(FWL_HTIMER hTimer) {
|
| - if (m_pCaret->GetStates() & FWL_STATE_CAT_HightLight) {
|
| - m_pCaret->SetStates(FWL_STATE_CAT_HightLight, FALSE);
|
| - } else {
|
| - m_pCaret->SetStates(FWL_STATE_CAT_HightLight);
|
| - }
|
| +void CFWL_CaretImp::CFWL_CaretTimer::Run(IFWL_TimerInfo* pTimerInfo) {
|
| + bool toggle = !(m_pCaret->GetStates() & FWL_STATE_CAT_HightLight);
|
| + m_pCaret->SetStates(FWL_STATE_CAT_HightLight, toggle);
|
| +
|
| CFX_RectF rt;
|
| m_pCaret->GetWidgetRect(rt);
|
| rt.Set(0, 0, rt.width + 1, rt.height);
|
| m_pCaret->Repaint(&rt);
|
| - return 1;
|
| }
|
|
|
| CFWL_CaretImpDelegate::CFWL_CaretImpDelegate(CFWL_CaretImp* pOwner)
|
|
|