X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/32b8ec418aee4e38877d4cb79e2984c766dcc358..a81c3c2383f9096ef5e96b708a0f1c1ffe7cc6a8:/samples/widgets/combobox.cpp?ds=sidebyside diff --git a/samples/widgets/combobox.cpp b/samples/widgets/combobox.cpp index 0abec90734..5570f43f1f 100644 --- a/samples/widgets/combobox.cpp +++ b/samples/widgets/combobox.cpp @@ -24,6 +24,8 @@ #pragma hdrstop #endif +#if wxUSE_COMBOBOX + // for all others, include the necessary headers #ifndef WX_PRECOMP #include "wx/log.h" @@ -39,7 +41,7 @@ #include "wx/sizer.h" #include "widgets.h" - +#if 1 #include "icons/combobox.xpm" // ---------------------------------------------------------------------------- @@ -131,8 +133,8 @@ protected: *m_textDelete; private: - DECLARE_EVENT_TABLE(); - DECLARE_WIDGETS_PAGE(ComboboxWidgetsPage); + DECLARE_EVENT_TABLE() + DECLARE_WIDGETS_PAGE(ComboboxWidgetsPage) }; // ---------------------------------------------------------------------------- @@ -180,8 +182,6 @@ ComboboxWidgetsPage::ComboboxWidgetsPage(wxNotebook *notebook, wxImageList *imaglist) : WidgetsPage(notebook) { - imaglist->Add(wxBitmap(combobox_xpm)); - // init everything m_chkSort = m_chkReadonly = (wxCheckBox *)NULL; @@ -189,6 +189,8 @@ ComboboxWidgetsPage::ComboboxWidgetsPage(wxNotebook *notebook, m_combobox = (wxComboBox *)NULL; m_sizerCombo = (wxSizer *)NULL; + imaglist->Add(wxBitmap(combobox_xpm)); + /* What we create here is a frame having 3 panes: style pane is the leftmost one, in the middle the pane with buttons allowing to perform @@ -275,7 +277,7 @@ ComboboxWidgetsPage::ComboboxWidgetsPage(wxNotebook *notebook, 0, NULL, 0); sizerRight->Add(m_combobox, 1, wxGROW | wxALL, 5); - sizerRight->SetMinSize(250, 0); + sizerRight->SetMinSize(150, 0); m_sizerCombo = sizerRight; // save it to modify it later // the 3 panes panes compose the window @@ -439,38 +441,49 @@ void ComboboxWidgetsPage::OnButtonAddSeveral(wxCommandEvent& event) void ComboboxWidgetsPage::OnUpdateUICurText(wxUpdateUIEvent& event) { - event.SetText( wxString::Format(_T("%d"), m_combobox->GetSelection()) ); + if (m_combobox) + event.SetText( wxString::Format(_T("%d"), m_combobox->GetSelection()) ); } void ComboboxWidgetsPage::OnUpdateUIResetButton(wxUpdateUIEvent& event) { - event.Enable( m_chkSort->GetValue() || m_chkReadonly->GetValue() ); + if (m_combobox) + event.Enable( m_chkSort->GetValue() || m_chkReadonly->GetValue() ); } void ComboboxWidgetsPage::OnUpdateUIDeleteButton(wxUpdateUIEvent& event) { - unsigned long n; - event.Enable(m_textDelete->GetValue().ToULong(&n) && - (n < (unsigned)m_combobox->GetCount())); + if (m_combobox) + { + unsigned long n; + event.Enable(m_textDelete->GetValue().ToULong(&n) && + (n < (unsigned)m_combobox->GetCount())); + } } void ComboboxWidgetsPage::OnUpdateUIDeleteSelButton(wxUpdateUIEvent& event) { - event.Enable(m_combobox->GetSelection() != -1); + if (m_combobox) + event.Enable(m_combobox->GetSelection() != -1); } void ComboboxWidgetsPage::OnUpdateUIClearButton(wxUpdateUIEvent& event) { - event.Enable(m_combobox->GetCount() != 0); + if (m_combobox) + event.Enable(m_combobox->GetCount() != 0); } void ComboboxWidgetsPage::OnUpdateUIAddSeveral(wxUpdateUIEvent& event) { - event.Enable(!(m_combobox->GetWindowStyle() & wxCB_SORT)); + if (m_combobox) + event.Enable(!(m_combobox->GetWindowStyle() & wxCB_SORT)); } void ComboboxWidgetsPage::OnComboText(wxCommandEvent& event) { + if (!m_combobox) + return; + wxString s = event.GetString(); wxASSERT_MSG( s == m_combobox->GetValue(), @@ -492,3 +505,6 @@ void ComboboxWidgetsPage::OnCheckOrRadioBox(wxCommandEvent& event) CreateCombo(); } +#endif //wxUSE_COMBOBOX + +#endif