| Index: xfa/fwl/core/ifwl_combobox.cpp
|
| diff --git a/xfa/fwl/basewidget/fwl_comboboximp.cpp b/xfa/fwl/core/ifwl_combobox.cpp
|
| similarity index 61%
|
| rename from xfa/fwl/basewidget/fwl_comboboximp.cpp
|
| rename to xfa/fwl/core/ifwl_combobox.cpp
|
| index e586055c3bee17254cff131443ff5e74022a97e4..6a4c13f4a624f7c60db5b62b83e4a38c7a26f902 100644
|
| --- a/xfa/fwl/basewidget/fwl_comboboximp.cpp
|
| +++ b/xfa/fwl/core/ifwl_combobox.cpp
|
| @@ -4,473 +4,31 @@
|
|
|
| // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com
|
|
|
| -#include "xfa/fwl/basewidget/fwl_comboboximp.h"
|
| +#include "xfa/fwl/core/ifwl_combobox.h"
|
|
|
| #include "xfa/fde/cfde_txtedtengine.h"
|
| #include "xfa/fde/tto/fde_textout.h"
|
| -#include "xfa/fwl/basewidget/fwl_editimp.h"
|
| -#include "xfa/fwl/basewidget/fwl_formproxyimp.h"
|
| -#include "xfa/fwl/basewidget/fwl_listboximp.h"
|
| -#include "xfa/fwl/basewidget/fwl_scrollbarimp.h"
|
| #include "xfa/fwl/core/cfwl_message.h"
|
| #include "xfa/fwl/core/cfwl_themebackground.h"
|
| #include "xfa/fwl/core/cfwl_themepart.h"
|
| #include "xfa/fwl/core/cfwl_themetext.h"
|
| #include "xfa/fwl/core/cfwl_widgetmgr.h"
|
| -#include "xfa/fwl/core/fwl_formimp.h"
|
| #include "xfa/fwl/core/fwl_noteimp.h"
|
| -#include "xfa/fwl/core/fwl_widgetimp.h"
|
| #include "xfa/fwl/core/ifwl_app.h"
|
| +#include "xfa/fwl/core/ifwl_comboedit.h"
|
| +#include "xfa/fwl/core/ifwl_combolist.h"
|
| +#include "xfa/fwl/core/ifwl_formproxy.h"
|
| #include "xfa/fwl/core/ifwl_themeprovider.h"
|
|
|
| // static
|
| IFWL_ComboBox* IFWL_ComboBox::Create(
|
| const CFWL_WidgetImpProperties& properties) {
|
| - IFWL_ComboBox* pComboBox = new IFWL_ComboBox;
|
| - CFWL_ComboBoxImp* pComboBoxImpl = new CFWL_ComboBoxImp(properties, nullptr);
|
| - pComboBox->SetImpl(pComboBoxImpl);
|
| - pComboBoxImpl->SetInterface(pComboBox);
|
| - return pComboBox;
|
| -}
|
| -IFWL_ComboBox::IFWL_ComboBox() {}
|
| -int32_t IFWL_ComboBox::GetCurSel() {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->GetCurSel();
|
| -}
|
| -FWL_Error IFWL_ComboBox::SetCurSel(int32_t iSel) {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->SetCurSel(iSel);
|
| -}
|
| -FWL_Error IFWL_ComboBox::SetEditText(const CFX_WideString& wsText) {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->SetEditText(wsText);
|
| -}
|
| -int32_t IFWL_ComboBox::GetEditTextLength() const {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->GetEditTextLength();
|
| -}
|
| -FWL_Error IFWL_ComboBox::GetEditText(CFX_WideString& wsText,
|
| - int32_t nStart,
|
| - int32_t nCount) const {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())
|
| - ->GetEditText(wsText, nStart, nCount);
|
| -}
|
| -FWL_Error IFWL_ComboBox::SetEditSelRange(int32_t nStart, int32_t nCount) {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())
|
| - ->SetEditSelRange(nStart, nCount);
|
| -}
|
| -int32_t IFWL_ComboBox::GetEditSelRange(int32_t nIndex, int32_t& nStart) {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())
|
| - ->GetEditSelRange(nIndex, nStart);
|
| -}
|
| -int32_t IFWL_ComboBox::GetEditLimit() {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->GetEditLimit();
|
| -}
|
| -FWL_Error IFWL_ComboBox::SetEditLimit(int32_t nLimit) {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->SetEditLimit(nLimit);
|
| -}
|
| -FWL_Error IFWL_ComboBox::EditDoClipboard(int32_t iCmd) {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->EditDoClipboard(iCmd);
|
| -}
|
| -FX_BOOL IFWL_ComboBox::EditRedo(const IFDE_TxtEdtDoRecord* pRecord) {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->EditRedo(pRecord);
|
| -}
|
| -FX_BOOL IFWL_ComboBox::EditUndo(const IFDE_TxtEdtDoRecord* pRecord) {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->EditUndo(pRecord);
|
| -}
|
| -IFWL_ListBox* IFWL_ComboBox::GetListBoxt() {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->GetListBoxt();
|
| -}
|
| -FX_BOOL IFWL_ComboBox::AfterFocusShowDropList() {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->AfterFocusShowDropList();
|
| -}
|
| -FWL_Error IFWL_ComboBox::OpenDropDownList(FX_BOOL bActivate) {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->OpenDropDownList(bActivate);
|
| -}
|
| -FX_BOOL IFWL_ComboBox::EditCanUndo() {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->EditCanUndo();
|
| -}
|
| -FX_BOOL IFWL_ComboBox::EditCanRedo() {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->EditCanRedo();
|
| -}
|
| -FX_BOOL IFWL_ComboBox::EditUndo() {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->EditUndo();
|
| -}
|
| -FX_BOOL IFWL_ComboBox::EditRedo() {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->EditRedo();
|
| -}
|
| -FX_BOOL IFWL_ComboBox::EditCanCopy() {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->EditCanCopy();
|
| -}
|
| -FX_BOOL IFWL_ComboBox::EditCanCut() {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->EditCanCut();
|
| -}
|
| -FX_BOOL IFWL_ComboBox::EditCanSelectAll() {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->EditCanSelectAll();
|
| -}
|
| -FX_BOOL IFWL_ComboBox::EditCopy(CFX_WideString& wsCopy) {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->EditCopy(wsCopy);
|
| -}
|
| -FX_BOOL IFWL_ComboBox::EditCut(CFX_WideString& wsCut) {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->EditCut(wsCut);
|
| -}
|
| -FX_BOOL IFWL_ComboBox::EditPaste(const CFX_WideString& wsPaste) {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->EditPaste(wsPaste);
|
| -}
|
| -FX_BOOL IFWL_ComboBox::EditSelectAll() {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->EditSelectAll();
|
| -}
|
| -FX_BOOL IFWL_ComboBox::EditDelete() {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->EditDelete();
|
| -}
|
| -FX_BOOL IFWL_ComboBox::EditDeSelect() {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->EditDeSelect();
|
| -}
|
| -FWL_Error IFWL_ComboBox::GetBBox(CFX_RectF& rect) {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())->GetBBox(rect);
|
| -}
|
| -FWL_Error IFWL_ComboBox::EditModifyStylesEx(uint32_t dwStylesExAdded,
|
| - uint32_t dwStylesExRemoved) {
|
| - return static_cast<CFWL_ComboBoxImp*>(GetImpl())
|
| - ->EditModifyStylesEx(dwStylesExAdded, dwStylesExRemoved);
|
| -}
|
| -
|
| -CFWL_ComboEditImp::CFWL_ComboEditImp(const CFWL_WidgetImpProperties& properties,
|
| - IFWL_Widget* pOuter)
|
| - : CFWL_EditImp(properties, pOuter) {
|
| - m_pOuter = static_cast<CFWL_ComboBoxImp*>(pOuter->GetImpl());
|
| -}
|
| -
|
| -CFWL_ComboEditImpDelegate::CFWL_ComboEditImpDelegate(CFWL_ComboEditImp* pOwner)
|
| - : CFWL_EditImpDelegate(pOwner), m_pOwner(pOwner) {}
|
| -
|
| -void CFWL_ComboEditImpDelegate::OnProcessMessage(CFWL_Message* pMessage) {
|
| - if (!pMessage)
|
| - return;
|
| -
|
| - FX_BOOL backDefault = TRUE;
|
| - switch (pMessage->GetClassID()) {
|
| - case CFWL_MessageType::SetFocus: {
|
| - m_pOwner->m_pProperties->m_dwStates |= FWL_WGTSTATE_Focused;
|
| - backDefault = FALSE;
|
| - break;
|
| - }
|
| - case CFWL_MessageType::KillFocus: {
|
| - m_pOwner->m_pProperties->m_dwStates &= ~FWL_WGTSTATE_Focused;
|
| - backDefault = FALSE;
|
| - break;
|
| - }
|
| - case CFWL_MessageType::Mouse: {
|
| - CFWL_MsgMouse* pMsg = static_cast<CFWL_MsgMouse*>(pMessage);
|
| - if ((pMsg->m_dwCmd == FWL_MouseCommand::LeftButtonDown) &&
|
| - ((m_pOwner->m_pProperties->m_dwStates & FWL_WGTSTATE_Focused) == 0)) {
|
| - m_pOwner->SetSelected();
|
| - m_pOwner->SetComboBoxFocus(TRUE);
|
| - }
|
| - break;
|
| - }
|
| - default:
|
| - break;
|
| - }
|
| - if (backDefault)
|
| - CFWL_EditImpDelegate::OnProcessMessage(pMessage);
|
| -}
|
| -
|
| -void CFWL_ComboEditImp::ClearSelected() {
|
| - ClearSelections();
|
| - Repaint(&m_rtClient);
|
| -}
|
| -void CFWL_ComboEditImp::SetSelected() {
|
| - FlagFocus(TRUE);
|
| - EndCaret();
|
| - AddSelRange(0);
|
| -}
|
| -void CFWL_ComboEditImp::EndCaret() {
|
| - m_pEdtEngine->MoveCaretPos(MC_End);
|
| -}
|
| -void CFWL_ComboEditImp::FlagFocus(FX_BOOL bSet) {
|
| - if (bSet) {
|
| - m_pProperties->m_dwStates |= FWL_WGTSTATE_Focused;
|
| - } else {
|
| - m_pProperties->m_dwStates &= ~FWL_WGTSTATE_Focused;
|
| - ShowCaret(FALSE);
|
| - }
|
| -}
|
| -void CFWL_ComboEditImp::SetComboBoxFocus(FX_BOOL bSet) {
|
| - m_pOuter->SetFocus(bSet);
|
| -}
|
| -CFWL_ComboListImp::CFWL_ComboListImp(const CFWL_WidgetImpProperties& properties,
|
| - IFWL_Widget* pOuter)
|
| - : CFWL_ListBoxImp(properties, pOuter), m_bNotifyOwner(TRUE) {
|
| - ASSERT(pOuter);
|
| -}
|
| -FWL_Error CFWL_ComboListImp::Initialize() {
|
| - if (CFWL_ListBoxImp::Initialize() != FWL_Error::Succeeded)
|
| - return FWL_Error::Indefinite;
|
| - delete m_pDelegate;
|
| - m_pDelegate = new CFWL_ComboListImpDelegate(this);
|
| - return FWL_Error::Succeeded;
|
| -}
|
| -FWL_Error CFWL_ComboListImp::Finalize() {
|
| - delete m_pDelegate;
|
| - m_pDelegate = nullptr;
|
| - return CFWL_ListBoxImp::Finalize();
|
| -}
|
| -int32_t CFWL_ComboListImp::MatchItem(const CFX_WideString& wsMatch) {
|
| - if (wsMatch.IsEmpty()) {
|
| - return -1;
|
| - }
|
| - if (!m_pProperties->m_pDataProvider)
|
| - return -1;
|
| - IFWL_ListBoxDP* pData =
|
| - static_cast<IFWL_ListBoxDP*>(m_pProperties->m_pDataProvider);
|
| - int32_t iCount = pData->CountItems(m_pInterface);
|
| - for (int32_t i = 0; i < iCount; i++) {
|
| - IFWL_ListItem* hItem = pData->GetItem(m_pInterface, i);
|
| - CFX_WideString wsText;
|
| - pData->GetItemText(m_pInterface, hItem, wsText);
|
| - FX_STRSIZE pos = wsText.Find(wsMatch.c_str());
|
| - if (!pos) {
|
| - return i;
|
| - }
|
| - }
|
| - return -1;
|
| -}
|
| -void CFWL_ComboListImp::ChangeSelected(int32_t iSel) {
|
| - if (!m_pProperties->m_pDataProvider)
|
| - return;
|
| - IFWL_ListBoxDP* pData =
|
| - static_cast<IFWL_ListBoxDP*>(m_pProperties->m_pDataProvider);
|
| - IFWL_ListItem* hItem = pData->GetItem(m_pInterface, iSel);
|
| - CFX_RectF rtInvalidate;
|
| - rtInvalidate.Reset();
|
| - IFWL_ListItem* hOld = GetSelItem(0);
|
| - int32_t iOld = pData->GetItemIndex(m_pInterface, hOld);
|
| - if (iOld == iSel) {
|
| - return;
|
| - } else if (iOld > -1) {
|
| - GetItemRect(iOld, rtInvalidate);
|
| - SetSelItem(hOld, FALSE);
|
| - }
|
| - if (hItem) {
|
| - CFX_RectF rect;
|
| - GetItemRect(iSel, rect);
|
| - rtInvalidate.Union(rect);
|
| - IFWL_ListItem* hSel = pData->GetItem(m_pInterface, iSel);
|
| - SetSelItem(hSel, TRUE);
|
| - }
|
| - if (!rtInvalidate.IsEmpty()) {
|
| - Repaint(&rtInvalidate);
|
| - }
|
| -}
|
| -int32_t CFWL_ComboListImp::CountItems() {
|
| - IFWL_ListBoxDP* pData =
|
| - static_cast<IFWL_ListBoxDP*>(m_pProperties->m_pDataProvider);
|
| - return pData ? pData->CountItems(m_pInterface) : 0;
|
| -}
|
| -void CFWL_ComboListImp::GetItemRect(int32_t nIndex, CFX_RectF& rtItem) {
|
| - IFWL_ListBoxDP* pData =
|
| - static_cast<IFWL_ListBoxDP*>(m_pProperties->m_pDataProvider);
|
| - IFWL_ListItem* hItem = pData->GetItem(m_pInterface, nIndex);
|
| - pData->GetItemRect(m_pInterface, hItem, rtItem);
|
| -}
|
| -void CFWL_ComboListImp::ClientToOuter(FX_FLOAT& fx, FX_FLOAT& fy) {
|
| - fx += m_pProperties->m_rtWidget.left, fy += m_pProperties->m_rtWidget.top;
|
| - IFWL_Widget* pOwner = GetOwner();
|
| - if (!pOwner)
|
| - return;
|
| - pOwner->TransformTo(m_pOuter, fx, fy);
|
| -}
|
| -void CFWL_ComboListImp::SetFocus(FX_BOOL bSet) {
|
| - CFWL_WidgetImp::SetFocus(bSet);
|
| -}
|
| -
|
| -CFWL_ComboListImpDelegate::CFWL_ComboListImpDelegate(CFWL_ComboListImp* pOwner)
|
| - : CFWL_ListBoxImpDelegate(pOwner), m_pOwner(pOwner) {}
|
| -
|
| -void CFWL_ComboListImpDelegate::OnProcessMessage(CFWL_Message* pMessage) {
|
| - if (!pMessage)
|
| - return;
|
| -
|
| - CFWL_MessageType dwHashCode = pMessage->GetClassID();
|
| - FX_BOOL backDefault = TRUE;
|
| - if (dwHashCode == CFWL_MessageType::SetFocus ||
|
| - dwHashCode == CFWL_MessageType::KillFocus) {
|
| - OnDropListFocusChanged(pMessage, dwHashCode == CFWL_MessageType::SetFocus);
|
| - } else if (dwHashCode == CFWL_MessageType::Mouse) {
|
| - CFWL_MsgMouse* pMsg = static_cast<CFWL_MsgMouse*>(pMessage);
|
| - if (m_pOwner->IsShowScrollBar(TRUE) && m_pOwner->m_pVertScrollBar) {
|
| - CFX_RectF rect;
|
| - m_pOwner->m_pVertScrollBar->GetWidgetRect(rect);
|
| - if (rect.Contains(pMsg->m_fx, pMsg->m_fy)) {
|
| - pMsg->m_fx -= rect.left;
|
| - pMsg->m_fy -= rect.top;
|
| - IFWL_WidgetDelegate* pDelegate =
|
| - m_pOwner->m_pVertScrollBar->SetDelegate(nullptr);
|
| - pDelegate->OnProcessMessage(pMsg);
|
| - return;
|
| - }
|
| - }
|
| - switch (pMsg->m_dwCmd) {
|
| - case FWL_MouseCommand::Move: {
|
| - backDefault = FALSE;
|
| - OnDropListMouseMove(pMsg);
|
| - break;
|
| - }
|
| - case FWL_MouseCommand::LeftButtonDown: {
|
| - backDefault = FALSE;
|
| - OnDropListLButtonDown(pMsg);
|
| - break;
|
| - }
|
| - case FWL_MouseCommand::LeftButtonUp: {
|
| - backDefault = FALSE;
|
| - OnDropListLButtonUp(pMsg);
|
| - break;
|
| - }
|
| - default:
|
| - break;
|
| - }
|
| - } else if (dwHashCode == CFWL_MessageType::Key) {
|
| - backDefault = !OnDropListKey(static_cast<CFWL_MsgKey*>(pMessage));
|
| - }
|
| - if (backDefault)
|
| - CFWL_ListBoxImpDelegate::OnProcessMessage(pMessage);
|
| + return new IFWL_ComboBox(properties, nullptr);
|
| }
|
|
|
| -void CFWL_ComboListImpDelegate::OnDropListFocusChanged(CFWL_Message* pMsg,
|
| - FX_BOOL bSet) {
|
| - if (!bSet) {
|
| - CFWL_MsgKillFocus* pKill = static_cast<CFWL_MsgKillFocus*>(pMsg);
|
| - CFWL_ComboBoxImp* pOuter =
|
| - static_cast<CFWL_ComboBoxImp*>(m_pOwner->m_pOuter->GetImpl());
|
| - if (pKill->m_pSetFocus == m_pOwner->m_pOuter ||
|
| - pKill->m_pSetFocus == pOuter->m_pEdit.get()) {
|
| - pOuter->ShowDropList(FALSE);
|
| - }
|
| - }
|
| -}
|
| -int32_t CFWL_ComboListImpDelegate::OnDropListMouseMove(CFWL_MsgMouse* pMsg) {
|
| - if (m_pOwner->m_rtClient.Contains(pMsg->m_fx, pMsg->m_fy)) {
|
| - if (m_pOwner->m_bNotifyOwner) {
|
| - m_pOwner->m_bNotifyOwner = FALSE;
|
| - }
|
| - if (m_pOwner->IsShowScrollBar(TRUE) && m_pOwner->m_pVertScrollBar) {
|
| - CFX_RectF rect;
|
| - m_pOwner->m_pVertScrollBar->GetWidgetRect(rect);
|
| - if (rect.Contains(pMsg->m_fx, pMsg->m_fy)) {
|
| - return 1;
|
| - }
|
| - }
|
| - IFWL_ListItem* hItem = m_pOwner->GetItemAtPoint(pMsg->m_fx, pMsg->m_fy);
|
| - if (hItem) {
|
| - if (!m_pOwner->m_pProperties->m_pDataProvider)
|
| - return 0;
|
| - IFWL_ListBoxDP* pData = static_cast<IFWL_ListBoxDP*>(
|
| - m_pOwner->m_pProperties->m_pDataProvider);
|
| - int32_t iSel = pData->GetItemIndex(m_pOwner->m_pInterface, hItem);
|
| - CFWL_EvtCmbHoverChanged event;
|
| - event.m_pSrcTarget = m_pOwner->m_pOuter;
|
| - event.m_iCurHover = iSel;
|
| - m_pOwner->DispatchEvent(&event);
|
| - m_pOwner->ChangeSelected(iSel);
|
| - }
|
| - } else if (m_pOwner->m_bNotifyOwner) {
|
| - m_pOwner->ClientToOuter(pMsg->m_fx, pMsg->m_fy);
|
| - CFWL_ComboBoxImp* pOuter =
|
| - static_cast<CFWL_ComboBoxImp*>(m_pOwner->m_pOuter->GetImpl());
|
| - pOuter->m_pDelegate->OnProcessMessage(pMsg);
|
| - }
|
| - return 1;
|
| -}
|
| -int32_t CFWL_ComboListImpDelegate::OnDropListLButtonDown(CFWL_MsgMouse* pMsg) {
|
| - if (m_pOwner->m_rtClient.Contains(pMsg->m_fx, pMsg->m_fy)) {
|
| - return 0;
|
| - }
|
| - CFWL_ComboBoxImp* pOuter =
|
| - static_cast<CFWL_ComboBoxImp*>(m_pOwner->m_pOuter->GetImpl());
|
| - pOuter->ShowDropList(FALSE);
|
| - return 1;
|
| -}
|
| -int32_t CFWL_ComboListImpDelegate::OnDropListLButtonUp(CFWL_MsgMouse* pMsg) {
|
| - CFWL_ComboBoxImp* pOuter =
|
| - static_cast<CFWL_ComboBoxImp*>(m_pOwner->m_pOuter->GetImpl());
|
| - if (m_pOwner->m_bNotifyOwner) {
|
| - m_pOwner->ClientToOuter(pMsg->m_fx, pMsg->m_fy);
|
| - pOuter->m_pDelegate->OnProcessMessage(pMsg);
|
| - } else {
|
| - if (m_pOwner->IsShowScrollBar(TRUE) && m_pOwner->m_pVertScrollBar) {
|
| - CFX_RectF rect;
|
| - m_pOwner->m_pVertScrollBar->GetWidgetRect(rect);
|
| - if (rect.Contains(pMsg->m_fx, pMsg->m_fy)) {
|
| - return 1;
|
| - }
|
| - }
|
| - pOuter->ShowDropList(FALSE);
|
| - IFWL_ListItem* hItem = m_pOwner->GetItemAtPoint(pMsg->m_fx, pMsg->m_fy);
|
| - if (hItem) {
|
| - pOuter->ProcessSelChanged(TRUE);
|
| - }
|
| - }
|
| - return 1;
|
| -}
|
| -int32_t CFWL_ComboListImpDelegate::OnDropListKey(CFWL_MsgKey* pKey) {
|
| - CFWL_ComboBoxImp* pOuter =
|
| - static_cast<CFWL_ComboBoxImp*>(m_pOwner->m_pOuter->GetImpl());
|
| - FX_BOOL bPropagate = FALSE;
|
| - if (pKey->m_dwCmd == FWL_KeyCommand::KeyDown) {
|
| - uint32_t dwKeyCode = pKey->m_dwKeyCode;
|
| - switch (dwKeyCode) {
|
| - case FWL_VKEY_Return:
|
| - case FWL_VKEY_Escape: {
|
| - pOuter->ShowDropList(FALSE);
|
| - return 1;
|
| - }
|
| - case FWL_VKEY_Up:
|
| - case FWL_VKEY_Down: {
|
| - OnDropListKeyDown(pKey);
|
| - pOuter->SetDelegate(nullptr);
|
| - pOuter->ProcessSelChanged(FALSE);
|
| - return 1;
|
| - }
|
| - default: { bPropagate = TRUE; }
|
| - }
|
| - } else if (pKey->m_dwCmd == FWL_KeyCommand::Char) {
|
| - bPropagate = TRUE;
|
| - }
|
| - if (bPropagate) {
|
| - pKey->m_pDstTarget = m_pOwner->m_pOuter;
|
| - pOuter->m_pDelegate->OnProcessMessage(pKey);
|
| - return 1;
|
| - }
|
| - return 0;
|
| -}
|
| -void CFWL_ComboListImpDelegate::OnDropListKeyDown(CFWL_MsgKey* pKey) {
|
| - uint32_t dwKeyCode = pKey->m_dwKeyCode;
|
| - switch (dwKeyCode) {
|
| - case FWL_VKEY_Up:
|
| - case FWL_VKEY_Down:
|
| - case FWL_VKEY_Home:
|
| - case FWL_VKEY_End: {
|
| - CFWL_ComboBoxImp* pOuter =
|
| - static_cast<CFWL_ComboBoxImp*>(m_pOwner->m_pOuter->GetImpl());
|
| - IFWL_ListBoxDP* pData = static_cast<IFWL_ListBoxDP*>(
|
| - m_pOwner->m_pProperties->m_pDataProvider);
|
| - IFWL_ListItem* hItem =
|
| - pData->GetItem(m_pOwner->m_pInterface, pOuter->m_iCurSel);
|
| - hItem = m_pOwner->GetItem(hItem, dwKeyCode);
|
| - if (!hItem) {
|
| - break;
|
| - }
|
| - m_pOwner->SetSelection(hItem, hItem, TRUE);
|
| - m_pOwner->ScrollToVisible(hItem);
|
| - CFX_RectF rtInvalidate;
|
| - rtInvalidate.Set(0, 0, m_pOwner->m_pProperties->m_rtWidget.width,
|
| - m_pOwner->m_pProperties->m_rtWidget.height);
|
| - m_pOwner->Repaint(&rtInvalidate);
|
| - break;
|
| - }
|
| - default: {}
|
| - }
|
| -}
|
| -CFWL_ComboBoxImp::CFWL_ComboBoxImp(const CFWL_WidgetImpProperties& properties,
|
| - IFWL_Widget* pOuter)
|
| - : CFWL_WidgetImp(properties, pOuter),
|
| +IFWL_ComboBox::IFWL_ComboBox(const CFWL_WidgetImpProperties& properties,
|
| + IFWL_Widget* pOuter)
|
| + : IFWL_Widget(properties, pOuter),
|
| m_pForm(nullptr),
|
| m_bLButtonDown(FALSE),
|
| m_iCurSel(-1),
|
| @@ -482,22 +40,22 @@ CFWL_ComboBoxImp::CFWL_ComboBoxImp(const CFWL_WidgetImpProperties& properties,
|
| m_rtHandler.Reset();
|
| }
|
|
|
| -CFWL_ComboBoxImp::~CFWL_ComboBoxImp() {}
|
| +IFWL_ComboBox::~IFWL_ComboBox() {}
|
|
|
| -FWL_Error CFWL_ComboBoxImp::GetClassName(CFX_WideString& wsClass) const {
|
| +FWL_Error IFWL_ComboBox::GetClassName(CFX_WideString& wsClass) const {
|
| wsClass = FWL_CLASS_ComboBox;
|
| return FWL_Error::Succeeded;
|
| }
|
|
|
| -FWL_Type CFWL_ComboBoxImp::GetClassID() const {
|
| +FWL_Type IFWL_ComboBox::GetClassID() const {
|
| return FWL_Type::ComboBox;
|
| }
|
|
|
| -FWL_Error CFWL_ComboBoxImp::Initialize() {
|
| +FWL_Error IFWL_ComboBox::Initialize() {
|
| if (m_pWidgetMgr->IsFormDisabled())
|
| return DisForm_Initialize();
|
|
|
| - if (CFWL_WidgetImp::Initialize() != FWL_Error::Succeeded)
|
| + if (IFWL_Widget::Initialize() != FWL_Error::Succeeded)
|
| return FWL_Error::Indefinite;
|
|
|
| m_pDelegate = new CFWL_ComboBoxImpDelegate(this);
|
| @@ -508,31 +66,32 @@ FWL_Error CFWL_ComboBoxImp::Initialize() {
|
| prop.m_dwStyleExes |= FWL_STYLEEXT_LTB_Icon;
|
|
|
| prop.m_pDataProvider = m_pProperties->m_pDataProvider;
|
| - m_pListBox.reset(IFWL_ListBox::CreateComboList(prop, m_pInterface));
|
| + m_pListBox.reset(IFWL_ComboList::Create(prop, this));
|
| m_pListBox->Initialize();
|
| if ((m_pProperties->m_dwStyleExes & FWL_STYLEEXT_CMB_DropDown) && !m_pEdit) {
|
| CFWL_WidgetImpProperties prop2;
|
| - m_pEdit.reset(IFWL_Edit::CreateComboEdit(prop2, m_pInterface));
|
| + m_pEdit.reset(IFWL_ComboEdit::Create(prop2, this));
|
| m_pEdit->Initialize();
|
| - static_cast<CFWL_EditImp*>(m_pEdit->GetImpl())->SetOuter(m_pInterface);
|
| + m_pEdit->SetOuter(this);
|
| }
|
| if (m_pEdit)
|
| - m_pEdit->SetParent(m_pInterface);
|
| + m_pEdit->SetParent(this);
|
|
|
| SetStates(m_pProperties->m_dwStates);
|
| return FWL_Error::Succeeded;
|
| }
|
|
|
| -FWL_Error CFWL_ComboBoxImp::Finalize() {
|
| +FWL_Error IFWL_ComboBox::Finalize() {
|
| if (m_pEdit) {
|
| m_pEdit->Finalize();
|
| }
|
| m_pListBox->Finalize();
|
| delete m_pDelegate;
|
| m_pDelegate = nullptr;
|
| - return CFWL_WidgetImp::Finalize();
|
| + return IFWL_Widget::Finalize();
|
| }
|
| -FWL_Error CFWL_ComboBoxImp::GetWidgetRect(CFX_RectF& rect, FX_BOOL bAutoSize) {
|
| +
|
| +FWL_Error IFWL_ComboBox::GetWidgetRect(CFX_RectF& rect, FX_BOOL bAutoSize) {
|
| if (bAutoSize) {
|
| rect.Reset();
|
| FX_BOOL bIsDropDown = IsDropDownStyle();
|
| @@ -550,14 +109,15 @@ FWL_Error CFWL_ComboBoxImp::GetWidgetRect(CFX_RectF& rect, FX_BOOL bAutoSize) {
|
| if (!pFWidth)
|
| return FWL_Error::Indefinite;
|
| rect.Inflate(0, 0, *pFWidth, 0);
|
| - CFWL_WidgetImp::GetWidgetRect(rect, TRUE);
|
| + IFWL_Widget::GetWidgetRect(rect, TRUE);
|
| } else {
|
| rect = m_pProperties->m_rtWidget;
|
| }
|
| return FWL_Error::Succeeded;
|
| }
|
| -FWL_Error CFWL_ComboBoxImp::ModifyStylesEx(uint32_t dwStylesExAdded,
|
| - uint32_t dwStylesExRemoved) {
|
| +
|
| +FWL_Error IFWL_ComboBox::ModifyStylesEx(uint32_t dwStylesExAdded,
|
| + uint32_t dwStylesExRemoved) {
|
| if (m_pWidgetMgr->IsFormDisabled()) {
|
| return DisForm_ModifyStylesEx(dwStylesExAdded, dwStylesExRemoved);
|
| }
|
| @@ -565,16 +125,17 @@ FWL_Error CFWL_ComboBoxImp::ModifyStylesEx(uint32_t dwStylesExAdded,
|
| bool bRemoveDropDown = !!(dwStylesExRemoved & FWL_STYLEEXT_CMB_DropDown);
|
| if (bAddDropDown && !m_pEdit) {
|
| CFWL_WidgetImpProperties prop;
|
| - m_pEdit.reset(IFWL_Edit::CreateComboEdit(prop, nullptr));
|
| + m_pEdit.reset(IFWL_ComboEdit::Create(prop, nullptr));
|
| m_pEdit->Initialize();
|
| - static_cast<CFWL_EditImp*>(m_pEdit->GetImpl())->SetOuter(m_pInterface);
|
| - m_pEdit->SetParent(m_pInterface);
|
| + m_pEdit->SetOuter(this);
|
| + m_pEdit->SetParent(this);
|
| } else if (bRemoveDropDown && m_pEdit) {
|
| m_pEdit->SetStates(FWL_WGTSTATE_Invisible, TRUE);
|
| }
|
| - return CFWL_WidgetImp::ModifyStylesEx(dwStylesExAdded, dwStylesExRemoved);
|
| + return IFWL_Widget::ModifyStylesEx(dwStylesExAdded, dwStylesExRemoved);
|
| }
|
| -FWL_Error CFWL_ComboBoxImp::Update() {
|
| +
|
| +FWL_Error IFWL_ComboBox::Update() {
|
| if (m_pWidgetMgr->IsFormDisabled()) {
|
| return DisForm_Update();
|
| }
|
| @@ -591,20 +152,22 @@ FWL_Error CFWL_ComboBoxImp::Update() {
|
| }
|
| Layout();
|
| CFWL_ThemePart part;
|
| - part.m_pWidget = m_pInterface;
|
| + part.m_pWidget = this;
|
| m_fComboFormHandler =
|
| *static_cast<FX_FLOAT*>(m_pProperties->m_pThemeProvider->GetCapacity(
|
| &part, CFWL_WidgetCapacity::ComboFormHandler));
|
| return FWL_Error::Succeeded;
|
| }
|
| -FWL_WidgetHit CFWL_ComboBoxImp::HitTest(FX_FLOAT fx, FX_FLOAT fy) {
|
| +
|
| +FWL_WidgetHit IFWL_ComboBox::HitTest(FX_FLOAT fx, FX_FLOAT fy) {
|
| if (m_pWidgetMgr->IsFormDisabled()) {
|
| return DisForm_HitTest(fx, fy);
|
| }
|
| - return CFWL_WidgetImp::HitTest(fx, fy);
|
| + return IFWL_Widget::HitTest(fx, fy);
|
| }
|
| -FWL_Error CFWL_ComboBoxImp::DrawWidget(CFX_Graphics* pGraphics,
|
| - const CFX_Matrix* pMatrix) {
|
| +
|
| +FWL_Error IFWL_ComboBox::DrawWidget(CFX_Graphics* pGraphics,
|
| + const CFX_Matrix* pMatrix) {
|
| if (m_pWidgetMgr->IsFormDisabled()) {
|
| return DisForm_DrawWidget(pGraphics, pMatrix);
|
| }
|
| @@ -624,7 +187,7 @@ FWL_Error CFWL_ComboBoxImp::DrawWidget(CFX_Graphics* pGraphics,
|
| CFX_RectF rtTextBk(m_rtClient);
|
| rtTextBk.width -= m_rtBtn.width;
|
| CFWL_ThemeBackground param;
|
| - param.m_pWidget = m_pInterface;
|
| + param.m_pWidget = this;
|
| param.m_iPart = CFWL_Part::Background;
|
| param.m_pGraphics = pGraphics;
|
| if (pMatrix) {
|
| @@ -633,8 +196,7 @@ FWL_Error CFWL_ComboBoxImp::DrawWidget(CFX_Graphics* pGraphics,
|
| param.m_rtPart = rtTextBk;
|
| if (m_iCurSel >= 0) {
|
| IFWL_ListBoxDP* pData = static_cast<IFWL_ListBoxDP*>(
|
| - static_cast<CFWL_ComboListImp*>(m_pListBox->GetImpl())
|
| - ->m_pProperties->m_pDataProvider);
|
| + m_pListBox->m_pProperties->m_pDataProvider);
|
| void* p = pData->GetItemData(m_pListBox.get(),
|
| pData->GetItem(m_pListBox.get(), m_iCurSel));
|
| if (p) {
|
| @@ -656,11 +218,10 @@ FWL_Error CFWL_ComboBoxImp::DrawWidget(CFX_Graphics* pGraphics,
|
| CFX_WideString wsText;
|
| IFWL_ComboBoxDP* pData =
|
| static_cast<IFWL_ComboBoxDP*>(m_pProperties->m_pDataProvider);
|
| - IFWL_ListItem* hItem = pData->GetItem(m_pInterface, m_iCurSel);
|
| - static_cast<CFWL_ComboListImp*>(m_pListBox->GetImpl())
|
| - ->GetItemText(hItem, wsText);
|
| + IFWL_ListItem* hItem = pData->GetItem(this, m_iCurSel);
|
| + m_pListBox->GetItemText(hItem, wsText);
|
| CFWL_ThemeText theme_text;
|
| - theme_text.m_pWidget = m_pInterface;
|
| + theme_text.m_pWidget = this;
|
| theme_text.m_iPart = CFWL_Part::Caption;
|
| theme_text.m_dwStates = m_iBtnState;
|
| theme_text.m_pGraphics = pGraphics;
|
| @@ -677,7 +238,7 @@ FWL_Error CFWL_ComboBoxImp::DrawWidget(CFX_Graphics* pGraphics,
|
| }
|
| {
|
| CFWL_ThemeBackground param;
|
| - param.m_pWidget = m_pInterface;
|
| + param.m_pWidget = this;
|
| param.m_iPart = CFWL_Part::DropDownButton;
|
| param.m_dwStates = (m_pProperties->m_dwStates & FWL_WGTSTATE_Disabled)
|
| ? CFWL_PartState_Disabled
|
| @@ -689,8 +250,8 @@ FWL_Error CFWL_ComboBoxImp::DrawWidget(CFX_Graphics* pGraphics,
|
| }
|
| return FWL_Error::Succeeded;
|
| }
|
| -FWL_Error CFWL_ComboBoxImp::SetThemeProvider(
|
| - IFWL_ThemeProvider* pThemeProvider) {
|
| +
|
| +FWL_Error IFWL_ComboBox::SetThemeProvider(IFWL_ThemeProvider* pThemeProvider) {
|
| if (!pThemeProvider)
|
| return FWL_Error::Indefinite;
|
| m_pProperties->m_pThemeProvider = pThemeProvider;
|
| @@ -700,12 +261,13 @@ FWL_Error CFWL_ComboBoxImp::SetThemeProvider(
|
| m_pEdit->SetThemeProvider(pThemeProvider);
|
| return FWL_Error::Succeeded;
|
| }
|
| -int32_t CFWL_ComboBoxImp::GetCurSel() {
|
| +
|
| +int32_t IFWL_ComboBox::GetCurSel() {
|
| return m_iCurSel;
|
| }
|
| -FWL_Error CFWL_ComboBoxImp::SetCurSel(int32_t iSel) {
|
| - int32_t iCount =
|
| - static_cast<CFWL_ComboListImp*>(m_pListBox->GetImpl())->CountItems();
|
| +
|
| +FWL_Error IFWL_ComboBox::SetCurSel(int32_t iSel) {
|
| + int32_t iCount = m_pListBox->CountItems();
|
| FX_BOOL bClearSel = iSel < 0 || iSel >= iCount;
|
| FX_BOOL bDropDown = IsDropDownStyle();
|
| if (bDropDown && m_pEdit) {
|
| @@ -715,9 +277,8 @@ FWL_Error CFWL_ComboBoxImp::SetCurSel(int32_t iSel) {
|
| CFX_WideString wsText;
|
| IFWL_ComboBoxDP* pData =
|
| static_cast<IFWL_ComboBoxDP*>(m_pProperties->m_pDataProvider);
|
| - IFWL_ListItem* hItem = pData->GetItem(m_pInterface, iSel);
|
| - static_cast<CFWL_ComboListImp*>(m_pListBox->GetImpl())
|
| - ->GetItemText(hItem, wsText);
|
| + IFWL_ListItem* hItem = pData->GetItem(this, iSel);
|
| + m_pListBox->GetItemText(hItem, wsText);
|
| m_pEdit->SetText(wsText);
|
| }
|
| m_pEdit->Update();
|
| @@ -726,79 +287,87 @@ FWL_Error CFWL_ComboBoxImp::SetCurSel(int32_t iSel) {
|
| return FWL_Error::Succeeded;
|
| }
|
|
|
| -void CFWL_ComboBoxImp::SetStates(uint32_t dwStates, FX_BOOL bSet) {
|
| +void IFWL_ComboBox::SetStates(uint32_t dwStates, FX_BOOL bSet) {
|
| FX_BOOL bIsDropDown = IsDropDownStyle();
|
| if (bIsDropDown && m_pEdit)
|
| m_pEdit->SetStates(dwStates, bSet);
|
| if (m_pListBox)
|
| m_pListBox->SetStates(dwStates, bSet);
|
| - CFWL_WidgetImp::SetStates(dwStates, bSet);
|
| + IFWL_Widget::SetStates(dwStates, bSet);
|
| }
|
|
|
| -FWL_Error CFWL_ComboBoxImp::SetEditText(const CFX_WideString& wsText) {
|
| +FWL_Error IFWL_ComboBox::SetEditText(const CFX_WideString& wsText) {
|
| if (!m_pEdit)
|
| return FWL_Error::Indefinite;
|
| m_pEdit->SetText(wsText);
|
| return m_pEdit->Update();
|
| }
|
| -int32_t CFWL_ComboBoxImp::GetEditTextLength() const {
|
| +
|
| +int32_t IFWL_ComboBox::GetEditTextLength() const {
|
| if (!m_pEdit)
|
| return -1;
|
| return m_pEdit->GetTextLength();
|
| }
|
| -FWL_Error CFWL_ComboBoxImp::GetEditText(CFX_WideString& wsText,
|
| - int32_t nStart,
|
| - int32_t nCount) const {
|
| +
|
| +FWL_Error IFWL_ComboBox::GetEditText(CFX_WideString& wsText,
|
| + int32_t nStart,
|
| + int32_t nCount) const {
|
| if (m_pEdit) {
|
| return m_pEdit->GetText(wsText, nStart, nCount);
|
| } else if (m_pListBox) {
|
| IFWL_ComboBoxDP* pData =
|
| static_cast<IFWL_ComboBoxDP*>(m_pProperties->m_pDataProvider);
|
| - IFWL_ListItem* hItem = pData->GetItem(m_pInterface, m_iCurSel);
|
| + IFWL_ListItem* hItem = pData->GetItem(this, m_iCurSel);
|
| return m_pListBox->GetItemText(hItem, wsText);
|
| }
|
| return FWL_Error::Indefinite;
|
| }
|
| -FWL_Error CFWL_ComboBoxImp::SetEditSelRange(int32_t nStart, int32_t nCount) {
|
| +
|
| +FWL_Error IFWL_ComboBox::SetEditSelRange(int32_t nStart, int32_t nCount) {
|
| if (!m_pEdit)
|
| return FWL_Error::Indefinite;
|
| - static_cast<CFWL_ComboEditImp*>(m_pEdit->GetImpl())->ClearSelected();
|
| + m_pEdit->ClearSelected();
|
| m_pEdit->AddSelRange(nStart, nCount);
|
| return FWL_Error::Succeeded;
|
| }
|
| -int32_t CFWL_ComboBoxImp::GetEditSelRange(int32_t nIndex, int32_t& nStart) {
|
| +
|
| +int32_t IFWL_ComboBox::GetEditSelRange(int32_t nIndex, int32_t& nStart) {
|
| if (!m_pEdit)
|
| return -1;
|
| return m_pEdit->GetSelRange(nIndex, nStart);
|
| }
|
| -int32_t CFWL_ComboBoxImp::GetEditLimit() {
|
| +
|
| +int32_t IFWL_ComboBox::GetEditLimit() {
|
| if (!m_pEdit)
|
| return -1;
|
| return m_pEdit->GetLimit();
|
| }
|
| -FWL_Error CFWL_ComboBoxImp::SetEditLimit(int32_t nLimit) {
|
| +
|
| +FWL_Error IFWL_ComboBox::SetEditLimit(int32_t nLimit) {
|
| if (!m_pEdit)
|
| return FWL_Error::Indefinite;
|
| return m_pEdit->SetLimit(nLimit);
|
| }
|
| -FWL_Error CFWL_ComboBoxImp::EditDoClipboard(int32_t iCmd) {
|
| +
|
| +FWL_Error IFWL_ComboBox::EditDoClipboard(int32_t iCmd) {
|
| if (!m_pEdit)
|
| return FWL_Error::Indefinite;
|
| return m_pEdit->DoClipboard(iCmd);
|
| }
|
|
|
| -FX_BOOL CFWL_ComboBoxImp::EditRedo(const IFDE_TxtEdtDoRecord* pRecord) {
|
| +FX_BOOL IFWL_ComboBox::EditRedo(const IFDE_TxtEdtDoRecord* pRecord) {
|
| return m_pEdit && m_pEdit->Redo(pRecord);
|
| }
|
|
|
| -FX_BOOL CFWL_ComboBoxImp::EditUndo(const IFDE_TxtEdtDoRecord* pRecord) {
|
| +FX_BOOL IFWL_ComboBox::EditUndo(const IFDE_TxtEdtDoRecord* pRecord) {
|
| return m_pEdit && m_pEdit->Undo(pRecord);
|
| }
|
|
|
| -IFWL_ListBox* CFWL_ComboBoxImp::GetListBoxt() {
|
| +IFWL_ListBox* IFWL_ComboBox::GetListBoxt() {
|
| return m_pListBox.get();
|
| }
|
| -FX_BOOL CFWL_ComboBoxImp::AfterFocusShowDropList() {
|
| +
|
| +FX_BOOL IFWL_ComboBox::AfterFocusShowDropList() {
|
| if (!m_bNeedShowList) {
|
| return FALSE;
|
| }
|
| @@ -809,53 +378,68 @@ FX_BOOL CFWL_ComboBoxImp::AfterFocusShowDropList() {
|
| m_bNeedShowList = FALSE;
|
| return TRUE;
|
| }
|
| -FWL_Error CFWL_ComboBoxImp::OpenDropDownList(FX_BOOL bActivate) {
|
| +
|
| +FWL_Error IFWL_ComboBox::OpenDropDownList(FX_BOOL bActivate) {
|
| ShowDropList(bActivate);
|
| return FWL_Error::Succeeded;
|
| }
|
| -FX_BOOL CFWL_ComboBoxImp::EditCanUndo() {
|
| +
|
| +FX_BOOL IFWL_ComboBox::EditCanUndo() {
|
| return m_pEdit->CanUndo();
|
| }
|
| -FX_BOOL CFWL_ComboBoxImp::EditCanRedo() {
|
| +
|
| +FX_BOOL IFWL_ComboBox::EditCanRedo() {
|
| return m_pEdit->CanRedo();
|
| }
|
| -FX_BOOL CFWL_ComboBoxImp::EditUndo() {
|
| +
|
| +FX_BOOL IFWL_ComboBox::EditUndo() {
|
| return m_pEdit->Undo();
|
| }
|
| -FX_BOOL CFWL_ComboBoxImp::EditRedo() {
|
| +
|
| +FX_BOOL IFWL_ComboBox::EditRedo() {
|
| return m_pEdit->Redo();
|
| }
|
| -FX_BOOL CFWL_ComboBoxImp::EditCanCopy() {
|
| +
|
| +FX_BOOL IFWL_ComboBox::EditCanCopy() {
|
| return m_pEdit->CountSelRanges() > 0;
|
| }
|
| -FX_BOOL CFWL_ComboBoxImp::EditCanCut() {
|
| +
|
| +FX_BOOL IFWL_ComboBox::EditCanCut() {
|
| if (m_pEdit->GetStylesEx() & FWL_STYLEEXT_EDT_ReadOnly) {
|
| return FALSE;
|
| }
|
| return m_pEdit->CountSelRanges() > 0;
|
| }
|
| -FX_BOOL CFWL_ComboBoxImp::EditCanSelectAll() {
|
| +
|
| +FX_BOOL IFWL_ComboBox::EditCanSelectAll() {
|
| return m_pEdit->GetTextLength() > 0;
|
| }
|
| -FX_BOOL CFWL_ComboBoxImp::EditCopy(CFX_WideString& wsCopy) {
|
| +
|
| +FX_BOOL IFWL_ComboBox::EditCopy(CFX_WideString& wsCopy) {
|
| return m_pEdit->Copy(wsCopy);
|
| }
|
| -FX_BOOL CFWL_ComboBoxImp::EditCut(CFX_WideString& wsCut) {
|
| +
|
| +FX_BOOL IFWL_ComboBox::EditCut(CFX_WideString& wsCut) {
|
| return m_pEdit->Cut(wsCut);
|
| }
|
| -FX_BOOL CFWL_ComboBoxImp::EditPaste(const CFX_WideString& wsPaste) {
|
| +
|
| +FX_BOOL IFWL_ComboBox::EditPaste(const CFX_WideString& wsPaste) {
|
| return m_pEdit->Paste(wsPaste);
|
| }
|
| -FX_BOOL CFWL_ComboBoxImp::EditSelectAll() {
|
| +
|
| +FX_BOOL IFWL_ComboBox::EditSelectAll() {
|
| return m_pEdit->AddSelRange(0) == FWL_Error::Succeeded;
|
| }
|
| -FX_BOOL CFWL_ComboBoxImp::EditDelete() {
|
| +
|
| +FX_BOOL IFWL_ComboBox::EditDelete() {
|
| return m_pEdit->ClearText() == FWL_Error::Succeeded;
|
| }
|
| -FX_BOOL CFWL_ComboBoxImp::EditDeSelect() {
|
| +
|
| +FX_BOOL IFWL_ComboBox::EditDeSelect() {
|
| return m_pEdit->ClearSelections() == FWL_Error::Succeeded;
|
| }
|
| -FWL_Error CFWL_ComboBoxImp::GetBBox(CFX_RectF& rect) {
|
| +
|
| +FWL_Error IFWL_ComboBox::GetBBox(CFX_RectF& rect) {
|
| if (m_pWidgetMgr->IsFormDisabled()) {
|
| return DisForm_GetBBox(rect);
|
| }
|
| @@ -869,31 +453,33 @@ FWL_Error CFWL_ComboBoxImp::GetBBox(CFX_RectF& rect) {
|
| return FWL_Error::Succeeded;
|
| }
|
|
|
| -FWL_Error CFWL_ComboBoxImp::EditModifyStylesEx(uint32_t dwStylesExAdded,
|
| - uint32_t dwStylesExRemoved) {
|
| +FWL_Error IFWL_ComboBox::EditModifyStylesEx(uint32_t dwStylesExAdded,
|
| + uint32_t dwStylesExRemoved) {
|
| if (!m_pEdit)
|
| return FWL_Error::ParameterInvalid;
|
| return m_pEdit->ModifyStylesEx(dwStylesExAdded, dwStylesExRemoved);
|
| }
|
|
|
| -FX_FLOAT CFWL_ComboBoxImp::GetListHeight() {
|
| +FX_FLOAT IFWL_ComboBox::GetListHeight() {
|
| return static_cast<IFWL_ComboBoxDP*>(m_pProperties->m_pDataProvider)
|
| - ->GetListHeight(m_pInterface);
|
| + ->GetListHeight(this);
|
| }
|
| -void CFWL_ComboBoxImp::DrawStretchHandler(CFX_Graphics* pGraphics,
|
| - const CFX_Matrix* pMatrix) {
|
| +
|
| +void IFWL_ComboBox::DrawStretchHandler(CFX_Graphics* pGraphics,
|
| + const CFX_Matrix* pMatrix) {
|
| CFWL_ThemeBackground param;
|
| param.m_pGraphics = pGraphics;
|
| param.m_iPart = CFWL_Part::StretchHandler;
|
| param.m_dwStates = CFWL_PartState_Normal;
|
| - param.m_pWidget = m_pInterface;
|
| + param.m_pWidget = this;
|
| if (pMatrix) {
|
| param.m_matrix.Concat(*pMatrix);
|
| }
|
| param.m_rtPart = m_rtHandler;
|
| m_pProperties->m_pThemeProvider->DrawBackground(¶m);
|
| }
|
| -void CFWL_ComboBoxImp::ShowDropList(FX_BOOL bActivate) {
|
| +
|
| +void IFWL_ComboBox::ShowDropList(FX_BOOL bActivate) {
|
| if (m_pWidgetMgr->IsFormDisabled()) {
|
| return DisForm_ShowDropList(bActivate);
|
| }
|
| @@ -906,8 +492,7 @@ void CFWL_ComboBoxImp::ShowDropList(FX_BOOL bActivate) {
|
| }
|
| m_pListProxyDelegate->Reset();
|
| if (bActivate) {
|
| - static_cast<CFWL_ComboListImp*>(m_pListBox->GetImpl())
|
| - ->ChangeSelected(m_iCurSel);
|
| + m_pListBox->ChangeSelected(m_iCurSel);
|
| ReSetListItemAlignment();
|
| uint32_t dwStyleAdd = m_pProperties->m_dwStyleExes &
|
| (FWL_STYLEEXT_CMB_Sort | FWL_STYLEEXT_CMB_OwnerDraw);
|
| @@ -950,58 +535,58 @@ void CFWL_ComboBoxImp::ShowDropList(FX_BOOL bActivate) {
|
| m_pListBox->SetWidgetRect(m_rtList);
|
| m_pListBox->Update();
|
| CFWL_EvtCmbPreDropDown ev;
|
| - ev.m_pSrcTarget = m_pInterface;
|
| + ev.m_pSrcTarget = this;
|
| DispatchEvent(&ev);
|
| - m_fItemHeight =
|
| - static_cast<CFWL_ComboListImp*>(m_pListBox->GetImpl())->m_fItemHeight;
|
| - static_cast<CFWL_ComboListImp*>(m_pListBox->GetImpl())->SetFocus(TRUE);
|
| + m_fItemHeight = m_pListBox->m_fItemHeight;
|
| + m_pListBox->SetFocus(TRUE);
|
| m_pForm->DoModal();
|
| - static_cast<CFWL_ComboListImp*>(m_pListBox->GetImpl())->SetFocus(FALSE);
|
| + m_pListBox->SetFocus(FALSE);
|
| } else {
|
| m_pForm->EndDoModal();
|
| CFWL_EvtCmbCloseUp ev;
|
| - ev.m_pSrcTarget = m_pInterface;
|
| + ev.m_pSrcTarget = this;
|
| DispatchEvent(&ev);
|
| m_bLButtonDown = FALSE;
|
| - static_cast<CFWL_ComboListImp*>(m_pListBox->GetImpl())->m_bNotifyOwner =
|
| - TRUE;
|
| + m_pListBox->m_bNotifyOwner = TRUE;
|
| SetFocus(TRUE);
|
| }
|
| }
|
| -FX_BOOL CFWL_ComboBoxImp::IsDropListShowed() {
|
| +
|
| +FX_BOOL IFWL_ComboBox::IsDropListShowed() {
|
| return m_pForm && !(m_pForm->GetStates() & FWL_WGTSTATE_Invisible);
|
| }
|
| -FX_BOOL CFWL_ComboBoxImp::IsDropDownStyle() const {
|
| +
|
| +FX_BOOL IFWL_ComboBox::IsDropDownStyle() const {
|
| return m_pProperties->m_dwStyleExes & FWL_STYLEEXT_CMB_DropDown;
|
| }
|
| -void CFWL_ComboBoxImp::MatchEditText() {
|
| +
|
| +void IFWL_ComboBox::MatchEditText() {
|
| CFX_WideString wsText;
|
| m_pEdit->GetText(wsText);
|
| - int32_t iMatch =
|
| - static_cast<CFWL_ComboListImp*>(m_pListBox->GetImpl())->MatchItem(wsText);
|
| + int32_t iMatch = m_pListBox->MatchItem(wsText);
|
| if (iMatch != m_iCurSel) {
|
| - static_cast<CFWL_ComboListImp*>(m_pListBox->GetImpl())
|
| - ->ChangeSelected(iMatch);
|
| + m_pListBox->ChangeSelected(iMatch);
|
| if (iMatch >= 0) {
|
| SynchrEditText(iMatch);
|
| }
|
| } else if (iMatch >= 0) {
|
| - static_cast<CFWL_ComboEditImp*>(m_pEdit->GetImpl())->SetSelected();
|
| + m_pEdit->SetSelected();
|
| }
|
| m_iCurSel = iMatch;
|
| }
|
| -void CFWL_ComboBoxImp::SynchrEditText(int32_t iListItem) {
|
| +
|
| +void IFWL_ComboBox::SynchrEditText(int32_t iListItem) {
|
| CFX_WideString wsText;
|
| IFWL_ComboBoxDP* pData =
|
| static_cast<IFWL_ComboBoxDP*>(m_pProperties->m_pDataProvider);
|
| - IFWL_ListItem* hItem = pData->GetItem(m_pInterface, iListItem);
|
| - static_cast<CFWL_ComboListImp*>(m_pListBox->GetImpl())
|
| - ->GetItemText(hItem, wsText);
|
| + IFWL_ListItem* hItem = pData->GetItem(this, iListItem);
|
| + m_pListBox->GetItemText(hItem, wsText);
|
| m_pEdit->SetText(wsText);
|
| m_pEdit->Update();
|
| - static_cast<CFWL_ComboEditImp*>(m_pEdit->GetImpl())->SetSelected();
|
| + m_pEdit->SetSelected();
|
| }
|
| -void CFWL_ComboBoxImp::Layout() {
|
| +
|
| +void IFWL_ComboBox::Layout() {
|
| if (m_pWidgetMgr->IsFormDisabled()) {
|
| return DisForm_Layout();
|
| }
|
| @@ -1023,9 +608,8 @@ void CFWL_ComboBoxImp::Layout() {
|
| CFX_WideString wsText;
|
| IFWL_ComboBoxDP* pData =
|
| static_cast<IFWL_ComboBoxDP*>(m_pProperties->m_pDataProvider);
|
| - IFWL_ListItem* hItem = pData->GetItem(m_pInterface, m_iCurSel);
|
| - static_cast<CFWL_ComboListImp*>(m_pListBox->GetImpl())
|
| - ->GetItemText(hItem, wsText);
|
| + IFWL_ListItem* hItem = pData->GetItem(this, m_iCurSel);
|
| + m_pListBox->GetItemText(hItem, wsText);
|
| m_pEdit->LockUpdate();
|
| m_pEdit->SetText(wsText);
|
| m_pEdit->UnlockUpdate();
|
| @@ -1033,7 +617,8 @@ void CFWL_ComboBoxImp::Layout() {
|
| m_pEdit->Update();
|
| }
|
| }
|
| -void CFWL_ComboBoxImp::ReSetTheme() {
|
| +
|
| +void IFWL_ComboBox::ReSetTheme() {
|
| IFWL_ThemeProvider* pTheme = m_pProperties->m_pThemeProvider;
|
| if (!pTheme) {
|
| pTheme = GetAvailableTheme();
|
| @@ -1044,7 +629,8 @@ void CFWL_ComboBoxImp::ReSetTheme() {
|
| if (m_pEdit && !m_pEdit->GetThemeProvider())
|
| m_pEdit->SetThemeProvider(pTheme);
|
| }
|
| -void CFWL_ComboBoxImp::ReSetEditAlignment() {
|
| +
|
| +void IFWL_ComboBox::ReSetEditAlignment() {
|
| if (!m_pEdit)
|
| return;
|
| uint32_t dwStylExes = m_pProperties->m_dwStyleExes;
|
| @@ -1081,7 +667,8 @@ void CFWL_ComboBoxImp::ReSetEditAlignment() {
|
| FWL_STYLEEXT_EDT_HAlignModeMask |
|
| FWL_STYLEEXT_EDT_VAlignMask);
|
| }
|
| -void CFWL_ComboBoxImp::ReSetListItemAlignment() {
|
| +
|
| +void IFWL_ComboBox::ReSetListItemAlignment() {
|
| if (!m_pListBox)
|
| return;
|
| uint32_t dwStylExes = m_pProperties->m_dwStyleExes;
|
| @@ -1097,26 +684,27 @@ void CFWL_ComboBoxImp::ReSetListItemAlignment() {
|
| }
|
| m_pListBox->ModifyStylesEx(dwAdd, FWL_STYLEEXT_CMB_ListItemAlignMask);
|
| }
|
| -void CFWL_ComboBoxImp::ProcessSelChanged(FX_BOOL bLButtonUp) {
|
| +
|
| +void IFWL_ComboBox::ProcessSelChanged(FX_BOOL bLButtonUp) {
|
| IFWL_ComboBoxDP* pDatas =
|
| static_cast<IFWL_ComboBoxDP*>(m_pProperties->m_pDataProvider);
|
| - m_iCurSel = pDatas->GetItemIndex(m_pInterface, m_pListBox->GetSelItem(0));
|
| + m_iCurSel = pDatas->GetItemIndex(this, m_pListBox->GetSelItem(0));
|
| FX_BOOL bDropDown = IsDropDownStyle();
|
| if (bDropDown) {
|
| IFWL_ComboBoxDP* pData =
|
| static_cast<IFWL_ComboBoxDP*>(m_pProperties->m_pDataProvider);
|
| - IFWL_ListItem* hItem = pData->GetItem(m_pInterface, m_iCurSel);
|
| + IFWL_ListItem* hItem = pData->GetItem(this, m_iCurSel);
|
| if (hItem) {
|
| CFX_WideString wsText;
|
| - pData->GetItemText(m_pInterface, hItem, wsText);
|
| + pData->GetItemText(this, hItem, wsText);
|
| if (m_pEdit) {
|
| m_pEdit->SetText(wsText);
|
| m_pEdit->Update();
|
| - static_cast<CFWL_ComboEditImp*>(m_pEdit->GetImpl())->SetSelected();
|
| + m_pEdit->SetSelected();
|
| }
|
| CFWL_EvtCmbSelChanged ev;
|
| ev.bLButtonUp = bLButtonUp;
|
| - ev.m_pSrcTarget = m_pInterface;
|
| + ev.m_pSrcTarget = this;
|
| ev.iArraySels.Add(m_iCurSel);
|
| DispatchEvent(&ev);
|
| }
|
| @@ -1125,27 +713,25 @@ void CFWL_ComboBoxImp::ProcessSelChanged(FX_BOOL bLButtonUp) {
|
| }
|
| }
|
|
|
| -void CFWL_ComboBoxImp::InitProxyForm() {
|
| +void IFWL_ComboBox::InitProxyForm() {
|
| if (m_pForm)
|
| return;
|
| if (!m_pListBox)
|
| return;
|
|
|
| CFWL_WidgetImpProperties propForm;
|
| - propForm.m_pOwner = m_pInterface;
|
| + propForm.m_pOwner = this;
|
| propForm.m_dwStyles = FWL_WGTSTYLE_Popup;
|
| propForm.m_dwStates = FWL_WGTSTATE_Invisible;
|
| - CFX_WideString className;
|
| - m_pForm = IFWL_Form::CreateFormProxy(propForm, &className, m_pListBox.get());
|
| + m_pForm = IFWL_FormProxy::Create(propForm, m_pListBox.get());
|
| m_pForm->Initialize();
|
| - m_pProxy = static_cast<CFWL_FormProxyImp*>(m_pForm->GetImpl());
|
| m_pListBox->SetParent(m_pForm);
|
| m_pListProxyDelegate = new CFWL_ComboProxyImpDelegate(m_pForm, this);
|
| - m_pProxy->SetDelegate(m_pListProxyDelegate);
|
| + m_pForm->SetDelegate(m_pListProxyDelegate);
|
| }
|
|
|
| -FWL_Error CFWL_ComboBoxImp::DisForm_Initialize() {
|
| - if (CFWL_WidgetImp::Initialize() != FWL_Error::Succeeded)
|
| +FWL_Error IFWL_ComboBox::DisForm_Initialize() {
|
| + if (IFWL_Widget::Initialize() != FWL_Error::Succeeded)
|
| return FWL_Error::Indefinite;
|
|
|
| m_pDelegate = new CFWL_ComboBoxImpDelegate(this);
|
| @@ -1154,41 +740,42 @@ FWL_Error CFWL_ComboBoxImp::DisForm_Initialize() {
|
| return FWL_Error::Succeeded;
|
| }
|
|
|
| -void CFWL_ComboBoxImp::DisForm_InitComboList() {
|
| +void IFWL_ComboBox::DisForm_InitComboList() {
|
| if (m_pListBox)
|
| return;
|
|
|
| CFWL_WidgetImpProperties prop;
|
| - prop.m_pParent = m_pInterface;
|
| + prop.m_pParent = this;
|
| prop.m_dwStyles = FWL_WGTSTYLE_Border | FWL_WGTSTYLE_VScroll;
|
| prop.m_dwStates = FWL_WGTSTATE_Invisible;
|
| prop.m_pDataProvider = m_pProperties->m_pDataProvider;
|
| prop.m_pThemeProvider = m_pProperties->m_pThemeProvider;
|
| - m_pListBox.reset(IFWL_ListBox::CreateComboList(prop, m_pInterface));
|
| + m_pListBox.reset(IFWL_ComboList::Create(prop, this));
|
| m_pListBox->Initialize();
|
| }
|
| -void CFWL_ComboBoxImp::DisForm_InitComboEdit() {
|
| +
|
| +void IFWL_ComboBox::DisForm_InitComboEdit() {
|
| if (m_pEdit) {
|
| return;
|
| }
|
| CFWL_WidgetImpProperties prop;
|
| - prop.m_pParent = m_pInterface;
|
| + prop.m_pParent = this;
|
| prop.m_pThemeProvider = m_pProperties->m_pThemeProvider;
|
| - m_pEdit.reset(IFWL_Edit::CreateComboEdit(prop, m_pInterface));
|
| + m_pEdit.reset(IFWL_ComboEdit::Create(prop, this));
|
| m_pEdit->Initialize();
|
| - static_cast<CFWL_ComboEditImp*>(m_pEdit->GetImpl())->SetOuter(m_pInterface);
|
| + m_pEdit->SetOuter(this);
|
| }
|
| -void CFWL_ComboBoxImp::DisForm_ShowDropList(FX_BOOL bActivate) {
|
| +
|
| +void IFWL_ComboBox::DisForm_ShowDropList(FX_BOOL bActivate) {
|
| FX_BOOL bDropList = DisForm_IsDropListShowed();
|
| if (bDropList == bActivate) {
|
| return;
|
| }
|
| if (bActivate) {
|
| CFWL_EvtCmbPreDropDown preEvent;
|
| - preEvent.m_pSrcTarget = m_pInterface;
|
| + preEvent.m_pSrcTarget = this;
|
| DispatchEvent(&preEvent);
|
| - CFWL_ComboListImp* pComboList =
|
| - static_cast<CFWL_ComboListImp*>(m_pListBox->GetImpl());
|
| + IFWL_ComboList* pComboList = m_pListBox.get();
|
| int32_t iItems = pComboList->CountItems();
|
| if (iItems < 1) {
|
| return;
|
| @@ -1216,7 +803,7 @@ void CFWL_ComboBoxImp::DisForm_ShowDropList(FX_BOOL bActivate) {
|
| m_pListBox->SetStates(FWL_WGTSTATE_Invisible, !bActivate);
|
| if (bActivate) {
|
| CFWL_EvtCmbPostDropDown postEvent;
|
| - postEvent.m_pSrcTarget = m_pInterface;
|
| + postEvent.m_pSrcTarget = this;
|
| DispatchEvent(&postEvent);
|
| }
|
| CFX_RectF rect;
|
| @@ -1224,11 +811,13 @@ void CFWL_ComboBoxImp::DisForm_ShowDropList(FX_BOOL bActivate) {
|
| rect.Inflate(2, 2);
|
| Repaint(&rect);
|
| }
|
| -FX_BOOL CFWL_ComboBoxImp::DisForm_IsDropListShowed() {
|
| +
|
| +FX_BOOL IFWL_ComboBox::DisForm_IsDropListShowed() {
|
| return !(m_pListBox->GetStates() & FWL_WGTSTATE_Invisible);
|
| }
|
| -FWL_Error CFWL_ComboBoxImp::DisForm_ModifyStylesEx(uint32_t dwStylesExAdded,
|
| - uint32_t dwStylesExRemoved) {
|
| +
|
| +FWL_Error IFWL_ComboBox::DisForm_ModifyStylesEx(uint32_t dwStylesExAdded,
|
| + uint32_t dwStylesExRemoved) {
|
| if (!m_pEdit) {
|
| DisForm_InitComboEdit();
|
| }
|
| @@ -1241,9 +830,10 @@ FWL_Error CFWL_ComboBoxImp::DisForm_ModifyStylesEx(uint32_t dwStylesExAdded,
|
| } else if (bDelDropDown) {
|
| m_pEdit->ModifyStylesEx(FWL_STYLEEXT_EDT_ReadOnly, 0);
|
| }
|
| - return CFWL_WidgetImp::ModifyStylesEx(dwStylesExAdded, dwStylesExRemoved);
|
| + return IFWL_Widget::ModifyStylesEx(dwStylesExAdded, dwStylesExRemoved);
|
| }
|
| -FWL_Error CFWL_ComboBoxImp::DisForm_Update() {
|
| +
|
| +FWL_Error IFWL_ComboBox::DisForm_Update() {
|
| if (m_iLock) {
|
| return FWL_Error::Indefinite;
|
| }
|
| @@ -1254,7 +844,8 @@ FWL_Error CFWL_ComboBoxImp::DisForm_Update() {
|
| Layout();
|
| return FWL_Error::Succeeded;
|
| }
|
| -FWL_WidgetHit CFWL_ComboBoxImp::DisForm_HitTest(FX_FLOAT fx, FX_FLOAT fy) {
|
| +
|
| +FWL_WidgetHit IFWL_ComboBox::DisForm_HitTest(FX_FLOAT fx, FX_FLOAT fy) {
|
| CFX_RectF rect;
|
| rect.Set(0, 0, m_pProperties->m_rtWidget.width - m_rtBtn.width,
|
| m_pProperties->m_rtWidget.height);
|
| @@ -1269,8 +860,9 @@ FWL_WidgetHit CFWL_ComboBoxImp::DisForm_HitTest(FX_FLOAT fx, FX_FLOAT fy) {
|
| }
|
| return FWL_WidgetHit::Unknown;
|
| }
|
| -FWL_Error CFWL_ComboBoxImp::DisForm_DrawWidget(CFX_Graphics* pGraphics,
|
| - const CFX_Matrix* pMatrix) {
|
| +
|
| +FWL_Error IFWL_ComboBox::DisForm_DrawWidget(CFX_Graphics* pGraphics,
|
| + const CFX_Matrix* pMatrix) {
|
| IFWL_ThemeProvider* pTheme = m_pProperties->m_pThemeProvider;
|
| CFX_Matrix mtOrg;
|
| mtOrg.Set(1, 0, 0, 1, 0, 0);
|
| @@ -1282,7 +874,7 @@ FWL_Error CFWL_ComboBoxImp::DisForm_DrawWidget(CFX_Graphics* pGraphics,
|
| pGraphics->ConcatMatrix(&mtOrg);
|
| if (!m_rtBtn.IsEmpty(0.1f)) {
|
| CFWL_ThemeBackground param;
|
| - param.m_pWidget = m_pInterface;
|
| + param.m_pWidget = this;
|
| param.m_iPart = CFWL_Part::DropDownButton;
|
| param.m_dwStates = m_iBtnState;
|
| param.m_pGraphics = pGraphics;
|
| @@ -1308,7 +900,8 @@ FWL_Error CFWL_ComboBoxImp::DisForm_DrawWidget(CFX_Graphics* pGraphics,
|
| }
|
| return FWL_Error::Succeeded;
|
| }
|
| -FWL_Error CFWL_ComboBoxImp::DisForm_GetBBox(CFX_RectF& rect) {
|
| +
|
| +FWL_Error IFWL_ComboBox::DisForm_GetBBox(CFX_RectF& rect) {
|
| rect = m_pProperties->m_rtWidget;
|
| if (m_pListBox && DisForm_IsDropListShowed()) {
|
| CFX_RectF rtList;
|
| @@ -1318,7 +911,8 @@ FWL_Error CFWL_ComboBoxImp::DisForm_GetBBox(CFX_RectF& rect) {
|
| }
|
| return FWL_Error::Succeeded;
|
| }
|
| -void CFWL_ComboBoxImp::DisForm_Layout() {
|
| +
|
| +void IFWL_ComboBox::DisForm_Layout() {
|
| GetClientRect(m_rtClient);
|
| m_rtContent = m_rtClient;
|
| FX_FLOAT* pFWidth = static_cast<FX_FLOAT*>(
|
| @@ -1347,9 +941,8 @@ void CFWL_ComboBoxImp::DisForm_Layout() {
|
| CFX_WideString wsText;
|
| IFWL_ComboBoxDP* pData =
|
| static_cast<IFWL_ComboBoxDP*>(m_pProperties->m_pDataProvider);
|
| - IFWL_ListItem* hItem = pData->GetItem(m_pInterface, m_iCurSel);
|
| - static_cast<CFWL_ComboListImp*>(m_pListBox->GetImpl())
|
| - ->GetItemText(hItem, wsText);
|
| + IFWL_ListItem* hItem = pData->GetItem(this, m_iCurSel);
|
| + m_pListBox->GetItemText(hItem, wsText);
|
| m_pEdit->LockUpdate();
|
| m_pEdit->SetText(wsText);
|
| m_pEdit->UnlockUpdate();
|
| @@ -1358,7 +951,7 @@ void CFWL_ComboBoxImp::DisForm_Layout() {
|
| }
|
| }
|
|
|
| -CFWL_ComboBoxImpDelegate::CFWL_ComboBoxImpDelegate(CFWL_ComboBoxImp* pOwner)
|
| +CFWL_ComboBoxImpDelegate::CFWL_ComboBoxImpDelegate(IFWL_ComboBox* pOwner)
|
| : m_pOwner(pOwner) {}
|
|
|
| void CFWL_ComboBoxImpDelegate::OnProcessMessage(CFWL_Message* pMessage) {
|
| @@ -1406,9 +999,7 @@ void CFWL_ComboBoxImpDelegate::OnProcessMessage(CFWL_Message* pMessage) {
|
| OnKey(static_cast<CFWL_MsgKey*>(pMessage));
|
| break;
|
| }
|
| - default: {
|
| - break;
|
| - }
|
| + default: { break; }
|
| }
|
|
|
| CFWL_WidgetImpDelegate::OnProcessMessage(pMessage);
|
| @@ -1420,7 +1011,7 @@ void CFWL_ComboBoxImpDelegate::OnProcessEvent(CFWL_Event* pEvent) {
|
| CFWL_EvtLtbDrawItem* pDrawItemEvent =
|
| static_cast<CFWL_EvtLtbDrawItem*>(pEvent);
|
| CFWL_EvtCmbDrawItem pTemp;
|
| - pTemp.m_pSrcTarget = m_pOwner->m_pInterface;
|
| + pTemp.m_pSrcTarget = m_pOwner;
|
| pTemp.m_pGraphics = pDrawItemEvent->m_pGraphics;
|
| pTemp.m_index = pDrawItemEvent->m_index;
|
| pTemp.m_rtItem = pDrawItemEvent->m_rect;
|
| @@ -1428,7 +1019,7 @@ void CFWL_ComboBoxImpDelegate::OnProcessEvent(CFWL_Event* pEvent) {
|
| } else if (dwFlag == CFWL_EventType::Scroll) {
|
| CFWL_EvtScroll* pScrollEvent = static_cast<CFWL_EvtScroll*>(pEvent);
|
| CFWL_EvtScroll pScrollEv;
|
| - pScrollEv.m_pSrcTarget = m_pOwner->m_pInterface;
|
| + pScrollEv.m_pSrcTarget = m_pOwner;
|
| pScrollEv.m_iScrollCode = pScrollEvent->m_iScrollCode;
|
| pScrollEv.m_fPos = pScrollEvent->m_fPos;
|
| m_pOwner->DispatchEvent(&pScrollEv);
|
| @@ -1436,7 +1027,7 @@ void CFWL_ComboBoxImpDelegate::OnProcessEvent(CFWL_Event* pEvent) {
|
| CFWL_EvtEdtTextChanged* pTextChangedEvent =
|
| static_cast<CFWL_EvtEdtTextChanged*>(pEvent);
|
| CFWL_EvtCmbEditChanged pTemp;
|
| - pTemp.m_pSrcTarget = m_pOwner->m_pInterface;
|
| + pTemp.m_pSrcTarget = m_pOwner;
|
| pTemp.wsInsert = pTextChangedEvent->wsInsert;
|
| pTemp.wsDelete = pTextChangedEvent->wsDelete;
|
| pTemp.nChangeType = pTextChangedEvent->nChangeType;
|
| @@ -1459,8 +1050,7 @@ void CFWL_ComboBoxImpDelegate::OnFocusChanged(CFWL_Message* pMsg,
|
| if (bDropDown && pSrcTarget != m_pOwner->m_pListBox.get()) {
|
| if (!m_pOwner->m_pEdit)
|
| return;
|
| - static_cast<CFWL_ComboEditImp*>(m_pOwner->m_pEdit->GetImpl())
|
| - ->SetSelected();
|
| + m_pOwner->m_pEdit->SetSelected();
|
| } else {
|
| m_pOwner->Repaint(&m_pOwner->m_rtClient);
|
| }
|
| @@ -1469,15 +1059,14 @@ void CFWL_ComboBoxImpDelegate::OnFocusChanged(CFWL_Message* pMsg,
|
| if (bDropDown && pDstTarget != m_pOwner->m_pListBox.get()) {
|
| if (!m_pOwner->m_pEdit)
|
| return;
|
| - static_cast<CFWL_ComboEditImp*>(m_pOwner->m_pEdit->GetImpl())
|
| - ->FlagFocus(FALSE);
|
| - static_cast<CFWL_ComboEditImp*>(m_pOwner->m_pEdit->GetImpl())
|
| - ->ClearSelected();
|
| + m_pOwner->m_pEdit->FlagFocus(FALSE);
|
| + m_pOwner->m_pEdit->ClearSelected();
|
| } else {
|
| m_pOwner->Repaint(&m_pOwner->m_rtClient);
|
| }
|
| }
|
| }
|
| +
|
| void CFWL_ComboBoxImpDelegate::OnLButtonDown(CFWL_MsgMouse* pMsg) {
|
| if (m_pOwner->m_pProperties->m_dwStates & FWL_WGTSTATE_Disabled) {
|
| return;
|
| @@ -1497,6 +1086,7 @@ void CFWL_ComboBoxImpDelegate::OnLButtonDown(CFWL_MsgMouse* pMsg) {
|
| m_pOwner->Repaint(&m_pOwner->m_rtClient);
|
| }
|
| }
|
| +
|
| void CFWL_ComboBoxImpDelegate::OnLButtonUp(CFWL_MsgMouse* pMsg) {
|
| m_pOwner->m_bLButtonDown = FALSE;
|
| if (m_pOwner->m_rtBtn.Contains(pMsg->m_fx, pMsg->m_fy)) {
|
| @@ -1506,6 +1096,7 @@ void CFWL_ComboBoxImpDelegate::OnLButtonUp(CFWL_MsgMouse* pMsg) {
|
| }
|
| m_pOwner->Repaint(&m_pOwner->m_rtBtn);
|
| }
|
| +
|
| void CFWL_ComboBoxImpDelegate::OnMouseMove(CFWL_MsgMouse* pMsg) {
|
| int32_t iOldState = m_pOwner->m_iBtnState;
|
| if (m_pOwner->m_rtBtn.Contains(pMsg->m_fx, pMsg->m_fy)) {
|
| @@ -1520,6 +1111,7 @@ void CFWL_ComboBoxImpDelegate::OnMouseMove(CFWL_MsgMouse* pMsg) {
|
| m_pOwner->Repaint(&m_pOwner->m_rtBtn);
|
| }
|
| }
|
| +
|
| void CFWL_ComboBoxImpDelegate::OnMouseLeave(CFWL_MsgMouse* pMsg) {
|
| if (!m_pOwner->IsDropListShowed() &&
|
| !((m_pOwner->m_pProperties->m_dwStates & FWL_WGTSTATE_Disabled) ==
|
| @@ -1528,23 +1120,23 @@ void CFWL_ComboBoxImpDelegate::OnMouseLeave(CFWL_MsgMouse* pMsg) {
|
| m_pOwner->Repaint(&m_pOwner->m_rtBtn);
|
| }
|
| }
|
| +
|
| void CFWL_ComboBoxImpDelegate::OnKey(CFWL_MsgKey* pMsg) {
|
| uint32_t dwKeyCode = pMsg->m_dwKeyCode;
|
| if (dwKeyCode == FWL_VKEY_Tab) {
|
| m_pOwner->DispatchKeyEvent(pMsg);
|
| return;
|
| }
|
| - if (pMsg->m_pDstTarget == m_pOwner->m_pInterface)
|
| + if (pMsg->m_pDstTarget == m_pOwner)
|
| DoSubCtrlKey(pMsg);
|
| }
|
| +
|
| void CFWL_ComboBoxImpDelegate::DoSubCtrlKey(CFWL_MsgKey* pMsg) {
|
| uint32_t dwKeyCode = pMsg->m_dwKeyCode;
|
| const bool bUp = dwKeyCode == FWL_VKEY_Up;
|
| const bool bDown = dwKeyCode == FWL_VKEY_Down;
|
| if (bUp || bDown) {
|
| - int32_t iCount =
|
| - static_cast<CFWL_ComboListImp*>(m_pOwner->m_pListBox->GetImpl())
|
| - ->CountItems();
|
| + int32_t iCount = m_pOwner->m_pListBox->CountItems();
|
| if (iCount < 1) {
|
| return;
|
| }
|
| @@ -1554,15 +1146,13 @@ void CFWL_ComboBoxImpDelegate::DoSubCtrlKey(CFWL_MsgKey* pMsg) {
|
| if (bDropDown && m_pOwner->m_pEdit) {
|
| CFX_WideString wsText;
|
| m_pOwner->m_pEdit->GetText(wsText);
|
| - iCurSel = static_cast<CFWL_ComboListImp*>(m_pOwner->m_pListBox->GetImpl())
|
| - ->MatchItem(wsText);
|
| + iCurSel = m_pOwner->m_pListBox->MatchItem(wsText);
|
| if (iCurSel >= 0) {
|
| CFX_WideString wsTemp;
|
| IFWL_ComboBoxDP* pData = static_cast<IFWL_ComboBoxDP*>(
|
| m_pOwner->m_pProperties->m_pDataProvider);
|
| - IFWL_ListItem* hItem = pData->GetItem(m_pOwner->m_pInterface, iCurSel);
|
| - static_cast<CFWL_ComboListImp*>(m_pOwner->m_pListBox->GetImpl())
|
| - ->GetItemText(hItem, wsTemp);
|
| + IFWL_ListItem* hItem = pData->GetItem(m_pOwner, iCurSel);
|
| + m_pOwner->m_pListBox->GetItemText(hItem, wsTemp);
|
| bMatchEqual = wsText == wsTemp;
|
| }
|
| }
|
| @@ -1592,6 +1182,7 @@ void CFWL_ComboBoxImpDelegate::DoSubCtrlKey(CFWL_MsgKey* pMsg) {
|
| pDelegate->OnProcessMessage(pMsg);
|
| }
|
| }
|
| +
|
| void CFWL_ComboBoxImpDelegate::DisForm_OnProcessMessage(
|
| CFWL_Message* pMessage) {
|
| if (!pMessage)
|
| @@ -1671,6 +1262,7 @@ void CFWL_ComboBoxImpDelegate::DisForm_OnLButtonDown(CFWL_MsgMouse* pMsg) {
|
| }
|
| }
|
| }
|
| +
|
| void CFWL_ComboBoxImpDelegate::DisForm_OnFocusChanged(CFWL_Message* pMsg,
|
| FX_BOOL bSet) {
|
| if (bSet) {
|
| @@ -1692,13 +1284,13 @@ void CFWL_ComboBoxImpDelegate::DisForm_OnFocusChanged(CFWL_Message* pMsg,
|
| pDelegate->OnProcessMessage(&msg);
|
| }
|
| }
|
| +
|
| void CFWL_ComboBoxImpDelegate::DisForm_OnKey(CFWL_MsgKey* pMsg) {
|
| uint32_t dwKeyCode = pMsg->m_dwKeyCode;
|
| const bool bUp = dwKeyCode == FWL_VKEY_Up;
|
| const bool bDown = dwKeyCode == FWL_VKEY_Down;
|
| if (bUp || bDown) {
|
| - CFWL_ComboListImp* pComboList =
|
| - static_cast<CFWL_ComboListImp*>(m_pOwner->m_pListBox->GetImpl());
|
| + IFWL_ComboList* pComboList = m_pOwner->m_pListBox.get();
|
| int32_t iCount = pComboList->CountItems();
|
| if (iCount < 1) {
|
| return;
|
| @@ -1738,9 +1330,8 @@ void CFWL_ComboBoxImpDelegate::DisForm_OnKey(CFWL_MsgKey* pMsg) {
|
| }
|
| }
|
|
|
| -CFWL_ComboProxyImpDelegate::CFWL_ComboProxyImpDelegate(
|
| - IFWL_Form* pForm,
|
| - CFWL_ComboBoxImp* pComboBox)
|
| +CFWL_ComboProxyImpDelegate::CFWL_ComboProxyImpDelegate(IFWL_Form* pForm,
|
| + IFWL_ComboBox* pComboBox)
|
| : m_bLButtonDown(FALSE),
|
| m_bLButtonUpSelf(FALSE),
|
| m_fStartPos(0),
|
| @@ -1814,6 +1405,7 @@ void CFWL_ComboProxyImpDelegate::OnLButtonDown(CFWL_MsgMouse* pMsg) {
|
| m_pComboBox->ShowDropList(FALSE);
|
| }
|
| }
|
| +
|
| void CFWL_ComboProxyImpDelegate::OnLButtonUp(CFWL_MsgMouse* pMsg) {
|
| m_bLButtonDown = FALSE;
|
| IFWL_App* pApp = m_pForm->GetOwnerApp();
|
| @@ -1835,10 +1427,13 @@ void CFWL_ComboProxyImpDelegate::OnLButtonUp(CFWL_MsgMouse* pMsg) {
|
| m_bLButtonUpSelf = TRUE;
|
| }
|
| }
|
| +
|
| void CFWL_ComboProxyImpDelegate::OnMouseMove(CFWL_MsgMouse* pMsg) {}
|
| +
|
| void CFWL_ComboProxyImpDelegate::OnDeactive(CFWL_MsgDeactivate* pMsg) {
|
| m_pComboBox->ShowDropList(FALSE);
|
| }
|
| +
|
| void CFWL_ComboProxyImpDelegate::OnFocusChanged(CFWL_MsgKillFocus* pMsg,
|
| FX_BOOL bSet) {
|
| if (!bSet) {
|
|
|