wxTreeEvent is declared in one header, not 3 of them
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@3111 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -142,89 +142,6 @@ protected:
|
|||||||
wxTreeItemId m_pItem;
|
wxTreeItemId m_pItem;
|
||||||
};
|
};
|
||||||
|
|
||||||
// -----------------------------------------------------------------------------
|
|
||||||
// wxTreeEvent - the event generated by the tree control
|
|
||||||
// -----------------------------------------------------------------------------
|
|
||||||
class WXDLLEXPORT wxTreeEvent : public wxNotifyEvent
|
|
||||||
{
|
|
||||||
friend class wxTreeCtrl;
|
|
||||||
public:
|
|
||||||
wxTreeEvent(wxEventType commandType = wxEVT_NULL, int id = 0);
|
|
||||||
|
|
||||||
// accessors
|
|
||||||
// get the item on which the operation was performed or the newly
|
|
||||||
// selected item for wxEVT_COMMAND_TREE_SEL_CHANGED/ING events
|
|
||||||
wxTreeItemId GetItem() const { return m_item; }
|
|
||||||
|
|
||||||
// for wxEVT_COMMAND_TREE_SEL_CHANGED/ING events, get the previously
|
|
||||||
// selected item
|
|
||||||
wxTreeItemId GetOldItem() const { return m_itemOld; }
|
|
||||||
|
|
||||||
// the point where the mouse was when the drag operation started (for
|
|
||||||
// wxEVT_COMMAND_TREE_BEGIN_(R)DRAG events only)
|
|
||||||
wxPoint GetPoint() const { return m_pointDrag; }
|
|
||||||
|
|
||||||
// keyboard code (for wxEVT_COMMAND_TREE_KEY_DOWN only)
|
|
||||||
int GetCode() const { return m_code; }
|
|
||||||
|
|
||||||
// set return code for wxEVT_COMMAND_TREE_ITEM_{EXPAND|COLLAPS}ING events
|
|
||||||
// call this to forbid the change in item status
|
|
||||||
void Veto() { m_code = TRUE; }
|
|
||||||
|
|
||||||
// for implementation usage only
|
|
||||||
bool WasVetoed() const { return m_code; }
|
|
||||||
|
|
||||||
private:
|
|
||||||
// @@ we could save some space by using union here
|
|
||||||
int m_code;
|
|
||||||
wxTreeItemId m_item,
|
|
||||||
m_itemOld;
|
|
||||||
wxPoint m_pointDrag;
|
|
||||||
|
|
||||||
DECLARE_DYNAMIC_CLASS(wxTreeEvent)
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef void (wxEvtHandler::*wxTreeEventFunction)(wxTreeEvent&);
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// macros for handling tree control events
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
// GetItem() returns the item being dragged, GetPoint() the mouse coords
|
|
||||||
#define EVT_TREE_BEGIN_DRAG(id, fn) { wxEVT_COMMAND_TREE_BEGIN_DRAG, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
#define EVT_TREE_BEGIN_RDRAG(id, fn) { wxEVT_COMMAND_TREE_BEGIN_RDRAG, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
|
|
||||||
// GetItem() returns the itme whose label is being edited
|
|
||||||
#define EVT_TREE_BEGIN_LABEL_EDIT(id, fn) { wxEVT_COMMAND_TREE_BEGIN_LABEL_EDIT, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
#define EVT_TREE_END_LABEL_EDIT(id, fn) { wxEVT_COMMAND_TREE_END_LABEL_EDIT, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
|
|
||||||
// provide/update information about GetItem() item
|
|
||||||
#define EVT_TREE_GET_INFO(id, fn) { wxEVT_COMMAND_TREE_GET_INFO, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
#define EVT_TREE_SET_INFO(id, fn) { wxEVT_COMMAND_TREE_SET_INFO, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
|
|
||||||
// GetItem() is the item being expanded/collapsed, the "ING" versions can use
|
|
||||||
#define EVT_TREE_ITEM_EXPANDED(id, fn) { wxEVT_COMMAND_TREE_ITEM_EXPANDED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
#define EVT_TREE_ITEM_EXPANDING(id, fn) { wxEVT_COMMAND_TREE_ITEM_EXPANDING, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
#define EVT_TREE_ITEM_COLLAPSED(id, fn) { wxEVT_COMMAND_TREE_ITEM_COLLAPSED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
#define EVT_TREE_ITEM_COLLAPSING(id, fn) { wxEVT_COMMAND_TREE_ITEM_COLLAPSING, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL },
|
|
||||||
|
|
||||||
// GetOldItem() is the item which had the selection previously, GetItem() is
|
|
||||||
// the item which acquires selection
|
|
||||||
#define EVT_TREE_SEL_CHANGED(id, fn) { wxEVT_COMMAND_TREE_SEL_CHANGED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL },
|
|
||||||
#define EVT_TREE_SEL_CHANGING(id, fn) { wxEVT_COMMAND_TREE_SEL_CHANGING, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL },
|
|
||||||
|
|
||||||
// GetCode() returns the key code
|
|
||||||
// NB: this is the only message for which GetItem() is invalid (you may get the
|
|
||||||
// item from GetSelection())
|
|
||||||
#define EVT_TREE_KEY_DOWN(id, fn) { wxEVT_COMMAND_TREE_KEY_DOWN, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL },
|
|
||||||
|
|
||||||
// GetItem() returns the item being deleted, the associated data (if any) will
|
|
||||||
// be deleted just after the return of this event handler (if any)
|
|
||||||
#define EVT_TREE_DELETE_ITEM(id, fn) { wxEVT_COMMAND_TREE_DELETE_ITEM, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
|
|
||||||
// GetItem() returns the item that was activated (double click, enter, space)
|
|
||||||
#define EVT_TREE_ITEM_ACTIVATED(id, fn) { wxEVT_COMMAND_TREE_ITEM_ACTIVATED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL },
|
|
||||||
|
|
||||||
// -----------------------------------------------------------------------------
|
// -----------------------------------------------------------------------------
|
||||||
// wxTreeCtrl - the tree control
|
// wxTreeCtrl - the tree control
|
||||||
// -----------------------------------------------------------------------------
|
// -----------------------------------------------------------------------------
|
||||||
|
@@ -17,8 +17,6 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "wx/textctrl.h"
|
#include "wx/textctrl.h"
|
||||||
#include "wx/control.h"
|
|
||||||
#include "wx/event.h"
|
|
||||||
#include "wx/imaglist.h"
|
#include "wx/imaglist.h"
|
||||||
|
|
||||||
#include <gtk/gtk.h>
|
#include <gtk/gtk.h>
|
||||||
@@ -408,85 +406,5 @@ protected:
|
|||||||
DECLARE_DYNAMIC_CLASS(wxTreeCtrl)
|
DECLARE_DYNAMIC_CLASS(wxTreeCtrl)
|
||||||
};
|
};
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// wxTreeEvent is a special class for all events associated with tree controls
|
|
||||||
//
|
|
||||||
// NB: note that not all accessors make sense for all events, see the event
|
|
||||||
// descriptions below
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
class WXDLLEXPORT wxTreeEvent : public wxCommandEvent
|
|
||||||
{
|
|
||||||
friend wxTreeCtrl;
|
|
||||||
public:
|
|
||||||
wxTreeEvent(wxEventType commandType = wxEVT_NULL, int id = 0);
|
|
||||||
|
|
||||||
// accessors
|
|
||||||
// get the item on which the operation was performed or the newly
|
|
||||||
// selected item for wxEVT_COMMAND_TREE_SEL_CHANGED/ING events
|
|
||||||
wxTreeItemId GetItem() const { return m_item; }
|
|
||||||
|
|
||||||
// for wxEVT_COMMAND_TREE_SEL_CHANGED/ING events, get the previously
|
|
||||||
// selected item
|
|
||||||
wxTreeItemId GetOldItem() const { return m_itemOld; }
|
|
||||||
|
|
||||||
// the point where the mouse was when the drag operation started (for
|
|
||||||
// wxEVT_COMMAND_TREE_BEGIN_(R)DRAG events only)
|
|
||||||
wxPoint GetPoint() const { return m_pointDrag; }
|
|
||||||
|
|
||||||
// keyboard code (for wxEVT_COMMAND_TREE_KEY_DOWN only)
|
|
||||||
int GetCode() const { return m_code; }
|
|
||||||
|
|
||||||
// set return code for wxEVT_COMMAND_TREE_ITEM_{EXPAND|COLLAPS}ING events
|
|
||||||
// call this to forbid the change in item status
|
|
||||||
void Veto() { m_code = TRUE; }
|
|
||||||
|
|
||||||
private:
|
|
||||||
// @@ we could save some space by using union here
|
|
||||||
int m_code;
|
|
||||||
wxTreeItemId m_item,
|
|
||||||
m_itemOld;
|
|
||||||
wxPoint m_pointDrag;
|
|
||||||
|
|
||||||
DECLARE_DYNAMIC_CLASS(wxTreeEvent)
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef void (wxEvtHandler::*wxTreeEventFunction)(wxTreeEvent&);
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// macros for handling tree control events
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
// GetItem() returns the item being dragged, GetPoint() the mouse coords
|
|
||||||
#define EVT_TREE_BEGIN_DRAG(id, fn) { wxEVT_COMMAND_TREE_BEGIN_DRAG, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
#define EVT_TREE_BEGIN_RDRAG(id, fn) { wxEVT_COMMAND_TREE_BEGIN_RDRAG, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
|
|
||||||
// GetItem() returns the itme whose label is being edited
|
|
||||||
#define EVT_TREE_BEGIN_LABEL_EDIT(id, fn) { wxEVT_COMMAND_TREE_BEGIN_LABEL_EDIT, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
#define EVT_TREE_END_LABEL_EDIT(id, fn) { wxEVT_COMMAND_TREE_END_LABEL_EDIT, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
|
|
||||||
// provide/update information about GetItem() item
|
|
||||||
#define EVT_TREE_GET_INFO(id, fn) { wxEVT_COMMAND_TREE_GET_INFO, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
#define EVT_TREE_SET_INFO(id, fn) { wxEVT_COMMAND_TREE_SET_INFO, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
|
|
||||||
// GetItem() is the item being expanded/collapsed, the "ING" versions can use
|
|
||||||
#define EVT_TREE_ITEM_EXPANDED(id, fn) { wxEVT_COMMAND_TREE_ITEM_EXPANDED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
#define EVT_TREE_ITEM_EXPANDING(id, fn) { wxEVT_COMMAND_TREE_ITEM_EXPANDING, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
#define EVT_TREE_ITEM_COLLAPSED(id, fn) { wxEVT_COMMAND_TREE_ITEM_COLLAPSED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
#define EVT_TREE_ITEM_COLLAPSING(id, fn) { wxEVT_COMMAND_TREE_ITEM_COLLAPSING, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL },
|
|
||||||
|
|
||||||
// GetOldItem() is the item which had the selection previously, GetItem() is
|
|
||||||
// the item which acquires selection
|
|
||||||
#define EVT_TREE_SEL_CHANGED(id, fn) { wxEVT_COMMAND_TREE_SEL_CHANGED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL },
|
|
||||||
#define EVT_TREE_SEL_CHANGING(id, fn) { wxEVT_COMMAND_TREE_SEL_CHANGING, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL },
|
|
||||||
|
|
||||||
// GetCode() returns the key code
|
|
||||||
// NB: this is the only message for which GetItem() is invalid (you may get the
|
|
||||||
// item from GetSelection())
|
|
||||||
#define EVT_TREE_KEY_DOWN(id, fn) { wxEVT_COMMAND_TREE_KEY_DOWN, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL },
|
|
||||||
|
|
||||||
// GetItem() returns the item being deleted, the associated data (if any) will
|
|
||||||
// be deleted just after the return of this event handler (if any)
|
|
||||||
#define EVT_TREE_DELETE_ITEM(id, fn) { wxEVT_COMMAND_TREE_DELETE_ITEM, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
// _WX_TREECTRL_H_
|
// _WX_TREECTRL_H_
|
||||||
|
@@ -17,8 +17,6 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "wx/textctrl.h"
|
#include "wx/textctrl.h"
|
||||||
#include "wx/control.h"
|
|
||||||
#include "wx/event.h"
|
|
||||||
#include "wx/imaglist.h"
|
#include "wx/imaglist.h"
|
||||||
|
|
||||||
#include <gtk/gtk.h>
|
#include <gtk/gtk.h>
|
||||||
@@ -408,85 +406,5 @@ protected:
|
|||||||
DECLARE_DYNAMIC_CLASS(wxTreeCtrl)
|
DECLARE_DYNAMIC_CLASS(wxTreeCtrl)
|
||||||
};
|
};
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// wxTreeEvent is a special class for all events associated with tree controls
|
|
||||||
//
|
|
||||||
// NB: note that not all accessors make sense for all events, see the event
|
|
||||||
// descriptions below
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
class WXDLLEXPORT wxTreeEvent : public wxCommandEvent
|
|
||||||
{
|
|
||||||
friend wxTreeCtrl;
|
|
||||||
public:
|
|
||||||
wxTreeEvent(wxEventType commandType = wxEVT_NULL, int id = 0);
|
|
||||||
|
|
||||||
// accessors
|
|
||||||
// get the item on which the operation was performed or the newly
|
|
||||||
// selected item for wxEVT_COMMAND_TREE_SEL_CHANGED/ING events
|
|
||||||
wxTreeItemId GetItem() const { return m_item; }
|
|
||||||
|
|
||||||
// for wxEVT_COMMAND_TREE_SEL_CHANGED/ING events, get the previously
|
|
||||||
// selected item
|
|
||||||
wxTreeItemId GetOldItem() const { return m_itemOld; }
|
|
||||||
|
|
||||||
// the point where the mouse was when the drag operation started (for
|
|
||||||
// wxEVT_COMMAND_TREE_BEGIN_(R)DRAG events only)
|
|
||||||
wxPoint GetPoint() const { return m_pointDrag; }
|
|
||||||
|
|
||||||
// keyboard code (for wxEVT_COMMAND_TREE_KEY_DOWN only)
|
|
||||||
int GetCode() const { return m_code; }
|
|
||||||
|
|
||||||
// set return code for wxEVT_COMMAND_TREE_ITEM_{EXPAND|COLLAPS}ING events
|
|
||||||
// call this to forbid the change in item status
|
|
||||||
void Veto() { m_code = TRUE; }
|
|
||||||
|
|
||||||
private:
|
|
||||||
// @@ we could save some space by using union here
|
|
||||||
int m_code;
|
|
||||||
wxTreeItemId m_item,
|
|
||||||
m_itemOld;
|
|
||||||
wxPoint m_pointDrag;
|
|
||||||
|
|
||||||
DECLARE_DYNAMIC_CLASS(wxTreeEvent)
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef void (wxEvtHandler::*wxTreeEventFunction)(wxTreeEvent&);
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// macros for handling tree control events
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
// GetItem() returns the item being dragged, GetPoint() the mouse coords
|
|
||||||
#define EVT_TREE_BEGIN_DRAG(id, fn) { wxEVT_COMMAND_TREE_BEGIN_DRAG, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
#define EVT_TREE_BEGIN_RDRAG(id, fn) { wxEVT_COMMAND_TREE_BEGIN_RDRAG, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
|
|
||||||
// GetItem() returns the itme whose label is being edited
|
|
||||||
#define EVT_TREE_BEGIN_LABEL_EDIT(id, fn) { wxEVT_COMMAND_TREE_BEGIN_LABEL_EDIT, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
#define EVT_TREE_END_LABEL_EDIT(id, fn) { wxEVT_COMMAND_TREE_END_LABEL_EDIT, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
|
|
||||||
// provide/update information about GetItem() item
|
|
||||||
#define EVT_TREE_GET_INFO(id, fn) { wxEVT_COMMAND_TREE_GET_INFO, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
#define EVT_TREE_SET_INFO(id, fn) { wxEVT_COMMAND_TREE_SET_INFO, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
|
|
||||||
// GetItem() is the item being expanded/collapsed, the "ING" versions can use
|
|
||||||
#define EVT_TREE_ITEM_EXPANDED(id, fn) { wxEVT_COMMAND_TREE_ITEM_EXPANDED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
#define EVT_TREE_ITEM_EXPANDING(id, fn) { wxEVT_COMMAND_TREE_ITEM_EXPANDING, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
#define EVT_TREE_ITEM_COLLAPSED(id, fn) { wxEVT_COMMAND_TREE_ITEM_COLLAPSED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
#define EVT_TREE_ITEM_COLLAPSING(id, fn) { wxEVT_COMMAND_TREE_ITEM_COLLAPSING, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL },
|
|
||||||
|
|
||||||
// GetOldItem() is the item which had the selection previously, GetItem() is
|
|
||||||
// the item which acquires selection
|
|
||||||
#define EVT_TREE_SEL_CHANGED(id, fn) { wxEVT_COMMAND_TREE_SEL_CHANGED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL },
|
|
||||||
#define EVT_TREE_SEL_CHANGING(id, fn) { wxEVT_COMMAND_TREE_SEL_CHANGING, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL },
|
|
||||||
|
|
||||||
// GetCode() returns the key code
|
|
||||||
// NB: this is the only message for which GetItem() is invalid (you may get the
|
|
||||||
// item from GetSelection())
|
|
||||||
#define EVT_TREE_KEY_DOWN(id, fn) { wxEVT_COMMAND_TREE_KEY_DOWN, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL },
|
|
||||||
|
|
||||||
// GetItem() returns the item being deleted, the associated data (if any) will
|
|
||||||
// be deleted just after the return of this event handler (if any)
|
|
||||||
#define EVT_TREE_DELETE_ITEM(id, fn) { wxEVT_COMMAND_TREE_DELETE_ITEM, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
// _WX_TREECTRL_H_
|
// _WX_TREECTRL_H_
|
||||||
|
@@ -20,8 +20,6 @@
|
|||||||
#pragma interface "treectrl.h"
|
#pragma interface "treectrl.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "wx/control.h"
|
|
||||||
#include "wx/event.h"
|
|
||||||
#include "wx/textctrl.h"
|
#include "wx/textctrl.h"
|
||||||
|
|
||||||
#ifdef __GNUWIN32__
|
#ifdef __GNUWIN32__
|
||||||
@@ -476,92 +474,5 @@ private:
|
|||||||
DECLARE_DYNAMIC_CLASS(wxTreeCtrl)
|
DECLARE_DYNAMIC_CLASS(wxTreeCtrl)
|
||||||
};
|
};
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// wxTreeEvent is a special class for all events associated with tree controls
|
|
||||||
//
|
|
||||||
// NB: note that not all accessors make sense for all events, see the event
|
|
||||||
// descriptions below
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
class WXDLLEXPORT wxTreeEvent : public wxNotifyEvent
|
|
||||||
{
|
|
||||||
friend wxTreeCtrl;
|
|
||||||
public:
|
|
||||||
wxTreeEvent(wxEventType commandType = wxEVT_NULL, int id = 0);
|
|
||||||
|
|
||||||
// accessors
|
|
||||||
// get the item on which the operation was performed or the newly
|
|
||||||
// selected item for wxEVT_COMMAND_TREE_SEL_CHANGED/ING events
|
|
||||||
wxTreeItemId GetItem() const { return m_item; }
|
|
||||||
|
|
||||||
// for wxEVT_COMMAND_TREE_SEL_CHANGED/ING events, get the previously
|
|
||||||
// selected item
|
|
||||||
wxTreeItemId GetOldItem() const { return m_itemOld; }
|
|
||||||
|
|
||||||
// the point where the mouse was when the drag operation started (for
|
|
||||||
// wxEVT_COMMAND_TREE_BEGIN_(R)DRAG events only)
|
|
||||||
wxPoint GetPoint() const { return m_pointDrag; }
|
|
||||||
|
|
||||||
// keyboard code (for wxEVT_COMMAND_TREE_KEY_DOWN only)
|
|
||||||
int GetCode() const { return m_code; }
|
|
||||||
|
|
||||||
// label (for EVT_TREE_{BEGIN|END}_LABEL_EDIT only)
|
|
||||||
const wxString& GetLabel() const { return m_label; }
|
|
||||||
|
|
||||||
private:
|
|
||||||
// TODO we could save some space by using union here
|
|
||||||
int m_code;
|
|
||||||
wxTreeItemId m_item,
|
|
||||||
m_itemOld;
|
|
||||||
wxPoint m_pointDrag;
|
|
||||||
wxString m_label;
|
|
||||||
|
|
||||||
DECLARE_DYNAMIC_CLASS(wxTreeEvent)
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef void (wxEvtHandler::*wxTreeEventFunction)(wxTreeEvent&);
|
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
// macros for handling tree control events
|
|
||||||
// ----------------------------------------------------------------------------
|
|
||||||
|
|
||||||
// GetItem() returns the item being dragged, GetPoint() the mouse coords
|
|
||||||
#define EVT_TREE_BEGIN_DRAG(id, fn) { wxEVT_COMMAND_TREE_BEGIN_DRAG, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
#define EVT_TREE_BEGIN_RDRAG(id, fn) { wxEVT_COMMAND_TREE_BEGIN_RDRAG, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
|
|
||||||
// GetItem() returns the itme whose label is being edited, GetLabel() returns
|
|
||||||
// the current item label for BEGIN and the would be new one for END.
|
|
||||||
//
|
|
||||||
// Vetoing BEGIN event means that label editing won't happen at all,
|
|
||||||
// vetoing END means that the new value is discarded and the old one kept
|
|
||||||
#define EVT_TREE_BEGIN_LABEL_EDIT(id, fn) { wxEVT_COMMAND_TREE_BEGIN_LABEL_EDIT, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
#define EVT_TREE_END_LABEL_EDIT(id, fn) { wxEVT_COMMAND_TREE_END_LABEL_EDIT, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
|
|
||||||
// provide/update information about GetItem() item
|
|
||||||
#define EVT_TREE_GET_INFO(id, fn) { wxEVT_COMMAND_TREE_GET_INFO, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
#define EVT_TREE_SET_INFO(id, fn) { wxEVT_COMMAND_TREE_SET_INFO, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
|
|
||||||
// GetItem() is the item being expanded/collapsed, the "ING" versions can use
|
|
||||||
#define EVT_TREE_ITEM_EXPANDED(id, fn) { wxEVT_COMMAND_TREE_ITEM_EXPANDED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
#define EVT_TREE_ITEM_EXPANDING(id, fn) { wxEVT_COMMAND_TREE_ITEM_EXPANDING, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
#define EVT_TREE_ITEM_COLLAPSED(id, fn) { wxEVT_COMMAND_TREE_ITEM_COLLAPSED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
#define EVT_TREE_ITEM_COLLAPSING(id, fn) { wxEVT_COMMAND_TREE_ITEM_COLLAPSING, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL },
|
|
||||||
|
|
||||||
// GetOldItem() is the item which had the selection previously, GetItem() is
|
|
||||||
// the item which acquires selection
|
|
||||||
#define EVT_TREE_SEL_CHANGED(id, fn) { wxEVT_COMMAND_TREE_SEL_CHANGED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL },
|
|
||||||
#define EVT_TREE_SEL_CHANGING(id, fn) { wxEVT_COMMAND_TREE_SEL_CHANGING, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL },
|
|
||||||
|
|
||||||
// GetCode() returns the key code
|
|
||||||
// NB: this is the only message for which GetItem() is invalid (you may get the
|
|
||||||
// item from GetSelection())
|
|
||||||
#define EVT_TREE_KEY_DOWN(id, fn) { wxEVT_COMMAND_TREE_KEY_DOWN, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL },
|
|
||||||
|
|
||||||
// GetItem() returns the item being deleted, the associated data (if any) will
|
|
||||||
// be deleted just after the return of this event handler (if any)
|
|
||||||
#define EVT_TREE_DELETE_ITEM(id, fn) { wxEVT_COMMAND_TREE_DELETE_ITEM, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
|
||||||
|
|
||||||
// GetItem() returns the item that was activated (double click, enter, space)
|
|
||||||
#define EVT_TREE_ITEM_ACTIVATED(id, fn) { wxEVT_COMMAND_TREE_ITEM_ACTIVATED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL },
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
// _WX_TREECTRL_H_
|
// _WX_TREECTRL_H_
|
||||||
|
@@ -1,23 +1,122 @@
|
|||||||
#ifndef _WX_TREECTRL_H_BASE_
|
#ifndef _WX_TREECTRL_H_BASE_
|
||||||
#define _WX_TREECTRL_H_BASE_
|
#define _WX_TREECTRL_H_BASE_
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// headers
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
#include "wx/control.h"
|
||||||
|
#include "wx/event.h"
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// include the platform-dependent wxTreeCtrl class
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
#if defined(__WXMSW__)
|
#if defined(__WXMSW__)
|
||||||
#ifdef __WIN16__
|
#ifdef __WIN16__
|
||||||
#include "wx/generic/treectrl.h"
|
#include "wx/generic/treectrl.h"
|
||||||
#else
|
#else
|
||||||
#include "wx/msw/treectrl.h"
|
#include "wx/msw/treectrl.h"
|
||||||
#endif
|
#endif
|
||||||
#elif defined(__WXMOTIF__)
|
#elif defined(__WXMOTIF__)
|
||||||
#include "wx/generic/treectrl.h"
|
#include "wx/generic/treectrl.h"
|
||||||
#elif defined(__WXGTK__)
|
#elif defined(__WXGTK__)
|
||||||
#include "wx/generic/treectrl.h"
|
#include "wx/generic/treectrl.h"
|
||||||
#elif defined(__WXQT__)
|
#elif defined(__WXQT__)
|
||||||
#include "wx/qt/treectrl.h"
|
#include "wx/qt/treectrl.h"
|
||||||
#elif defined(__WXMAC__)
|
#elif defined(__WXMAC__)
|
||||||
#include "wx/generic/treectrl.h"
|
#include "wx/generic/treectrl.h"
|
||||||
#elif defined(__WXSTUBS__)
|
#elif defined(__WXSTUBS__)
|
||||||
#include "wx/generic/treectrl.h"
|
#include "wx/generic/treectrl.h"
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// wxTreeEvent is a special class for all events associated with tree controls
|
||||||
|
//
|
||||||
|
// NB: note that not all accessors make sense for all events, see the event
|
||||||
|
// descriptions below
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
class WXDLLEXPORT wxTreeEvent : public wxNotifyEvent
|
||||||
|
{
|
||||||
|
friend wxTreeCtrl;
|
||||||
|
public:
|
||||||
|
wxTreeEvent(wxEventType commandType = wxEVT_NULL, int id = 0);
|
||||||
|
|
||||||
|
// accessors
|
||||||
|
// get the item on which the operation was performed or the newly
|
||||||
|
// selected item for wxEVT_COMMAND_TREE_SEL_CHANGED/ING events
|
||||||
|
wxTreeItemId GetItem() const { return m_item; }
|
||||||
|
|
||||||
|
// for wxEVT_COMMAND_TREE_SEL_CHANGED/ING events, get the previously
|
||||||
|
// selected item
|
||||||
|
wxTreeItemId GetOldItem() const { return m_itemOld; }
|
||||||
|
|
||||||
|
// the point where the mouse was when the drag operation started (for
|
||||||
|
// wxEVT_COMMAND_TREE_BEGIN_(R)DRAG events only)
|
||||||
|
wxPoint GetPoint() const { return m_pointDrag; }
|
||||||
|
|
||||||
|
// keyboard code (for wxEVT_COMMAND_TREE_KEY_DOWN only)
|
||||||
|
int GetCode() const { return m_code; }
|
||||||
|
|
||||||
|
// label (for EVT_TREE_{BEGIN|END}_LABEL_EDIT only)
|
||||||
|
const wxString& GetLabel() const { return m_label; }
|
||||||
|
|
||||||
|
private:
|
||||||
|
// TODO we could save some space by using union here
|
||||||
|
int m_code;
|
||||||
|
wxTreeItemId m_item,
|
||||||
|
m_itemOld;
|
||||||
|
wxPoint m_pointDrag;
|
||||||
|
wxString m_label;
|
||||||
|
|
||||||
|
DECLARE_DYNAMIC_CLASS(wxTreeEvent)
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef void (wxEvtHandler::*wxTreeEventFunction)(wxTreeEvent&);
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
// macros for handling tree control events
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
// GetItem() returns the item being dragged, GetPoint() the mouse coords
|
||||||
|
#define EVT_TREE_BEGIN_DRAG(id, fn) { wxEVT_COMMAND_TREE_BEGIN_DRAG, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
||||||
|
#define EVT_TREE_BEGIN_RDRAG(id, fn) { wxEVT_COMMAND_TREE_BEGIN_RDRAG, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
||||||
|
|
||||||
|
// GetItem() returns the itme whose label is being edited, GetLabel() returns
|
||||||
|
// the current item label for BEGIN and the would be new one for END.
|
||||||
|
//
|
||||||
|
// Vetoing BEGIN event means that label editing won't happen at all,
|
||||||
|
// vetoing END means that the new value is discarded and the old one kept
|
||||||
|
#define EVT_TREE_BEGIN_LABEL_EDIT(id, fn) { wxEVT_COMMAND_TREE_BEGIN_LABEL_EDIT, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
||||||
|
#define EVT_TREE_END_LABEL_EDIT(id, fn) { wxEVT_COMMAND_TREE_END_LABEL_EDIT, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
||||||
|
|
||||||
|
// provide/update information about GetItem() item
|
||||||
|
#define EVT_TREE_GET_INFO(id, fn) { wxEVT_COMMAND_TREE_GET_INFO, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
||||||
|
#define EVT_TREE_SET_INFO(id, fn) { wxEVT_COMMAND_TREE_SET_INFO, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
||||||
|
|
||||||
|
// GetItem() is the item being expanded/collapsed, the "ING" versions can use
|
||||||
|
#define EVT_TREE_ITEM_EXPANDED(id, fn) { wxEVT_COMMAND_TREE_ITEM_EXPANDED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
||||||
|
#define EVT_TREE_ITEM_EXPANDING(id, fn) { wxEVT_COMMAND_TREE_ITEM_EXPANDING, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
||||||
|
#define EVT_TREE_ITEM_COLLAPSED(id, fn) { wxEVT_COMMAND_TREE_ITEM_COLLAPSED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
||||||
|
#define EVT_TREE_ITEM_COLLAPSING(id, fn) { wxEVT_COMMAND_TREE_ITEM_COLLAPSING, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL },
|
||||||
|
|
||||||
|
// GetOldItem() is the item which had the selection previously, GetItem() is
|
||||||
|
// the item which acquires selection
|
||||||
|
#define EVT_TREE_SEL_CHANGED(id, fn) { wxEVT_COMMAND_TREE_SEL_CHANGED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL },
|
||||||
|
#define EVT_TREE_SEL_CHANGING(id, fn) { wxEVT_COMMAND_TREE_SEL_CHANGING, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL },
|
||||||
|
|
||||||
|
// GetCode() returns the key code
|
||||||
|
// NB: this is the only message for which GetItem() is invalid (you may get the
|
||||||
|
// item from GetSelection())
|
||||||
|
#define EVT_TREE_KEY_DOWN(id, fn) { wxEVT_COMMAND_TREE_KEY_DOWN, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL },
|
||||||
|
|
||||||
|
// GetItem() returns the item being deleted, the associated data (if any) will
|
||||||
|
// be deleted just after the return of this event handler (if any)
|
||||||
|
#define EVT_TREE_DELETE_ITEM(id, fn) { wxEVT_COMMAND_TREE_DELETE_ITEM, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, (wxObject *) NULL },
|
||||||
|
|
||||||
|
// GetItem() returns the item that was activated (double click, enter, space)
|
||||||
|
#define EVT_TREE_ITEM_ACTIVATED(id, fn) { wxEVT_COMMAND_TREE_ITEM_ACTIVATED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxTreeEventFunction) & fn, NULL },
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
// _WX_TREECTRL_H_BASE_
|
// _WX_TREECTRL_H_BASE_
|
||||||
|
@@ -1777,7 +1777,8 @@ void wxTreeCtrl::OnMouse( wxMouseEvent &event )
|
|||||||
if (onButton)
|
if (onButton)
|
||||||
{
|
{
|
||||||
Toggle( item );
|
Toggle( item );
|
||||||
if (is_multiple) return;
|
if (is_multiple)
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
SelectItem(item, unselect_others, extended_select);
|
SelectItem(item, unselect_others, extended_select);
|
||||||
|
Reference in New Issue
Block a user