X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/f135ff73b4b0b7c76a1fa3396f768c44f8dc204f..717b9bf234a20c491e0c9ee8f2c1bffad56a59c5:/samples/treectrl/treetest.h diff --git a/samples/treectrl/treetest.h b/samples/treectrl/treetest.h index a72ee5fa51..12c6b2245b 100644 --- a/samples/treectrl/treetest.h +++ b/samples/treectrl/treetest.h @@ -6,85 +6,165 @@ // Created: 04/01/98 // RCS-ID: $Id$ // Copyright: (c) Julian Smart and Markus Holzem -// Licence: wxWindows license +// Licence: wxWindows license ///////////////////////////////////////////////////////////////////////////// // Define a new application type -class MyApp: public wxApp -{ public: - bool OnInit(void); +class MyApp : public wxApp +{ +public: + bool OnInit(); +}; - wxImageList *m_imageListNormal; +class MyTreeItemData : public wxTreeItemData +{ +public: + MyTreeItemData(const wxString& desc) : m_desc(desc) { } + + void ShowInfo(wxTreeCtrl *tree); + const char *GetDesc() const { return m_desc.c_str(); } + +private: + wxString m_desc; }; -class MyTreeCtrl: public wxTreeCtrl +class MyTreeCtrl : public wxTreeCtrl { public: - MyTreeCtrl(wxWindow *parent, const wxWindowID id, const wxPoint& pos, - const wxSize& size, long style); - ~MyTreeCtrl(); - - void AddItemsRecursively(const wxTreeItemId& idParent, - size_t numChildren, - size_t depth); - void AddTestItemsToTree(size_t numChildren, - size_t depth); - - - void OnBeginDrag(wxTreeEvent& event); - void OnBeginRDrag(wxTreeEvent& event); - void OnBeginLabelEdit(wxTreeEvent& event); - void OnEndLabelEdit(wxTreeEvent& event); - void OnDeleteItem(wxTreeEvent& event); - void OnGetInfo(wxTreeEvent& event); - void OnSetInfo(wxTreeEvent& event); - void OnItemExpanded(wxTreeEvent& event); - void OnItemExpanding(wxTreeEvent& event); - void OnItemCollapsed(wxTreeEvent& event); - void OnItemCollapsing(wxTreeEvent& event); - void OnSelChanged(wxTreeEvent& event); - void OnSelChanging(wxTreeEvent& event); - void OnKeyDown(wxTreeEvent& event); - - DECLARE_EVENT_TABLE() + enum + { + TreeCtrlIcon_File, + TreeCtrlIcon_Folder + }; + + MyTreeCtrl() { } + MyTreeCtrl(wxWindow *parent, const wxWindowID id, + const wxPoint& pos, const wxSize& size, + long style); + virtual ~MyTreeCtrl(); + + void OnBeginDrag(wxTreeEvent& event); + void OnBeginRDrag(wxTreeEvent& event); + void OnBeginLabelEdit(wxTreeEvent& event); + void OnEndLabelEdit(wxTreeEvent& event); + void OnDeleteItem(wxTreeEvent& event); + void OnGetInfo(wxTreeEvent& event); + void OnSetInfo(wxTreeEvent& event); + void OnItemExpanded(wxTreeEvent& event); + void OnItemExpanding(wxTreeEvent& event); + void OnItemCollapsed(wxTreeEvent& event); + void OnItemCollapsing(wxTreeEvent& event); + void OnSelChanged(wxTreeEvent& event); + void OnSelChanging(wxTreeEvent& event); + void OnTreeKeyDown(wxTreeEvent& event); + void OnItemActivated(wxTreeEvent& event); + void OnRMouseDClick(wxMouseEvent& event); + + void GetItemsRecursively(const wxTreeItemId& idParent, long cookie); + + void AddTestItemsToTree(size_t numChildren, size_t depth); + + void DoSortChildren(const wxTreeItemId& item, bool reverse = FALSE) + { m_reverseSort = reverse; wxTreeCtrl::SortChildren(item); } + void DoEnsureVisible() { EnsureVisible(m_lastItem); } + +protected: + virtual int OnCompareItems(const wxTreeItemId& i1, const wxTreeItemId& i2); + + // is this the test item which we use in several event handlers? + bool IsTestItem(const wxTreeItemId& item) + { + // the test item is the first child folder + return GetParent(item) == GetRootItem() && !GetPrevSibling(item); + } + +private: + void AddItemsRecursively(const wxTreeItemId& idParent, + size_t nChildren, + size_t depth, + size_t folder); + + wxImageList *m_imageListNormal; + bool m_reverseSort; // flag for OnCompareItems + wxTreeItemId m_lastItem; // for OnEnsureVisible() + + // NB: due to an ugly wxMSW hack you _must_ use DECLARE_DYNAMIC_CLASS() + // if you want your overloaded OnCompareItems() to be called. + // OTOH, if you don't want it you may omit the next line - this will + // make default (alphabetical) sorting much faster under wxMSW. + DECLARE_DYNAMIC_CLASS(MyTreeCtrl) + DECLARE_EVENT_TABLE() }; // Define a new frame type class MyFrame: public wxFrame -{ public: - MyTreeCtrl *m_treeCtrl; - wxTextCtrl *m_logWindow; - +{ +public: + // ctor and dtor MyFrame(const wxString& title, int x, int y, int w, int h); - ~MyFrame(void); - - public: + virtual ~MyFrame(); + + // menu callbacks void OnQuit(wxCommandEvent& event); void OnAbout(wxCommandEvent& event); - bool OnClose(void) { return TRUE; } - DECLARE_EVENT_TABLE() -}; + void OnDump(wxCommandEvent& event); + void OnDumpSelected(wxCommandEvent& event); + void OnDelete(wxCommandEvent& event); + void OnDeleteChildren(wxCommandEvent& event); + void OnDeleteAll(wxCommandEvent& event); + void OnRecreate(wxCommandEvent& event); + void OnCollapseAndReset(wxCommandEvent& event); -class MyTreeItemData : public wxTreeItemData -{ -public: - MyTreeItemData(const wxString& desc) : m_desc(desc) { } + void OnSetBold(wxCommandEvent& WXUNUSED(event)) { DoSetBold(TRUE); } + void OnClearBold(wxCommandEvent& WXUNUSED(event)) { DoSetBold(FALSE); } - void ShowInfo(wxTreeCtrl *tree); + void OnEnsureVisible(wxCommandEvent& event); + + void OnRename(wxCommandEvent& event); + void OnSort(wxCommandEvent& event) { DoSort(); } + void OnSortRev(wxCommandEvent& event) { DoSort(TRUE); } + + void OnAddItem(wxCommandEvent& event); + + void OnIncIndent(wxCommandEvent& event); + void OnDecIndent(wxCommandEvent& event); + + void OnIncSpacing(wxCommandEvent& event); + void OnDecSpacing(wxCommandEvent& event); private: - wxString m_desc; -}; + void DoSort(bool reverse = FALSE); + + MyTreeCtrl *m_treeCtrl; -// ID for the menu quit command -#define TREE_QUIT 1 -#define TREE_ABOUT 102 + void DoSetBold(bool bold = TRUE); -#define TREE_CTRL 1000 + DECLARE_EVENT_TABLE() +}; +// menu and control ids enum { - TreeCtrlIcon_File, - TreeCtrlIcon_Folder + TreeTest_Quit, + TreeTest_About, + TreeTest_Dump, + TreeTest_Dump_Selected, + TreeTest_Sort, + TreeTest_SortRev, + TreeTest_Bold, + TreeTest_UnBold, + TreeTest_Rename, + TreeTest_Delete, + TreeTest_DeleteChildren, + TreeTest_DeleteAll, + TreeTest_Recreate, + TreeTest_CollapseAndReset, + TreeTest_EnsureVisible, + TreeTest_AddItem, + TreeTest_IncIndent, + TreeTest_DecIndent, + TreeTest_IncSpacing, + TreeTest_DecSpacing, + TreeTest_Ctrl = 100 };