X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/a92b0cfd2bd0bef75b43c071df0b0e028f360d8e..d77836e48cf1a0f7575cd1ce66f59f5bc07e5b56:/samples/listctrl/listtest.h diff --git a/samples/listctrl/listtest.h b/samples/listctrl/listtest.h index a79ca7c580..90359d0030 100644 --- a/samples/listctrl/listtest.h +++ b/samples/listctrl/listtest.h @@ -5,7 +5,7 @@ // Modified by: // Created: 04/01/98 // RCS-ID: $Id$ -// Copyright: (c) Julian Smart and Markus Holzem +// Copyright: (c) Julian Smart // Licence: wxWindows license ///////////////////////////////////////////////////////////////////////////// @@ -13,7 +13,12 @@ class MyApp: public wxApp { public: + MyApp() { } + virtual bool OnInit(); + +private: + DECLARE_NO_COPY_CLASS(MyApp) }; class MyListCtrl: public wxListCtrl @@ -43,8 +48,10 @@ public: void OnEndLabelEdit(wxListEvent& event); void OnDeleteItem(wxListEvent& event); void OnDeleteAllItems(wxListEvent& event); +#if WXWIN_COMPATIBILITY_2_4 void OnGetInfo(wxListEvent& event); void OnSetInfo(wxListEvent& event); +#endif void OnSelected(wxListEvent& event); void OnDeselected(wxListEvent& event); void OnListKeyDown(wxListEvent& event); @@ -58,6 +65,7 @@ private: void SetColumnImage(int col, int image); void LogEvent(const wxListEvent& event, const wxChar *eventName); + void LogColEvent(const wxListEvent& event, const wxChar *eventName); virtual wxString OnGetItemText(long item, long column) const; virtual int OnGetItemImage(long item) const; @@ -65,6 +73,7 @@ private: wxListItemAttr m_attr; + DECLARE_NO_COPY_CLASS(MyListCtrl) DECLARE_EVENT_TABLE() }; @@ -72,13 +81,12 @@ private: class MyFrame: public wxFrame { public: - MyListCtrl *m_listCtrl; - wxTextCtrl *m_logWindow; - MyFrame(const wxChar *title, int x, int y, int w, int h); - ~MyFrame(); + virtual ~MyFrame(); -public: + void DoSize(); + +protected: void OnSize(wxSizeEvent& event); void OnQuit(wxCommandEvent& event); @@ -90,12 +98,14 @@ public: void OnSmallIconView(wxCommandEvent& event); void OnSmallIconTextView(wxCommandEvent& event); void OnVirtualView(wxCommandEvent& event); + void OnSmallVirtualView(wxCommandEvent& event); void OnFocusLast(wxCommandEvent& event); void OnToggleFirstSel(wxCommandEvent& event); void OnDeselectAll(wxCommandEvent& event); void OnSelectAll(wxCommandEvent& event); void OnAdd(wxCommandEvent& event); + void OnEdit(wxCommandEvent& event); void OnDelete(wxCommandEvent& event); void OnDeleteAll(wxCommandEvent& event); void OnSort(wxCommandEvent& event); @@ -106,24 +116,38 @@ public: void OnShowSelInfo(wxCommandEvent& event); void OnFreeze(wxCommandEvent& event); void OnThaw(wxCommandEvent& event); + void OnToggleLines(wxCommandEvent& event); void OnUpdateShowColInfo(wxUpdateUIEvent& event); + void OnUpdateToggleMultiSel(wxUpdateUIEvent& event); wxImageList *m_imageListNormal; wxImageList *m_imageListSmall; + wxPanel *m_panel; + MyListCtrl *m_listCtrl; + wxTextCtrl *m_logWindow; + private: // recreate the list control with the new flags - void RecreateList(long flags, bool withText = TRUE); + void RecreateList(long flags, bool withText = true); // fill the control with items depending on the view void InitWithListItems(); void InitWithReportItems(); - void InitWithIconItems(bool withText, bool sameIcon = FALSE); + void InitWithIconItems(bool withText, bool sameIcon = false); void InitWithVirtualItems(); + // return true if the control is not in virtual view, give an error message + // and return false if it is + bool CheckNonVirtual() const; + + wxLog *m_logOld; + bool m_smallVirtual; + + DECLARE_NO_COPY_CLASS(MyFrame) DECLARE_EVENT_TABLE() }; @@ -131,22 +155,24 @@ private: // IDs for the menu commands enum { - LIST_ABOUT, - LIST_QUIT, + LIST_ABOUT = wxID_ABOUT, + LIST_QUIT = wxID_EXIT, - LIST_LIST_VIEW, + LIST_LIST_VIEW = wxID_HIGHEST, LIST_ICON_VIEW, LIST_ICON_TEXT_VIEW, LIST_SMALL_ICON_VIEW, LIST_SMALL_ICON_TEXT_VIEW, LIST_REPORT_VIEW, LIST_VIRTUAL_VIEW, + LIST_SMALL_VIRTUAL_VIEW, LIST_DESELECT_ALL, LIST_SELECT_ALL, LIST_DELETE_ALL, LIST_DELETE, LIST_ADD, + LIST_EDIT, LIST_SORT, LIST_SET_FG_COL, LIST_SET_BG_COL, @@ -157,6 +183,7 @@ enum LIST_FOCUS_LAST, LIST_FREEZE, LIST_THAW, + LIST_TOGGLE_LINES, LIST_CTRL = 1000 };