X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/78b3b018ce9edca5742d8ab263d849f77f3d19bf..e894be201b9866e2f5dbf29050bd1aaa58d95cc4:/samples/widgets/combobox.cpp diff --git a/samples/widgets/combobox.cpp b/samples/widgets/combobox.cpp index 72c4b023f1..c14d2ff633 100644 --- a/samples/widgets/combobox.cpp +++ b/samples/widgets/combobox.cpp @@ -54,6 +54,7 @@ enum { ComboPage_Reset = 100, ComboPage_CurText, + ComboPage_InsertionPointText, ComboPage_Insert, ComboPage_InsertText, ComboPage_Add, @@ -84,7 +85,7 @@ enum class ComboboxWidgetsPage : public WidgetsPage { public: - ComboboxWidgetsPage(wxBookCtrl *book, wxImageList *imaglist); + ComboboxWidgetsPage(wxBookCtrlBase *book, wxImageList *imaglist); virtual wxControl *GetWidget() const { return m_combobox; } @@ -106,6 +107,7 @@ protected: void OnCheckOrRadioBox(wxCommandEvent& event); void OnUpdateUICurText(wxUpdateUIEvent& event); + void OnUpdateUIInsertionPointText(wxUpdateUIEvent& event); void OnUpdateUIInsert(wxUpdateUIEvent& event); void OnUpdateUIAddSeveral(wxUpdateUIEvent& event); @@ -165,6 +167,7 @@ BEGIN_EVENT_TABLE(ComboboxWidgetsPage, WidgetsPage) EVT_TEXT_ENTER(ComboPage_DeleteText, ComboboxWidgetsPage::OnButtonDelete) EVT_UPDATE_UI(ComboPage_CurText, ComboboxWidgetsPage::OnUpdateUICurText) + EVT_UPDATE_UI(ComboPage_InsertionPointText, ComboboxWidgetsPage::OnUpdateUIInsertionPointText) EVT_UPDATE_UI(ComboPage_Reset, ComboboxWidgetsPage::OnUpdateUIResetButton) EVT_UPDATE_UI(ComboPage_Insert, ComboboxWidgetsPage::OnUpdateUIInsert) @@ -190,7 +193,7 @@ END_EVENT_TABLE() IMPLEMENT_WIDGETS_PAGE(ComboboxWidgetsPage, _T("Combobox")); -ComboboxWidgetsPage::ComboboxWidgetsPage(wxBookCtrl *book, +ComboboxWidgetsPage::ComboboxWidgetsPage(wxBookCtrlBase *book, wxImageList *imaglist) : WidgetsPage(book) { @@ -253,6 +256,13 @@ ComboboxWidgetsPage::ComboboxWidgetsPage(wxBookCtrl *book, sizerMiddle->Add(sizerRow, 0, wxALL | wxGROW, 5); + sizerRow = CreateSizerWithTextAndLabel(_T("Insertion Point"), + ComboPage_InsertionPointText, + &text); + text->SetEditable(false); + + sizerMiddle->Add(sizerRow, 0, wxALL | wxGROW, 5); + sizerRow = CreateSizerWithTextAndButton(ComboPage_Insert, _T("&Insert this string"), ComboPage_InsertText, @@ -478,6 +488,12 @@ void ComboboxWidgetsPage::OnUpdateUICurText(wxUpdateUIEvent& event) event.SetText( wxString::Format(_T("%d"), m_combobox->GetSelection()) ); } +void ComboboxWidgetsPage::OnUpdateUIInsertionPointText(wxUpdateUIEvent& event) +{ + if (m_combobox) + event.SetText( wxString::Format(_T("%d"), m_combobox->GetInsertionPoint()) ); +} + void ComboboxWidgetsPage::OnUpdateUIResetButton(wxUpdateUIEvent& event) { if (m_combobox) @@ -536,7 +552,7 @@ void ComboboxWidgetsPage::OnComboText(wxCommandEvent& event) if (event.GetEventType() == wxEVT_COMMAND_TEXT_ENTER) wxLogMessage(_T("Combobox enter pressed (now '%s')"), s.c_str()); else - wxLogMessage(_T("Combobox text changed (now '%s')"), s.c_str()); + wxLogMessage(_T("Combobox text changed (now '%s')"), s.c_str()); } void ComboboxWidgetsPage::OnComboBox(wxCommandEvent& event) @@ -545,7 +561,7 @@ void ComboboxWidgetsPage::OnComboBox(wxCommandEvent& event) m_textDelete->SetValue(wxString::Format(_T("%ld"), sel)); wxLogMessage(_T("Combobox item %ld selected"), sel); - + wxLogMessage(_T("Combobox GetValue(): %s"), m_combobox->GetValue().c_str() ); }