X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/80fdcdb90ef779185492dab676d461fc34933312..07aaf32633ecf18ec3edfbb41793a112914792d0:/src/msw/bmpcbox.cpp?ds=sidebyside diff --git a/src/msw/bmpcbox.cpp b/src/msw/bmpcbox.cpp index c2928c9657..ea7c925762 100644 --- a/src/msw/bmpcbox.cpp +++ b/src/msw/bmpcbox.cpp @@ -31,6 +31,7 @@ #endif #include "wx/settings.h" +#include "wx/vector.h" #include "wx/msw/dcclient.h" #include "wx/msw/private.h" @@ -134,6 +135,12 @@ void wxBitmapComboBox::RecreateControl() size.y = GetBestSize().y; wxArrayString strings = GetStrings(); + // Save the client data pointers before clearing the control. + wxVector clientData; + clientData.reserve(strings.size()); + for ( size_t n = 0; n < strings.size(); ++n ) + clientData.push_back(GetClientObject(n)); + wxComboBox::DoClear(); HWND hwnd = GetHwnd(); @@ -146,7 +153,7 @@ void wxBitmapComboBox::RecreateControl() // initialize the controls contents for ( unsigned int i = 0; i < strings.size(); i++ ) { - wxComboBox::Append(strings[i]); + wxComboBox::Append(strings[i], clientData[i]); } // and make sure it has the same attributes as before @@ -257,6 +264,16 @@ int wxBitmapComboBox::Insert(const wxString& item, return n; } +int wxBitmapComboBox::Insert(const wxString& item, const wxBitmap& bitmap, + unsigned int pos, void *clientData) +{ + OnAddBitmap(bitmap); + const int n = wxComboBox::Insert(item, pos, clientData); + if ( n != wxNOT_FOUND ) + DoSetItemBitmap(n, bitmap); + return n; +} + int wxBitmapComboBox::Insert(const wxString& item, const wxBitmap& bitmap, unsigned int pos, wxClientData *clientData) {