X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/d9b72d25405c4229b6195b581e6723f95d77e31d..a87f2821adee59d00f99cad1f9bcf61b0accbcb6:/src/generic/odcombo.cpp diff --git a/src/generic/odcombo.cpp b/src/generic/odcombo.cpp index b6c8c7e843..c72efc280c 100644 --- a/src/generic/odcombo.cpp +++ b/src/generic/odcombo.cpp @@ -242,7 +242,7 @@ bool wxVListBoxComboPopup::HandleKey( int keycode, bool saturate, wxChar unicode } else if (unicode>0) { - keychar = unicode; + keychar = unicode; } if ( keycode == WXK_DOWN || keycode == WXK_RIGHT ) @@ -279,12 +279,12 @@ bool wxVListBoxComboPopup::HandleKey( int keycode, bool saturate, wxChar unicode // now search through the values to see if this is found int found = -1; - unsigned int length=m_partialCompletionString.Length(); + unsigned int length=m_partialCompletionString.length(); int i; for (i=0; i=length) && (! m_partialCompletionString.CmpNoCase(item.Left(length)))) + if (( item.length() >= length) && (! m_partialCompletionString.CmpNoCase(item.Left(length)))) { found=i; break; @@ -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(); @@ -1044,10 +1051,12 @@ void wxOwnerDrawnComboBox::OnDrawBackground(wxDC& dc, const wxRect& rect, int it if ( GetVListBoxComboPopup()->IsCurrent((size_t)item) || (flags & wxODCB_PAINTING_CONTROL) ) { - DrawFocusBackground(dc, - rect, - (flags&wxODCB_PAINTING_CONTROL?0:wxCONTROL_ISSUBMENU) | - wxCONTROL_SELECTED); + int focusFlag = wxCONTROL_SELECTED; + + if ( (flags & wxODCB_PAINTING_CONTROL) != wxODCB_PAINTING_CONTROL ) + focusFlag |= wxCONTROL_ISSUBMENU; + + DrawFocusBackground(dc, rect, focusFlag ); } //else: do nothing for the normal items }