X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/0544bc0aab888b4e064de10e451a4fa94ba0f33a..c3d434725bd76bc0306b9751e722ed70bd776876:/samples/controls/controls.cpp diff --git a/samples/controls/controls.cpp b/samples/controls/controls.cpp index 39651183ae..ed3755f463 100644 --- a/samples/controls/controls.cpp +++ b/samples/controls/controls.cpp @@ -84,6 +84,8 @@ public: void OnPageChanging( wxNotebookEvent &event ); void OnSliderUpdate( wxCommandEvent &event ); #ifndef wxUSE_SPINBUTTON + void OnSpinUp( wxSpinEvent &event ); + void OnSpinDown( wxSpinEvent &event ); void OnSpinUpdate( wxSpinEvent &event ); void OnUpdateShowProgress( wxUpdateUIEvent& event ); void OnShowProgress( wxCommandEvent &event ); @@ -279,6 +281,8 @@ EVT_BUTTON (ID_SET_FONT, MyPanel::OnSetFont) EVT_SLIDER (ID_SLIDER, MyPanel::OnSliderUpdate) #ifndef wxUSE_SPINBUTTON EVT_SPIN (ID_SPIN, MyPanel::OnSpinUpdate) +EVT_SPIN_UP (ID_SPIN, MyPanel::OnSpinUp) +EVT_SPIN_DOWN (ID_SPIN, MyPanel::OnSpinDown) EVT_UPDATE_UI (ID_BTNPROGRESS, MyPanel::OnUpdateShowProgress) EVT_BUTTON (ID_BTNPROGRESS, MyPanel::OnShowProgress) #endif @@ -433,16 +437,16 @@ MyPanel::MyPanel( wxFrame *frame, int x, int y, int w, int h ) m_notebook->AddPage(panel, "wxRadioBox", FALSE, Image_Radio); panel = new wxPanel(m_notebook); - (void)new wxStaticBox( panel, -1, "wxGauge and wxSlider", wxPoint(10,10), wxSize(180,130) ); + (void)new wxStaticBox( panel, -1, "wxGauge and wxSlider", wxPoint(10,10), wxSize(200,130) ); m_gauge = new wxGauge( panel, -1, 200, wxPoint(18,50), wxSize(155, 30) ); m_slider = new wxSlider( panel, ID_SLIDER, 0, 0, 200, wxPoint(18,90), wxSize(155,-1), wxSL_LABELS ); - (void)new wxStaticBox( panel, -1, "Explanation", wxPoint(200,10), wxSize(290,130) ); + (void)new wxStaticBox( panel, -1, "Explanation", wxPoint(220,10), wxSize(270,130) ); #ifdef __WXMOTIF__ // No wrapping text in wxStaticText yet :-( (void)new wxStaticText( panel, -1, "Drag the slider!", - wxPoint(208,30), - wxSize(210, -1) + wxPoint(228,30), + wxSize(240, -1) ); #else (void)new wxStaticText( panel, -1, @@ -452,15 +456,18 @@ MyPanel::MyPanel( wxFrame *frame, int x, int y, int w, int h ) "\n" "This is also supposed to demonstrate how\n" "to use static controls.\n", - wxPoint(208,25), - wxSize(250, 110) + wxPoint(228,25), + wxSize(240, 110) ); #endif - m_spintext = new wxTextCtrl( panel, -1, "0", wxPoint(20,160), wxSize(80,-1) ); + int initialSpinValue = -5; + wxString s; + s << initialSpinValue; + m_spintext = new wxTextCtrl( panel, -1, s, wxPoint(20,160), wxSize(80,-1) ); #ifndef wxUSE_SPINBUTTON m_spinbutton = new wxSpinButton( panel, ID_SPIN, wxPoint(103,159), wxSize(-1,-1) ); m_spinbutton->SetRange(-10,30); - m_spinbutton->SetValue(-5); + m_spinbutton->SetValue(initialSpinValue); m_btnProgress = new wxButton( panel, ID_BTNPROGRESS, "Show progress dialog", wxPoint(208, 159) ); @@ -491,6 +498,8 @@ MyPanel::MyPanel( wxFrame *frame, int x, int y, int w, int h ) ); bmpBtn = NULL; // suppress warning + new wxButton(panel, -1, "Another button", wxPoint(250, 20)); + m_notebook->AddPage(panel, "wxBitmapXXX"); } @@ -509,14 +518,16 @@ void MyPanel::OnPageChanging( wxNotebookEvent &event ) int selOld = event.GetOldSelection(); if ( selOld == 2 ) { - wxMessageBox("This demonstrates how a program may prevent the " - "page change from taking place - \n the current page will " - "stay the third one", "Control sample", - wxICON_INFORMATION | wxOK); - - event.Veto(); + if ( wxMessageBox("This demonstrates how a program may prevent the " + "page change from taking place - if you select " + "[No] the current page will stay the third one", + "Control sample", + wxICON_QUESTION | wxYES_NO) != wxYES ) + { + event.Veto(); - return; + return; + } } *m_text << "Notebook selection is being changed from " << selOld << "\n"; @@ -564,13 +575,13 @@ void MyPanel::OnListBoxButtons( wxCommandEvent &event ) case ID_LISTBOX_SEL_NUM: { m_listbox->SetSelection( 2 ); - m_lbSelectThis->WarpPointer( 40, 14 ); + m_lbSelectThis->WarpPointer( 40, 14 ); break; } case ID_LISTBOX_SEL_STR: { m_listbox->SetStringSelection( "This" ); - m_lbSelectNum->WarpPointer( 40, 14 ); + m_lbSelectNum->WarpPointer( 40, 14 ); break; } case ID_LISTBOX_CLEAR: @@ -750,6 +761,38 @@ void MyPanel::OnSliderUpdate( wxCommandEvent &WXUNUSED(event) ) } #ifndef wxUSE_SPINBUTTON +void MyPanel::OnSpinUp( wxSpinEvent &event ) +{ + wxString value; + value.Printf( _T("Spin control up: current = %d\n"), + m_spinbutton->GetValue()); + + if ( m_spinbutton->GetValue() > 17 ) + { + value += _T("Preventing the spin button from going above 17.\n"); + + event.Veto(); + } + + m_text->AppendText(value); +} + +void MyPanel::OnSpinDown( wxSpinEvent &event ) +{ + wxString value; + value.Printf( _T("Spin control down: current = %d\n"), + m_spinbutton->GetValue()); + + if ( m_spinbutton->GetValue() < -17 ) + { + value += _T("Preventing the spin button from going below -17.\n"); + + event.Veto(); + } + + m_text->AppendText(value); +} + void MyPanel::OnSpinUpdate( wxSpinEvent &event ) { wxString value; @@ -775,8 +818,12 @@ void MyPanel::OnShowProgress( wxCommandEvent& WXUNUSED(event) ) "An informative message", max, // range this, // parent - wxPD_CAN_ABORT | wxPD_APP_MODAL | wxPD_ELAPSED_TIME | wxPD_ESTIMATED_TIME | wxPD_REMAINING_TIME); - + wxPD_CAN_ABORT | + wxPD_APP_MODAL | + wxPD_ELAPSED_TIME | + wxPD_ESTIMATED_TIME | + wxPD_REMAINING_TIME); + bool cont = TRUE; for ( int i = 0; i < max && cont; i++ )