X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/4dd31ff527b70ef0228f773475a0a58b6072456a..923608c3ac95e2c705fb0f49ab48fbe62fc871bd:/src/generic/odcombo.cpp diff --git a/src/generic/odcombo.cpp b/src/generic/odcombo.cpp index 4d39e83afa..cccd7660f1 100644 --- a/src/generic/odcombo.cpp +++ b/src/generic/odcombo.cpp @@ -410,17 +410,24 @@ void wxVListBoxComboPopup::OnLeftClick(wxMouseEvent& WXUNUSED(event)) void wxVListBoxComboPopup::OnKey(wxKeyEvent& event) { - // Select item if ENTER is pressed - if ( event.GetKeyCode() == WXK_RETURN || event.GetKeyCode() == WXK_NUMPAD_ENTER ) - { - DismissWithEvent(); - } - // Hide popup if ESC is pressed - else if ( event.GetKeyCode() == WXK_ESCAPE ) + // Hide popup if certain key or key combination was pressed + if ( m_combo->IsKeyPopupToggle(event) ) { StopPartialCompletion(); Dismiss(); } + else if ( event.AltDown() ) + { + // On both wxGTK and wxMSW, pressing Alt down seems to + // completely freeze things in popup (ie. arrow keys and + // enter won't work). + return; + } + // Select item if ENTER is pressed + else if ( event.GetKeyCode() == WXK_RETURN || event.GetKeyCode() == WXK_NUMPAD_ENTER ) + { + DismissWithEvent(); + } else { int comboStyle = m_combo->GetWindowStyle(); @@ -549,8 +556,16 @@ void wxVListBoxComboPopup::Delete( unsigned int item ) if ( (int)item == m_widestItem ) m_findWidest = true; + int sel = GetSelection(); + if ( IsCreated() ) wxVListBox::SetItemCount( wxVListBox::GetItemCount()-1 ); + + // Fix selection + if ( (int)item < sel ) + SetSelection(sel-1); + else if ( (int)item == sel ) + SetSelection(wxNOT_FOUND); } int wxVListBoxComboPopup::FindString(const wxString& s, bool bCase) const @@ -1044,12 +1059,15 @@ void wxOwnerDrawnComboBox::OnDrawBackground(wxDC& dc, const wxRect& rect, int it if ( GetVListBoxComboPopup()->IsCurrent((size_t)item) || (flags & wxODCB_PAINTING_CONTROL) ) { - int focusFlag = wxCONTROL_SELECTED; + int bgFlags = wxCONTROL_SELECTED; - if ( flags & wxODCB_PAINTING_CONTROL != wxODCB_PAINTING_CONTROL ) - focusFlag |= wxCONTROL_ISSUBMENU; - - DrawFocusBackground(dc, rect, focusFlag ); + if ( (flags & wxODCB_PAINTING_CONTROL) != wxODCB_PAINTING_CONTROL ) + { + bgFlags |= wxCONTROL_ISSUBMENU; + PrepareBackground(dc, rect, bgFlags); + } + else if ( HasFlag(wxCB_READONLY) ) + PrepareBackground(dc, rect, bgFlags); } //else: do nothing for the normal items }