- 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()
+ MyTreeItemData(const wxString& desc) : m_desc(desc) { }
+
+ void ShowInfo(wxTreeCtrl *tree);
+ const wxChar *GetDesc() const { return m_desc.c_str(); }
+
+private:
+ wxString m_desc;
+};
+
+class MyTreeCtrl : public wxTreeCtrl
+{
+public:
+ enum
+ {
+ TreeCtrlIcon_File,
+ TreeCtrlIcon_FileSelected,
+ TreeCtrlIcon_Folder,
+ TreeCtrlIcon_FolderSelected,
+ TreeCtrlIcon_FolderOpened
+ };
+
+ MyTreeCtrl() { m_alternateImages = false; m_alternateStates = false; }
+ 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 OnEndDrag(wxTreeEvent& event);
+ void OnBeginLabelEdit(wxTreeEvent& event);
+ void OnEndLabelEdit(wxTreeEvent& event);
+ void OnDeleteItem(wxTreeEvent& event);
+ void OnContextMenu(wxContextMenuEvent& event);
+ void OnItemMenu(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 OnItemStateClick(wxTreeEvent& event);
+ void OnItemRClick(wxTreeEvent& event);
+
+ void OnRMouseDown(wxMouseEvent& event);
+ void OnRMouseUp(wxMouseEvent& event);
+ void OnRMouseDClick(wxMouseEvent& event);
+
+ void GetItemsRecursively(const wxTreeItemId& idParent,
+ wxTreeItemIdValue cookie = 0);
+
+ void CreateImageList(int size = 16);
+ void CreateButtonsImageList(int size = 11);
+ void CreateStateImageList(bool del = false);
+
+ void AddTestItemsToTree(size_t numChildren, size_t depth);
+
+ void DoSortChildren(const wxTreeItemId& item, bool reverse = false)
+ { m_reverseSort = reverse; wxTreeCtrl::SortChildren(item); }
+ void DoEnsureVisible() { if (m_lastItem.IsOk()) EnsureVisible(m_lastItem); }
+
+ void DoToggleIcon(const wxTreeItemId& item);
+ void DoToggleState(const wxTreeItemId& item);
+
+ void ShowMenu(wxTreeItemId id, const wxPoint& pt);
+
+ int ImageSize(void) const { return m_imageSize; }
+
+ void SetLastItem(wxTreeItemId id) { m_lastItem = id; }
+
+ void SetAlternateImages(bool show) { m_alternateImages = show; }
+ bool AlternateImages() const { return m_alternateImages; }
+
+ void SetAlternateStates(bool show) { m_alternateStates = show; }
+ bool AlternateStates() const { return m_alternateStates; }
+
+ void ResetBrokenStateImages()
+ {
+ const size_t count = GetStateImageList()->GetImageCount();
+ int state = count > 0 ? count - 1 : wxTREE_ITEMSTATE_NONE;
+ DoResetBrokenStateImages(GetRootItem(), 0, state);
+ }
+
+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 GetItemParent(item) == GetRootItem() && !GetPrevSibling(item);
+ }
+
+private:
+ void AddItemsRecursively(const wxTreeItemId& idParent,
+ size_t nChildren,
+ size_t depth,
+ size_t folder);
+
+ void DoResetBrokenStateImages(const wxTreeItemId& idParent,
+ wxTreeItemIdValue cookie, int state);
+
+ void LogEvent(const wxChar *name, const wxTreeEvent& event);
+
+ int m_imageSize; // current size of images
+ bool m_reverseSort; // flag for OnCompareItems
+ wxTreeItemId m_lastItem, // for OnEnsureVisible()
+ m_draggedItem; // item being dragged right now
+ bool m_alternateImages;
+ bool m_alternateStates;
+
+ // 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()