X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/c386222cd305fb273a7ee735a326a81f0a45b8d6..52ca3f113ee669e6e46f358a7999f6a0fe9af48b:/samples/checklst/checklst.cpp diff --git a/samples/checklst/checklst.cpp b/samples/checklst/checklst.cpp index dfc27c262a..039e140226 100644 --- a/samples/checklst/checklst.cpp +++ b/samples/checklst/checklst.cpp @@ -30,6 +30,7 @@ #include "wx/log.h" +#include "wx/sizer.h" #include "wx/menuitem.h" #include "wx/checklst.h" @@ -61,6 +62,8 @@ public: private: void OnButtonMove(bool up); + void AdjustColour(size_t index); + wxCheckListBox *m_pListBox; DECLARE_EVENT_TABLE() @@ -112,7 +115,7 @@ CheckListBoxFrame::CheckListBoxFrame(wxFrame *frame, const int widths[] = { -1, 60 }; CreateStatusBar(2); SetStatusWidths(2, widths); - wxLogStatus(this, "no selection"); + wxLogStatus(this, _T("no selection")); // Make a menubar wxMenu *file_menu = new wxMenu; @@ -147,7 +150,7 @@ CheckListBoxFrame::CheckListBoxFrame(wxFrame *frame, panel, // parent Control_Listbox, // control id wxPoint(10, 10), // listbox poistion - wxSize(400, 200), // listbox size + wxSize(400, 100), // listbox size WXSIZEOF(aszChoices), // number of strings astrChoices // array of strings ); @@ -156,20 +159,37 @@ CheckListBoxFrame::CheckListBoxFrame(wxFrame *frame, delete [] astrChoices; - // not implemented in other ports yet -#ifdef __WXMSW__ // set grey background for every second entry for ( ui = 0; ui < WXSIZEOF(aszChoices); ui += 2 ) { - m_pListBox->GetItem(ui)->SetBackgroundColour(wxColor(200, 200, 200)); + AdjustColour(ui); } -#endif // wxGTK m_pListBox->Check(2); // create buttons for moving the items around - (void)new wxButton(panel, Btn_Up, " &Up ", wxPoint(420, 90)); - (void)new wxButton(panel, Btn_Down, "&Down", wxPoint(420, 120)); + wxButton *button1 = new wxButton(panel, Btn_Up, " &Up ", wxPoint(420, 90)); + wxButton *button2 = new wxButton(panel, Btn_Down, "&Down", wxPoint(420, 120)); + + + wxBoxSizer *mainsizer = new wxBoxSizer( wxVERTICAL ); + + mainsizer->Add( m_pListBox, 1, wxGROW|wxALL, 10 ); + + wxBoxSizer *bottomsizer = new wxBoxSizer( wxHORIZONTAL ); + + bottomsizer->Add( button1, 0, wxALL, 10 ); + bottomsizer->Add( button2, 0, wxALL, 10 ); + + mainsizer->Add( bottomsizer, 0, wxCENTER ); + + // tell frame to make use of sizer (or constraints, if any) + panel->SetAutoLayout( TRUE ); + panel->SetSizer( mainsizer ); + + // don't allow frame to get smaller than what the sizers tell ye + mainsizer->SetSizeHints( this ); + Show(TRUE); } @@ -184,23 +204,23 @@ void CheckListBoxFrame::OnQuit(wxCommandEvent& WXUNUSED(event)) void CheckListBoxFrame::OnAbout(wxCommandEvent& WXUNUSED(event)) { - wxMessageBox("Demo of wxCheckListBox control\n" - "© Vadim Zeitlin 1998-1999", - "About wxCheckListBox", + wxMessageBox(_T("Demo of wxCheckListBox control\n" + "© Vadim Zeitlin 1998-1999"), + _T("About wxCheckListBox"), wxICON_INFORMATION, this); } void CheckListBoxFrame::OnListboxSelect(wxCommandEvent& event) { int nSel = event.GetSelection(); - wxLogStatus(this, "item %d selected (%schecked)", nSel, - m_pListBox->IsChecked(nSel) ? "" : "not "); + wxLogStatus(this, _T("item %d selected (%schecked)"), nSel, + m_pListBox->IsChecked(nSel) ? _T("") : _T("not ")); } void CheckListBoxFrame::OnListboxDblClick(wxCommandEvent& WXUNUSED(event)) { wxString strSelection; - strSelection.sprintf("item %d double clicked", m_pListBox->GetSelection()); + strSelection.sprintf(_T("item %d double clicked"), m_pListBox->GetSelection()); wxMessageDialog dialog(this, strSelection); dialog.ShowModal(); } @@ -209,8 +229,8 @@ void CheckListBoxFrame::OnCheckboxToggle(wxCommandEvent& event) { unsigned int nItem = event.GetInt(); - wxLogStatus(this, "item %d was %schecked", nItem, - m_pListBox->IsChecked(nItem) ? "" : "un"); + wxLogStatus(this, _T("item %d was %schecked"), nItem, + m_pListBox->IsChecked(nItem) ? _T("") : _T("un")); } void CheckListBoxFrame::OnButtonUp(wxCommandEvent& WXUNUSED(event)) @@ -231,9 +251,9 @@ void CheckListBoxFrame::OnButtonMove(bool up) wxString label = m_pListBox->GetString(selection); int positionNew = up ? selection - 1 : selection + 2; - if ( positionNew < 0 || positionNew > m_pListBox->Number() ) + if ( positionNew < 0 || positionNew > m_pListBox->GetCount() ) { - wxLogStatus(this, "Can't move this item %s", up ? "up" : "down"); + wxLogStatus(this, _T("Can't move this item %s"), up ? _T("up") : _T("down")); } else { @@ -251,11 +271,24 @@ void CheckListBoxFrame::OnButtonMove(bool up) m_pListBox->Check(selectionNew, wasChecked); m_pListBox->SetSelection(selectionNew); - wxLogStatus(this, "Item moved %s", up ? "up" : "down"); + AdjustColour(selection); + AdjustColour(selectionNew); + + wxLogStatus(this, _T("Item moved %s"), up ? _T("up") : _T("down")); } } else { - wxLogStatus(this, "Please select an item"); + wxLogStatus(this, _T("Please select an item")); } } + +void CheckListBoxFrame::AdjustColour(size_t index) +{ + // not implemented in other ports yet +#ifdef __WXMSW__ + // even items have grey backround, odd ones - white + unsigned char c = index % 2 ? 255 : 200; + m_pListBox->GetItem(index)->SetBackgroundColour(wxColor(c, c, c)); +#endif // wxMSW +}