X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/161f4f7380e945b0769ad5f7122df55b8777396a..7af284fda7500594b2ab86c8ba60138164ab4d04:/include/wx/treebase.h diff --git a/include/wx/treebase.h b/include/wx/treebase.h index 1ef4de314a..1d91001888 100644 --- a/include/wx/treebase.h +++ b/include/wx/treebase.h @@ -20,10 +20,9 @@ // headers // ---------------------------------------------------------------------------- -// Not defined in setup.h so removing for now -// #if wxUSE_TREECTRL +#if wxUSE_TREECTRL -#include "wx/control.h" +#include "wx/window.h" // for wxClientData #include "wx/event.h" // ---------------------------------------------------------------------------- @@ -111,6 +110,40 @@ enum wxTreeItemIcon wxTreeItemIcon_Max }; +enum wxButtonImage // effectively the same as wxTreeItemIcon +{ + wxCLOSED_BUTTON = 0, // closed, not selected + wxCLOSED_BUTTON_SELECTED, // closed, selected + wxOPEN_BUTTON, // open, not selected + wxOPEN_BUTTON_SELECTED // open, selected +}; + +/* + * wxTreeCtrl flags + */ +// TODO: maybe renumber these? +#define wxTR_NO_BUTTONS 0x0000 // for convenience +#define wxTR_HAS_BUTTONS 0x0004 // generates a +/- button +#define wxTR_TWIST_BUTTONS 0x0008 // twister buttons +#define wxTR_NO_LINES 0x0100 // don't generate level connectors +#define wxTR_MAC_BUTTONS wxTR_TWIST_BUTTONS // backward compatibility + +#define wxTR_SINGLE 0x0000 // for convenience +#define wxTR_MULTIPLE 0x0020 // can select multiple items +#define wxTR_EXTENDED 0x0040 // TODO: allow extended selection + +#define wxTR_EDIT_LABELS 0x0200 // can edit item labels +#define wxTR_LINES_AT_ROOT 0x0010 // specific to wxMSW +#define wxTR_HIDE_ROOT 0x0800 // don't display root node +#define wxTR_ROW_LINES 0x0400 // put border around items +#define wxTR_HAS_VARIABLE_ROW_HEIGHT 0x0080 // what it says + +// TODO: different default styles for wxGTK, wxMotif, whatever? +#ifdef __WXMAC__ + #define wxTR_DEFAULT_STYLE (wxTR_TWIST_BUTTONS|wxTR_NO_LINES|wxTR_ROW_LINES) +#else + #define wxTR_DEFAULT_STYLE (wxTR_HAS_BUTTONS|wxTR_LINES_AT_ROOT) +#endif // values for the `flags' parameter of wxTreeCtrl::HitTest() which determine // where exactly the specified point is situated: @@ -221,8 +254,6 @@ private: m_itemOld; wxPoint m_pointDrag; wxString m_label; - - DECLARE_DYNAMIC_CLASS(wxTreeEvent) }; typedef void (wxEvtHandler::*wxTreeEventFunction)(wxTreeEvent&); @@ -302,9 +333,7 @@ END_DECLARE_EVENT_TYPES() #define EVT_TREE_ITEM_RIGHT_CLICK(id, fn) DECLARE_EVENT_TABLE_ENTRY( wxEVT_COMMAND_TREE_ITEM_RIGHT_CLICK, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL ), #define EVT_TREE_ITEM_MIDDLE_CLICK(id, fn) DECLARE_EVENT_TABLE_ENTRY( wxEVT_COMMAND_TREE_ITEM_MIDDLE_CLICK, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL ), -// #endif // wxUSE_TREECTRL - -#endif - // _WX_TREEBASE_H_ +#endif // wxUSE_TREECTRL +#endif // _WX_TREEBASE_H_