Index: xfa/fwl/core/ifwl_combobox.cpp |
diff --git a/xfa/fwl/core/ifwl_combobox.cpp b/xfa/fwl/core/ifwl_combobox.cpp |
index 6299632e93526df209c96bf68fd692455f4317e3..c26a9fc9f1f3391addad0d40c994682d41954773 100644 |
--- a/xfa/fwl/core/ifwl_combobox.cpp |
+++ b/xfa/fwl/core/ifwl_combobox.cpp |
@@ -16,8 +16,6 @@ |
#include "xfa/fwl/core/cfwl_widgetmgr.h" |
#include "xfa/fwl/core/fwl_noteimp.h" |
#include "xfa/fwl/core/ifwl_app.h" |
-#include "xfa/fwl/core/ifwl_comboboxproxy.h" |
-#include "xfa/fwl/core/ifwl_comboedit.h" |
#include "xfa/fwl/core/ifwl_formproxy.h" |
#include "xfa/fwl/core/ifwl_themeprovider.h" |
@@ -65,27 +63,28 @@ FWL_Type IFWL_ComboBox::GetClassID() const { |
} |
void IFWL_ComboBox::GetWidgetRect(CFX_RectF& rect, bool bAutoSize) { |
- if (bAutoSize) { |
- rect.Reset(); |
- bool bIsDropDown = IsDropDownStyle(); |
- if (bIsDropDown && m_pEdit) { |
- m_pEdit->GetWidgetRect(rect, true); |
- } else { |
- rect.width = 100; |
- rect.height = 16; |
- } |
- if (!m_pProperties->m_pThemeProvider) { |
- ResetTheme(); |
- } |
- FX_FLOAT* pFWidth = static_cast<FX_FLOAT*>( |
- GetThemeCapacity(CFWL_WidgetCapacity::ScrollBarWidth)); |
- if (!pFWidth) |
- return; |
- rect.Inflate(0, 0, *pFWidth, 0); |
- IFWL_Widget::GetWidgetRect(rect, true); |
- } else { |
+ if (!bAutoSize) { |
rect = m_pProperties->m_rtWidget; |
+ return; |
+ } |
+ |
+ rect.Reset(); |
+ if (IsDropDownStyle() && m_pEdit) { |
+ m_pEdit->GetWidgetRect(rect, true); |
+ } else { |
+ rect.width = 100; |
+ rect.height = 16; |
} |
+ if (!m_pProperties->m_pThemeProvider) |
+ ResetTheme(); |
+ |
+ FX_FLOAT* pFWidth = static_cast<FX_FLOAT*>( |
+ GetThemeCapacity(CFWL_WidgetCapacity::ScrollBarWidth)); |
+ if (!pFWidth) |
+ return; |
+ |
+ rect.Inflate(0, 0, *pFWidth, 0); |
+ IFWL_Widget::GetWidgetRect(rect, true); |
} |
void IFWL_ComboBox::ModifyStylesEx(uint32_t dwStylesExAdded, |
@@ -94,11 +93,12 @@ void IFWL_ComboBox::ModifyStylesEx(uint32_t dwStylesExAdded, |
DisForm_ModifyStylesEx(dwStylesExAdded, dwStylesExRemoved); |
return; |
} |
+ |
bool bAddDropDown = !!(dwStylesExAdded & FWL_STYLEEXT_CMB_DropDown); |
bool bRemoveDropDown = !!(dwStylesExRemoved & FWL_STYLEEXT_CMB_DropDown); |
if (bAddDropDown && !m_pEdit) { |
- m_pEdit.reset(new IFWL_ComboEdit( |
- m_pOwnerApp, pdfium::MakeUnique<CFWL_WidgetProperties>(), nullptr)); |
+ m_pEdit = pdfium::MakeUnique<IFWL_ComboEdit>( |
+ m_pOwnerApp, pdfium::MakeUnique<CFWL_WidgetProperties>(), nullptr); |
m_pEdit->SetOuter(this); |
m_pEdit->SetParent(this); |
} else if (bRemoveDropDown && m_pEdit) { |
@@ -112,17 +112,15 @@ void IFWL_ComboBox::Update() { |
DisForm_Update(); |
return; |
} |
- if (IsLocked()) { |
+ if (IsLocked()) |
return; |
- } |
+ |
ResetTheme(); |
- bool bDropDown = IsDropDownStyle(); |
- if (bDropDown && m_pEdit) { |
+ if (IsDropDownStyle() && m_pEdit) |
ResetEditAlignment(); |
- } |
- if (!m_pProperties->m_pThemeProvider) { |
+ if (!m_pProperties->m_pThemeProvider) |
m_pProperties->m_pThemeProvider = GetAvailableTheme(); |
- } |
+ |
Layout(); |
CFWL_ThemePart part; |
part.m_pWidget = this; |
@@ -132,9 +130,8 @@ void IFWL_ComboBox::Update() { |
} |
FWL_WidgetHit IFWL_ComboBox::HitTest(FX_FLOAT fx, FX_FLOAT fy) { |
- if (m_pWidgetMgr->IsFormDisabled()) { |
+ if (m_pWidgetMgr->IsFormDisabled()) |
return DisForm_HitTest(fx, fy); |
- } |
return IFWL_Widget::HitTest(fx, fy); |
} |
@@ -144,38 +141,39 @@ void IFWL_ComboBox::DrawWidget(CFX_Graphics* pGraphics, |
DisForm_DrawWidget(pGraphics, pMatrix); |
return; |
} |
+ |
if (!pGraphics) |
return; |
if (!m_pProperties->m_pThemeProvider) |
return; |
+ |
IFWL_ThemeProvider* pTheme = m_pProperties->m_pThemeProvider; |
- bool bIsDropDown = IsDropDownStyle(); |
- if (HasBorder()) { |
+ if (HasBorder()) |
DrawBorder(pGraphics, CFWL_Part::Border, pTheme, pMatrix); |
- } |
- if (HasEdge()) { |
+ if (HasEdge()) |
DrawEdge(pGraphics, CFWL_Part::Edge, pTheme, pMatrix); |
- } |
- if (!bIsDropDown) { |
+ |
+ if (!IsDropDownStyle()) { |
CFX_RectF rtTextBk(m_rtClient); |
rtTextBk.width -= m_rtBtn.width; |
+ |
CFWL_ThemeBackground param; |
param.m_pWidget = this; |
param.m_iPart = CFWL_Part::Background; |
param.m_pGraphics = pGraphics; |
- if (pMatrix) { |
+ if (pMatrix) |
param.m_matrix.Concat(*pMatrix); |
- } |
param.m_rtPart = rtTextBk; |
+ |
if (m_iCurSel >= 0) { |
IFWL_ListBoxDP* pData = |
static_cast<IFWL_ListBoxDP*>(m_pListBox->GetDataProvider()); |
void* p = pData->GetItemData(m_pListBox.get(), |
pData->GetItem(m_pListBox.get(), m_iCurSel)); |
- if (p) { |
+ if (p) |
param.m_pData = p; |
- } |
} |
+ |
if (m_pProperties->m_dwStates & FWL_WGTSTATE_Disabled) { |
param.m_dwStates = CFWL_PartState_Disabled; |
} else if ((m_pProperties->m_dwStates & FWL_WGTSTATE_Focused) && |
@@ -185,14 +183,17 @@ void IFWL_ComboBox::DrawWidget(CFX_Graphics* pGraphics, |
param.m_dwStates = CFWL_PartState_Normal; |
} |
pTheme->DrawBackground(¶m); |
+ |
if (m_iCurSel >= 0) { |
if (!m_pListBox) |
return; |
+ |
CFX_WideString wsText; |
IFWL_ComboBoxDP* pData = |
static_cast<IFWL_ComboBoxDP*>(m_pProperties->m_pDataProvider); |
CFWL_ListItem* hItem = pData->GetItem(this, m_iCurSel); |
m_pListBox->GetItemText(hItem, wsText); |
+ |
CFWL_ThemeText theme_text; |
theme_text.m_pWidget = this; |
theme_text.m_iPart = CFWL_Part::Caption; |
@@ -209,23 +210,23 @@ void IFWL_ComboBox::DrawWidget(CFX_Graphics* pGraphics, |
pTheme->DrawText(&theme_text); |
} |
} |
- { |
- CFWL_ThemeBackground param; |
- param.m_pWidget = this; |
- param.m_iPart = CFWL_Part::DropDownButton; |
- param.m_dwStates = (m_pProperties->m_dwStates & FWL_WGTSTATE_Disabled) |
- ? CFWL_PartState_Disabled |
- : m_iBtnState; |
- param.m_pGraphics = pGraphics; |
- param.m_matrix.Concat(*pMatrix); |
- param.m_rtPart = m_rtBtn; |
- pTheme->DrawBackground(¶m); |
- } |
+ |
+ CFWL_ThemeBackground param; |
+ param.m_pWidget = this; |
+ param.m_iPart = CFWL_Part::DropDownButton; |
+ param.m_dwStates = (m_pProperties->m_dwStates & FWL_WGTSTATE_Disabled) |
+ ? CFWL_PartState_Disabled |
+ : m_iBtnState; |
+ param.m_pGraphics = pGraphics; |
+ param.m_matrix.Concat(*pMatrix); |
+ param.m_rtPart = m_rtBtn; |
+ pTheme->DrawBackground(¶m); |
} |
void IFWL_ComboBox::SetThemeProvider(IFWL_ThemeProvider* pThemeProvider) { |
if (!pThemeProvider) |
return; |
+ |
m_pProperties->m_pThemeProvider = pThemeProvider; |
if (m_pListBox) |
m_pListBox->SetThemeProvider(pThemeProvider); |
@@ -233,15 +234,10 @@ void IFWL_ComboBox::SetThemeProvider(IFWL_ThemeProvider* pThemeProvider) { |
m_pEdit->SetThemeProvider(pThemeProvider); |
} |
-int32_t IFWL_ComboBox::GetCurSel() const { |
- return m_iCurSel; |
-} |
- |
void IFWL_ComboBox::SetCurSel(int32_t iSel) { |
int32_t iCount = m_pListBox->CountItems(); |
bool bClearSel = iSel < 0 || iSel >= iCount; |
- bool bDropDown = IsDropDownStyle(); |
- if (bDropDown && m_pEdit) { |
+ if (IsDropDownStyle() && m_pEdit) { |
if (bClearSel) { |
m_pEdit->SetText(CFX_WideString()); |
} else { |
@@ -258,8 +254,7 @@ void IFWL_ComboBox::SetCurSel(int32_t iSel) { |
} |
void IFWL_ComboBox::SetStates(uint32_t dwStates, bool bSet) { |
- bool bIsDropDown = IsDropDownStyle(); |
- if (bIsDropDown && m_pEdit) |
+ if (IsDropDownStyle() && m_pEdit) |
m_pEdit->SetStates(dwStates, bSet); |
if (m_pListBox) |
m_pListBox->SetStates(dwStates, bSet); |
@@ -269,6 +264,7 @@ void IFWL_ComboBox::SetStates(uint32_t dwStates, bool bSet) { |
void IFWL_ComboBox::SetEditText(const CFX_WideString& wsText) { |
if (!m_pEdit) |
return; |
+ |
m_pEdit->SetText(wsText); |
m_pEdit->Update(); |
} |
@@ -293,76 +289,20 @@ void IFWL_ComboBox::OpenDropDownList(bool bActivate) { |
ShowDropList(bActivate); |
} |
-bool IFWL_ComboBox::EditCanUndo() { |
- return m_pEdit->CanUndo(); |
-} |
- |
-bool IFWL_ComboBox::EditCanRedo() { |
- return m_pEdit->CanRedo(); |
-} |
- |
-bool IFWL_ComboBox::EditUndo() { |
- return m_pEdit->Undo(); |
-} |
- |
-bool IFWL_ComboBox::EditRedo() { |
- return m_pEdit->Redo(); |
-} |
- |
-bool IFWL_ComboBox::EditCanCopy() { |
- return m_pEdit->CountSelRanges() > 0; |
-} |
- |
-bool IFWL_ComboBox::EditCanCut() { |
- if (m_pEdit->GetStylesEx() & FWL_STYLEEXT_EDT_ReadOnly) { |
- return false; |
- } |
- return m_pEdit->CountSelRanges() > 0; |
-} |
- |
-bool IFWL_ComboBox::EditCanSelectAll() { |
- return m_pEdit->GetTextLength() > 0; |
-} |
- |
-bool IFWL_ComboBox::EditCopy(CFX_WideString& wsCopy) { |
- return m_pEdit->Copy(wsCopy); |
-} |
- |
-bool IFWL_ComboBox::EditCut(CFX_WideString& wsCut) { |
- return m_pEdit->Cut(wsCut); |
-} |
- |
-bool IFWL_ComboBox::EditPaste(const CFX_WideString& wsPaste) { |
- return m_pEdit->Paste(wsPaste); |
-} |
- |
-bool IFWL_ComboBox::EditSelectAll() { |
- m_pEdit->AddSelRange(0); |
- return true; |
-} |
- |
-bool IFWL_ComboBox::EditDelete() { |
- m_pEdit->ClearText(); |
- return true; |
-} |
- |
-bool IFWL_ComboBox::EditDeSelect() { |
- m_pEdit->ClearSelections(); |
- return true; |
-} |
- |
-void IFWL_ComboBox::GetBBox(CFX_RectF& rect) { |
+void IFWL_ComboBox::GetBBox(CFX_RectF& rect) const { |
if (m_pWidgetMgr->IsFormDisabled()) { |
DisForm_GetBBox(rect); |
return; |
} |
+ |
rect = m_pProperties->m_rtWidget; |
- if (m_pListBox && IsDropListVisible()) { |
- CFX_RectF rtList; |
- m_pListBox->GetWidgetRect(rtList); |
- rtList.Offset(rect.left, rect.top); |
- rect.Union(rtList); |
- } |
+ if (!m_pListBox || !IsDropListVisible()) |
+ return; |
+ |
+ CFX_RectF rtList; |
+ m_pListBox->GetWidgetRect(rtList); |
+ rtList.Offset(rect.left, rect.top); |
+ rect.Union(rtList); |
} |
void IFWL_ComboBox::EditModifyStylesEx(uint32_t dwStylesExAdded, |
@@ -383,9 +323,8 @@ void IFWL_ComboBox::DrawStretchHandler(CFX_Graphics* pGraphics, |
param.m_iPart = CFWL_Part::StretchHandler; |
param.m_dwStates = CFWL_PartState_Normal; |
param.m_pWidget = this; |
- if (pMatrix) { |
+ if (pMatrix) |
param.m_matrix.Concat(*pMatrix); |
- } |
param.m_rtPart = m_rtHandler; |
m_pProperties->m_pThemeProvider->DrawBackground(¶m); |
} |
@@ -393,78 +332,75 @@ void IFWL_ComboBox::DrawStretchHandler(CFX_Graphics* pGraphics, |
void IFWL_ComboBox::ShowDropList(bool bActivate) { |
if (m_pWidgetMgr->IsFormDisabled()) |
return DisForm_ShowDropList(bActivate); |
- |
- bool bDropList = IsDropListVisible(); |
- if (bDropList == bActivate) |
+ if (IsDropListVisible() == bActivate) |
return; |
if (!m_pComboBoxProxy) |
InitProxyForm(); |
m_pComboBoxProxy->Reset(); |
- if (bActivate) { |
- m_pListBox->ChangeSelected(m_iCurSel); |
- ResetListItemAlignment(); |
- uint32_t dwStyleAdd = m_pProperties->m_dwStyleExes & |
- (FWL_STYLEEXT_CMB_Sort | FWL_STYLEEXT_CMB_OwnerDraw); |
- m_pListBox->ModifyStylesEx(dwStyleAdd, 0); |
- m_pListBox->GetWidgetRect(m_rtList, true); |
- FX_FLOAT fHeight = GetListHeight(); |
- if (fHeight > 0) { |
- if (m_rtList.height > GetListHeight()) { |
- m_rtList.height = GetListHeight(); |
- m_pListBox->ModifyStyles(FWL_WGTSTYLE_VScroll, 0); |
- } |
- } |
- CFX_RectF rtAnchor; |
- rtAnchor.Set(0, 0, m_pProperties->m_rtWidget.width, |
- m_pProperties->m_rtWidget.height); |
- FX_FLOAT fMinHeight = 0; |
- if (m_rtList.width < m_rtClient.width) { |
- m_rtList.width = m_rtClient.width; |
- } |
- m_rtProxy = m_rtList; |
- if (m_pProperties->m_dwStyleExes & FWL_STYLEEXT_CMB_ListDrag) { |
- m_rtProxy.height += m_fComboFormHandler; |
- } |
- GetPopupPos(fMinHeight, m_rtProxy.height, rtAnchor, m_rtProxy); |
- if (m_pProperties->m_dwStyleExes & FWL_STYLEEXT_CMB_ListDrag) { |
- FX_FLOAT fx = 0; |
- FX_FLOAT fy = m_rtClient.top + m_rtClient.height / 2; |
- TransformTo(nullptr, fx, fy); |
- m_bUpFormHandler = fy > m_rtProxy.top; |
- if (m_bUpFormHandler) { |
- m_rtHandler.Set(0, 0, m_rtList.width, m_fComboFormHandler); |
- m_rtList.top = m_fComboFormHandler; |
- } else { |
- m_rtHandler.Set(0, m_rtList.height, m_rtList.width, |
- m_fComboFormHandler); |
- } |
- } |
- m_pComboBoxProxy->SetWidgetRect(m_rtProxy); |
- m_pComboBoxProxy->Update(); |
- m_pListBox->SetWidgetRect(m_rtList); |
- m_pListBox->Update(); |
- CFWL_EvtCmbPreDropDown ev; |
- ev.m_pSrcTarget = this; |
- DispatchEvent(&ev); |
- m_fItemHeight = m_pListBox->GetItemHeight(); |
- m_pListBox->SetFocus(true); |
- m_pComboBoxProxy->DoModal(); |
- m_pListBox->SetFocus(false); |
- } else { |
+ if (!bActivate) { |
m_pComboBoxProxy->EndDoModal(); |
+ |
CFWL_EvtCmbCloseUp ev; |
ev.m_pSrcTarget = this; |
DispatchEvent(&ev); |
+ |
m_bLButtonDown = false; |
m_pListBox->SetNotifyOwner(true); |
SetFocus(true); |
+ return; |
} |
-} |
-bool IFWL_ComboBox::IsDropListVisible() { |
- return m_pComboBoxProxy && |
- !(m_pComboBoxProxy->GetStates() & FWL_WGTSTATE_Invisible); |
+ m_pListBox->ChangeSelected(m_iCurSel); |
+ ResetListItemAlignment(); |
+ |
+ uint32_t dwStyleAdd = m_pProperties->m_dwStyleExes & |
+ (FWL_STYLEEXT_CMB_Sort | FWL_STYLEEXT_CMB_OwnerDraw); |
+ m_pListBox->ModifyStylesEx(dwStyleAdd, 0); |
+ m_pListBox->GetWidgetRect(m_rtList, true); |
+ FX_FLOAT fHeight = GetListHeight(); |
+ if (fHeight > 0 && m_rtList.height > GetListHeight()) { |
+ m_rtList.height = GetListHeight(); |
+ m_pListBox->ModifyStyles(FWL_WGTSTYLE_VScroll, 0); |
+ } |
+ |
+ CFX_RectF rtAnchor; |
+ rtAnchor.Set(0, 0, m_pProperties->m_rtWidget.width, |
+ m_pProperties->m_rtWidget.height); |
+ |
+ m_rtList.width = std::max(m_rtList.width, m_rtClient.width); |
+ m_rtProxy = m_rtList; |
+ if (m_pProperties->m_dwStyleExes & FWL_STYLEEXT_CMB_ListDrag) |
+ m_rtProxy.height += m_fComboFormHandler; |
+ |
+ FX_FLOAT fMinHeight = 0; |
+ GetPopupPos(fMinHeight, m_rtProxy.height, rtAnchor, m_rtProxy); |
+ if (m_pProperties->m_dwStyleExes & FWL_STYLEEXT_CMB_ListDrag) { |
+ FX_FLOAT fx = 0; |
+ FX_FLOAT fy = m_rtClient.top + m_rtClient.height / 2; |
+ TransformTo(nullptr, fx, fy); |
+ |
+ m_bUpFormHandler = fy > m_rtProxy.top; |
+ if (m_bUpFormHandler) { |
+ m_rtHandler.Set(0, 0, m_rtList.width, m_fComboFormHandler); |
+ m_rtList.top = m_fComboFormHandler; |
+ } else { |
+ m_rtHandler.Set(0, m_rtList.height, m_rtList.width, m_fComboFormHandler); |
+ } |
+ } |
+ m_pComboBoxProxy->SetWidgetRect(m_rtProxy); |
+ m_pComboBoxProxy->Update(); |
+ m_pListBox->SetWidgetRect(m_rtList); |
+ m_pListBox->Update(); |
+ |
+ CFWL_EvtCmbPreDropDown ev; |
+ ev.m_pSrcTarget = this; |
+ DispatchEvent(&ev); |
+ |
+ m_fItemHeight = m_pListBox->GetItemHeight(); |
+ m_pListBox->SetFocus(true); |
+ m_pComboBoxProxy->DoModal(); |
+ m_pListBox->SetFocus(false); |
} |
void IFWL_ComboBox::MatchEditText() { |
@@ -473,9 +409,8 @@ void IFWL_ComboBox::MatchEditText() { |
int32_t iMatch = m_pListBox->MatchItem(wsText); |
if (iMatch != m_iCurSel) { |
m_pListBox->ChangeSelected(iMatch); |
- if (iMatch >= 0) { |
+ if (iMatch >= 0) |
SyncEditText(iMatch); |
- } |
} else if (iMatch >= 0) { |
m_pEdit->SetSelected(); |
} |
@@ -494,35 +429,37 @@ void IFWL_ComboBox::SyncEditText(int32_t iListItem) { |
} |
void IFWL_ComboBox::Layout() { |
- if (m_pWidgetMgr->IsFormDisabled()) { |
+ if (m_pWidgetMgr->IsFormDisabled()) |
return DisForm_Layout(); |
- } |
+ |
GetClientRect(m_rtClient); |
FX_FLOAT* pFWidth = static_cast<FX_FLOAT*>( |
GetThemeCapacity(CFWL_WidgetCapacity::ScrollBarWidth)); |
if (!pFWidth) |
return; |
+ |
FX_FLOAT fBtn = *pFWidth; |
m_rtBtn.Set(m_rtClient.right() - fBtn, m_rtClient.top, fBtn, |
m_rtClient.height); |
- bool bIsDropDown = IsDropDownStyle(); |
- if (bIsDropDown && m_pEdit) { |
- CFX_RectF rtEdit; |
- rtEdit.Set(m_rtClient.left, m_rtClient.top, m_rtClient.width - fBtn, |
- m_rtClient.height); |
- m_pEdit->SetWidgetRect(rtEdit); |
- if (m_iCurSel >= 0) { |
- CFX_WideString wsText; |
- IFWL_ComboBoxDP* pData = |
- static_cast<IFWL_ComboBoxDP*>(m_pProperties->m_pDataProvider); |
- CFWL_ListItem* hItem = pData->GetItem(this, m_iCurSel); |
- m_pListBox->GetItemText(hItem, wsText); |
- m_pEdit->LockUpdate(); |
- m_pEdit->SetText(wsText); |
- m_pEdit->UnlockUpdate(); |
- } |
- m_pEdit->Update(); |
+ if (!IsDropDownStyle() || !m_pEdit) |
+ return; |
+ |
+ CFX_RectF rtEdit; |
+ rtEdit.Set(m_rtClient.left, m_rtClient.top, m_rtClient.width - fBtn, |
+ m_rtClient.height); |
+ m_pEdit->SetWidgetRect(rtEdit); |
+ |
+ if (m_iCurSel >= 0) { |
+ CFX_WideString wsText; |
+ IFWL_ComboBoxDP* pData = |
+ static_cast<IFWL_ComboBoxDP*>(m_pProperties->m_pDataProvider); |
+ CFWL_ListItem* hItem = pData->GetItem(this, m_iCurSel); |
+ m_pListBox->GetItemText(hItem, wsText); |
+ m_pEdit->LockUpdate(); |
+ m_pEdit->SetText(wsText); |
+ m_pEdit->UnlockUpdate(); |
} |
+ m_pEdit->Update(); |
} |
void IFWL_ComboBox::ResetTheme() { |
@@ -540,9 +477,9 @@ void IFWL_ComboBox::ResetTheme() { |
void IFWL_ComboBox::ResetEditAlignment() { |
if (!m_pEdit) |
return; |
- uint32_t dwStylExes = m_pProperties->m_dwStyleExes; |
+ |
uint32_t dwAdd = 0; |
- switch (dwStylExes & FWL_STYLEEXT_CMB_EditHAlignMask) { |
+ switch (m_pProperties->m_dwStyleExes & FWL_STYLEEXT_CMB_EditHAlignMask) { |
case FWL_STYLEEXT_CMB_EditHCenter: { |
dwAdd |= FWL_STYLEEXT_EDT_HCenter; |
break; |
@@ -553,7 +490,7 @@ void IFWL_ComboBox::ResetEditAlignment() { |
} |
default: { dwAdd |= FWL_STYLEEXT_EDT_HNear; } |
} |
- switch (dwStylExes & FWL_STYLEEXT_CMB_EditVAlignMask) { |
+ switch (m_pProperties->m_dwStyleExes & FWL_STYLEEXT_CMB_EditVAlignMask) { |
case FWL_STYLEEXT_CMB_EditVCenter: { |
dwAdd |= FWL_STYLEEXT_EDT_VCenter; |
break; |
@@ -562,14 +499,16 @@ void IFWL_ComboBox::ResetEditAlignment() { |
dwAdd |= FWL_STYLEEXT_EDT_VFar; |
break; |
} |
- default: { dwAdd |= FWL_STYLEEXT_EDT_VNear; } |
+ default: { |
+ dwAdd |= FWL_STYLEEXT_EDT_VNear; |
+ break; |
+ } |
} |
- if (dwStylExes & FWL_STYLEEXT_CMB_EditJustified) { |
+ if (m_pProperties->m_dwStyleExes & FWL_STYLEEXT_CMB_EditJustified) |
dwAdd |= FWL_STYLEEXT_EDT_Justified; |
- } |
- if (dwStylExes & FWL_STYLEEXT_CMB_EditDistributed) { |
+ if (m_pProperties->m_dwStyleExes & FWL_STYLEEXT_CMB_EditDistributed) |
dwAdd |= FWL_STYLEEXT_EDT_Distributed; |
- } |
+ |
m_pEdit->ModifyStylesEx(dwAdd, FWL_STYLEEXT_EDT_HAlignMask | |
FWL_STYLEEXT_EDT_HAlignModeMask | |
FWL_STYLEEXT_EDT_VAlignMask); |
@@ -578,16 +517,21 @@ void IFWL_ComboBox::ResetEditAlignment() { |
void IFWL_ComboBox::ResetListItemAlignment() { |
if (!m_pListBox) |
return; |
- uint32_t dwStylExes = m_pProperties->m_dwStyleExes; |
+ |
uint32_t dwAdd = 0; |
- switch (dwStylExes & FWL_STYLEEXT_CMB_ListItemAlignMask) { |
+ switch (m_pProperties->m_dwStyleExes & FWL_STYLEEXT_CMB_ListItemAlignMask) { |
case FWL_STYLEEXT_CMB_ListItemCenterAlign: { |
dwAdd |= FWL_STYLEEXT_LTB_CenterAlign; |
+ break; |
} |
case FWL_STYLEEXT_CMB_ListItemRightAlign: { |
dwAdd |= FWL_STYLEEXT_LTB_RightAlign; |
+ break; |
+ } |
+ default: { |
+ dwAdd |= FWL_STYLEEXT_LTB_LeftAlign; |
+ break; |
} |
- default: { dwAdd |= FWL_STYLEEXT_LTB_LeftAlign; } |
} |
m_pListBox->ModifyStylesEx(dwAdd, FWL_STYLEEXT_CMB_ListItemAlignMask); |
} |
@@ -596,28 +540,30 @@ void IFWL_ComboBox::ProcessSelChanged(bool bLButtonUp) { |
IFWL_ComboBoxDP* pDatas = |
static_cast<IFWL_ComboBoxDP*>(m_pProperties->m_pDataProvider); |
m_iCurSel = pDatas->GetItemIndex(this, m_pListBox->GetSelItem(0)); |
- bool bDropDown = IsDropDownStyle(); |
- if (bDropDown) { |
- IFWL_ComboBoxDP* pData = |
- static_cast<IFWL_ComboBoxDP*>(m_pProperties->m_pDataProvider); |
- CFWL_ListItem* hItem = pData->GetItem(this, m_iCurSel); |
- if (hItem) { |
- CFX_WideString wsText; |
- pData->GetItemText(this, hItem, wsText); |
- if (m_pEdit) { |
- m_pEdit->SetText(wsText); |
- m_pEdit->Update(); |
- m_pEdit->SetSelected(); |
- } |
- CFWL_EvtCmbSelChanged ev; |
- ev.bLButtonUp = bLButtonUp; |
- ev.m_pSrcTarget = this; |
- ev.iArraySels.Add(m_iCurSel); |
- DispatchEvent(&ev); |
- } |
- } else { |
+ if (!IsDropDownStyle()) { |
Repaint(&m_rtClient); |
+ return; |
+ } |
+ |
+ IFWL_ComboBoxDP* pData = |
+ static_cast<IFWL_ComboBoxDP*>(m_pProperties->m_pDataProvider); |
+ CFWL_ListItem* hItem = pData->GetItem(this, m_iCurSel); |
+ if (!hItem) |
+ return; |
+ |
+ CFX_WideString wsText; |
+ pData->GetItemText(this, hItem, wsText); |
+ if (m_pEdit) { |
+ m_pEdit->SetText(wsText); |
+ m_pEdit->Update(); |
+ m_pEdit->SetSelected(); |
} |
+ |
+ CFWL_EvtCmbSelChanged ev; |
+ ev.bLButtonUp = bLButtonUp; |
+ ev.m_pSrcTarget = this; |
+ ev.iArraySels.Add(m_iCurSel); |
+ DispatchEvent(&ev); |
} |
void IFWL_ComboBox::InitProxyForm() { |
@@ -631,6 +577,8 @@ void IFWL_ComboBox::InitProxyForm() { |
prop->m_dwStyles = FWL_WGTSTYLE_Popup; |
prop->m_dwStates = FWL_WGTSTATE_Invisible; |
+ // TODO(dsinclair): Does this leak? I don't see a delete, but I'm not sure |
+ // if the SetParent call is going to transfer ownership. |
m_pComboBoxProxy = new IFWL_ComboBoxProxy(this, m_pOwnerApp, std::move(prop), |
m_pListBox.get()); |
m_pListBox->SetParent(m_pComboBoxProxy); |
@@ -646,7 +594,9 @@ void IFWL_ComboBox::DisForm_InitComboList() { |
prop->m_dwStyles = FWL_WGTSTYLE_Border | FWL_WGTSTYLE_VScroll; |
prop->m_dwStates = FWL_WGTSTATE_Invisible; |
prop->m_pThemeProvider = m_pProperties->m_pThemeProvider; |
- m_pListBox.reset(new IFWL_ComboList(m_pOwnerApp, std::move(prop), this)); |
+ |
+ m_pListBox = |
+ pdfium::MakeUnique<IFWL_ComboList>(m_pOwnerApp, std::move(prop), this); |
} |
void IFWL_ComboBox::DisForm_InitComboEdit() { |
@@ -656,32 +606,35 @@ void IFWL_ComboBox::DisForm_InitComboEdit() { |
auto prop = pdfium::MakeUnique<CFWL_WidgetProperties>(); |
prop->m_pParent = this; |
prop->m_pThemeProvider = m_pProperties->m_pThemeProvider; |
- m_pEdit.reset(new IFWL_ComboEdit(m_pOwnerApp, std::move(prop), this)); |
+ |
+ m_pEdit = |
+ pdfium::MakeUnique<IFWL_ComboEdit>(m_pOwnerApp, std::move(prop), this); |
m_pEdit->SetOuter(this); |
} |
void IFWL_ComboBox::DisForm_ShowDropList(bool bActivate) { |
- bool bDropList = DisForm_IsDropListVisible(); |
- if (bDropList == bActivate) { |
+ if (DisForm_IsDropListVisible() == bActivate) |
return; |
- } |
+ |
if (bActivate) { |
CFWL_EvtCmbPreDropDown preEvent; |
preEvent.m_pSrcTarget = this; |
DispatchEvent(&preEvent); |
+ |
IFWL_ComboList* pComboList = m_pListBox.get(); |
int32_t iItems = pComboList->CountItems(); |
- if (iItems < 1) { |
+ if (iItems < 1) |
return; |
- } |
+ |
ResetListItemAlignment(); |
pComboList->ChangeSelected(m_iCurSel); |
+ |
FX_FLOAT fItemHeight = pComboList->CalcItemHeight(); |
FX_FLOAT fBorder = GetBorderSize(); |
FX_FLOAT fPopupMin = 0.0f; |
- if (iItems > 3) { |
+ if (iItems > 3) |
fPopupMin = fItemHeight * 3 + fBorder * 2; |
- } |
+ |
FX_FLOAT fPopupMax = fItemHeight * iItems + fBorder * 2; |
CFX_RectF rtList; |
rtList.left = m_rtClient.left; |
@@ -689,17 +642,20 @@ void IFWL_ComboBox::DisForm_ShowDropList(bool bActivate) { |
rtList.top = 0; |
rtList.height = 0; |
GetPopupPos(fPopupMin, fPopupMax, m_pProperties->m_rtWidget, rtList); |
+ |
m_pListBox->SetWidgetRect(rtList); |
m_pListBox->Update(); |
} else { |
SetFocus(true); |
} |
+ |
m_pListBox->SetStates(FWL_WGTSTATE_Invisible, !bActivate); |
if (bActivate) { |
CFWL_EvtCmbPostDropDown postEvent; |
postEvent.m_pSrcTarget = this; |
DispatchEvent(&postEvent); |
} |
+ |
CFX_RectF rect; |
m_pListBox->GetWidgetRect(rect); |
rect.Inflate(2, 2); |
@@ -713,23 +669,22 @@ void IFWL_ComboBox::DisForm_ModifyStylesEx(uint32_t dwStylesExAdded, |
bool bAddDropDown = !!(dwStylesExAdded & FWL_STYLEEXT_CMB_DropDown); |
bool bDelDropDown = !!(dwStylesExRemoved & FWL_STYLEEXT_CMB_DropDown); |
+ |
dwStylesExRemoved &= ~FWL_STYLEEXT_CMB_DropDown; |
m_pProperties->m_dwStyleExes |= FWL_STYLEEXT_CMB_DropDown; |
- if (bAddDropDown) { |
+ |
+ if (bAddDropDown) |
m_pEdit->ModifyStylesEx(0, FWL_STYLEEXT_EDT_ReadOnly); |
- } else if (bDelDropDown) { |
+ else if (bDelDropDown) |
m_pEdit->ModifyStylesEx(FWL_STYLEEXT_EDT_ReadOnly, 0); |
- } |
IFWL_Widget::ModifyStylesEx(dwStylesExAdded, dwStylesExRemoved); |
} |
void IFWL_ComboBox::DisForm_Update() { |
- if (m_iLock) { |
+ if (m_iLock) |
return; |
- } |
- if (m_pEdit) { |
+ if (m_pEdit) |
ResetEditAlignment(); |
- } |
ResetTheme(); |
Layout(); |
} |
@@ -755,10 +710,9 @@ void IFWL_ComboBox::DisForm_DrawWidget(CFX_Graphics* pGraphics, |
IFWL_ThemeProvider* pTheme = m_pProperties->m_pThemeProvider; |
CFX_Matrix mtOrg; |
mtOrg.Set(1, 0, 0, 1, 0, 0); |
- if (pMatrix) { |
+ if (pMatrix) |
mtOrg = *pMatrix; |
- } |
- bool bListShowed = m_pListBox && DisForm_IsDropListVisible(); |
+ |
pGraphics->SaveGraphState(); |
pGraphics->ConcatMatrix(&mtOrg); |
if (!m_rtBtn.IsEmpty(0.1f)) { |
@@ -771,6 +725,7 @@ void IFWL_ComboBox::DisForm_DrawWidget(CFX_Graphics* pGraphics, |
pTheme->DrawBackground(¶m); |
} |
pGraphics->RestoreGraphState(); |
+ |
if (m_pEdit) { |
CFX_RectF rtEdit; |
m_pEdit->GetWidgetRect(rtEdit); |
@@ -779,7 +734,7 @@ void IFWL_ComboBox::DisForm_DrawWidget(CFX_Graphics* pGraphics, |
mt.Concat(mtOrg); |
m_pEdit->DrawWidget(pGraphics, &mt); |
} |
- if (bListShowed) { |
+ if (m_pListBox && DisForm_IsDropListVisible()) { |
CFX_RectF rtList; |
m_pListBox->GetWidgetRect(rtList); |
CFX_Matrix mt; |
@@ -789,14 +744,15 @@ void IFWL_ComboBox::DisForm_DrawWidget(CFX_Graphics* pGraphics, |
} |
} |
-void IFWL_ComboBox::DisForm_GetBBox(CFX_RectF& rect) { |
+void IFWL_ComboBox::DisForm_GetBBox(CFX_RectF& rect) const { |
rect = m_pProperties->m_rtWidget; |
- if (m_pListBox && DisForm_IsDropListVisible()) { |
- CFX_RectF rtList; |
- m_pListBox->GetWidgetRect(rtList); |
- rtList.Offset(rect.left, rect.top); |
- rect.Union(rtList); |
- } |
+ if (!m_pListBox || !DisForm_IsDropListVisible()) |
+ return; |
+ |
+ CFX_RectF rtList; |
+ m_pListBox->GetWidgetRect(rtList); |
+ rtList.Offset(rect.left, rect.top); |
+ rect.Union(rtList); |
} |
void IFWL_ComboBox::DisForm_Layout() { |
@@ -806,36 +762,40 @@ void IFWL_ComboBox::DisForm_Layout() { |
GetThemeCapacity(CFWL_WidgetCapacity::ScrollBarWidth)); |
if (!pFWidth) |
return; |
+ |
FX_FLOAT borderWidth = 1; |
FX_FLOAT fBtn = *pFWidth; |
if (!(GetStylesEx() & FWL_STYLEEXT_CMB_ReadOnly)) { |
m_rtBtn.Set(m_rtClient.right() - fBtn, m_rtClient.top + borderWidth, |
fBtn - borderWidth, m_rtClient.height - 2 * borderWidth); |
} |
+ |
CFX_RectF* pUIMargin = |
static_cast<CFX_RectF*>(GetThemeCapacity(CFWL_WidgetCapacity::UIMargin)); |
if (pUIMargin) { |
m_rtContent.Deflate(pUIMargin->left, pUIMargin->top, pUIMargin->width, |
pUIMargin->height); |
} |
- bool bIsDropDown = IsDropDownStyle(); |
- if (bIsDropDown && m_pEdit) { |
- CFX_RectF rtEdit; |
- rtEdit.Set(m_rtContent.left, m_rtContent.top, m_rtContent.width - fBtn, |
- m_rtContent.height); |
- m_pEdit->SetWidgetRect(rtEdit); |
- if (m_iCurSel >= 0) { |
- CFX_WideString wsText; |
- IFWL_ComboBoxDP* pData = |
- static_cast<IFWL_ComboBoxDP*>(m_pProperties->m_pDataProvider); |
- CFWL_ListItem* hItem = pData->GetItem(this, m_iCurSel); |
- m_pListBox->GetItemText(hItem, wsText); |
- m_pEdit->LockUpdate(); |
- m_pEdit->SetText(wsText); |
- m_pEdit->UnlockUpdate(); |
- } |
- m_pEdit->Update(); |
+ |
+ if (!IsDropDownStyle() || !m_pEdit) |
+ return; |
+ |
+ CFX_RectF rtEdit; |
+ rtEdit.Set(m_rtContent.left, m_rtContent.top, m_rtContent.width - fBtn, |
+ m_rtContent.height); |
+ m_pEdit->SetWidgetRect(rtEdit); |
+ |
+ if (m_iCurSel >= 0) { |
+ CFX_WideString wsText; |
+ IFWL_ComboBoxDP* pData = |
+ static_cast<IFWL_ComboBoxDP*>(m_pProperties->m_pDataProvider); |
+ CFWL_ListItem* hItem = pData->GetItem(this, m_iCurSel); |
+ m_pListBox->GetItemText(hItem, wsText); |
+ m_pEdit->LockUpdate(); |
+ m_pEdit->SetText(wsText); |
+ m_pEdit->UnlockUpdate(); |
} |
+ m_pEdit->Update(); |
} |
void IFWL_ComboBox::OnProcessMessage(CFWL_Message* pMessage) { |
@@ -919,47 +879,46 @@ void IFWL_ComboBox::OnDrawWidget(CFX_Graphics* pGraphics, |
} |
void IFWL_ComboBox::OnFocusChanged(CFWL_Message* pMsg, bool bSet) { |
- IFWL_Widget* pDstTarget = pMsg->m_pDstTarget; |
- IFWL_Widget* pSrcTarget = pMsg->m_pSrcTarget; |
- bool bDropDown = IsDropDownStyle(); |
if (bSet) { |
m_pProperties->m_dwStates |= FWL_WGTSTATE_Focused; |
- if (bDropDown && pSrcTarget != m_pListBox.get()) { |
+ if (IsDropDownStyle() && pMsg->m_pSrcTarget != m_pListBox.get()) { |
if (!m_pEdit) |
return; |
m_pEdit->SetSelected(); |
- } else { |
- Repaint(&m_rtClient); |
- } |
- } else { |
- m_pProperties->m_dwStates &= ~FWL_WGTSTATE_Focused; |
- if (bDropDown && pDstTarget != m_pListBox.get()) { |
- if (!m_pEdit) |
- return; |
- m_pEdit->FlagFocus(false); |
- m_pEdit->ClearSelected(); |
- } else { |
- Repaint(&m_rtClient); |
+ return; |
} |
+ |
+ Repaint(&m_rtClient); |
+ return; |
} |
+ |
+ m_pProperties->m_dwStates &= ~FWL_WGTSTATE_Focused; |
+ if (!IsDropDownStyle() || pMsg->m_pDstTarget == m_pListBox.get()) { |
+ Repaint(&m_rtClient); |
+ return; |
+ } |
+ if (!m_pEdit) |
+ return; |
+ |
+ m_pEdit->FlagFocus(false); |
+ m_pEdit->ClearSelected(); |
} |
void IFWL_ComboBox::OnLButtonDown(CFWL_MsgMouse* pMsg) { |
if (m_pProperties->m_dwStates & FWL_WGTSTATE_Disabled) |
return; |
- bool bDropDown = IsDropDownStyle(); |
- CFX_RectF& rtBtn = bDropDown ? m_rtBtn : m_rtClient; |
- bool bClickBtn = rtBtn.Contains(pMsg->m_fx, pMsg->m_fy); |
- if (!bClickBtn) |
+ CFX_RectF& rtBtn = IsDropDownStyle() ? m_rtBtn : m_rtClient; |
+ if (!rtBtn.Contains(pMsg->m_fx, pMsg->m_fy)) |
return; |
- if (bDropDown && m_pEdit) |
+ if (IsDropDownStyle() && m_pEdit) |
MatchEditText(); |
m_bLButtonDown = true; |
m_iBtnState = CFWL_PartState_Pressed; |
Repaint(&m_rtClient); |
+ |
ShowDropList(true); |
m_iBtnState = CFWL_PartState_Normal; |
Repaint(&m_rtClient); |
@@ -1052,8 +1011,7 @@ void IFWL_ComboBox::DoSubCtrlKey(CFWL_MsgKey* pMsg) { |
return; |
} |
- bool bDropDown = IsDropDownStyle(); |
- if (bDropDown) |
+ if (IsDropDownStyle()) |
m_pEdit->GetDelegate()->OnProcessMessage(pMsg); |
} |