X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/77ff2d2639049a0bd8d64d87fbe27694354b7097..2356708db31b737c6eae53c2316b642aa5a2e68d:/include/wx/generic/listctrl.h diff --git a/include/wx/generic/listctrl.h b/include/wx/generic/listctrl.h index a2c0493699..4b14eb011c 100644 --- a/include/wx/generic/listctrl.h +++ b/include/wx/generic/listctrl.h @@ -17,7 +17,7 @@ #include "wx/defs.h" #include "wx/object.h" -#include "wx/imaglist.h" +#include "wx/generic/imaglist.h" #include "wx/control.h" #include "wx/timer.h" #include "wx/textctrl.h" @@ -25,27 +25,31 @@ #include "wx/scrolwin.h" #include "wx/settings.h" +#if wxUSE_DRAG_AND_DROP +class WXDLLEXPORT wxDropTarget; +#endif + //----------------------------------------------------------------------------- // classes //----------------------------------------------------------------------------- -class wxListItem; -class wxListEvent; -class wxListCtrl; +class WXDLLEXPORT wxListItem; +class WXDLLEXPORT wxListEvent; +class WXDLLEXPORT wxListCtrl; //----------------------------------------------------------------------------- // internal classes //----------------------------------------------------------------------------- -class wxListHeaderData; -class wxListItemData; -class wxListLineData; +class WXDLLEXPORT wxListHeaderData; +class WXDLLEXPORT wxListItemData; +class WXDLLEXPORT wxListLineData; -class wxListHeaderWindow; -class wxListMainWindow; +class WXDLLEXPORT wxListHeaderWindow; +class WXDLLEXPORT wxListMainWindow; -class wxListRenameTimer; -//class wxListTextCtrl; +class WXDLLEXPORT wxListRenameTimer; +class WXDLLEXPORT wxListTextCtrl; //----------------------------------------------------------------------------- // types @@ -141,8 +145,8 @@ enum { // Autosize values for SetColumnWidth enum { - wxLIST_AUTOSIZE = -1, // always 80 in wxGLC (what else?) - wxLIST_AUTOSIZE_USEHEADER = -2 + wxLIST_AUTOSIZE = -1, // width of longest item + wxLIST_AUTOSIZE_USEHEADER = -2 // always 80 in wxGLC }; // Flag values for GetItemRect @@ -164,7 +168,7 @@ enum { // wxListItem //----------------------------------------------------------------------------- -class wxListItem: public wxObject +class WXDLLEXPORT wxListItem: public wxObject { DECLARE_DYNAMIC_CLASS(wxListItem) @@ -186,53 +190,15 @@ class wxListItem: public wxObject wxListItem(void); }; -//----------------------------------------------------------------------------- -// wxListEvent -//----------------------------------------------------------------------------- - -class WXDLLEXPORT wxListEvent: public wxCommandEvent -{ - DECLARE_DYNAMIC_CLASS(wxListEvent) - - public: - wxListEvent(wxEventType commandType = wxEVT_NULL, int id = 0); - - int m_code; - long m_itemIndex; - long m_oldItemIndex; - int m_col; - bool m_cancelled; - wxPoint m_pointDrag; - - wxListItem m_item; -}; - -typedef void (wxEvtHandler::*wxListEventFunction)(wxListEvent&); - -#define EVT_LIST_BEGIN_DRAG(id, fn) { wxEVT_COMMAND_LIST_BEGIN_DRAG, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxListEventFunction) & fn, NULL }, -#define EVT_LIST_BEGIN_RDRAG(id, fn) { wxEVT_COMMAND_LIST_BEGIN_RDRAG, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxListEventFunction) & fn, NULL }, -#define EVT_LIST_BEGIN_LABEL_EDIT(id, fn) { wxEVT_COMMAND_LIST_BEGIN_LABEL_EDIT, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxListEventFunction) & fn, NULL }, -#define EVT_LIST_END_LABEL_EDIT(id, fn) { wxEVT_COMMAND_LIST_END_LABEL_EDIT, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxListEventFunction) & fn, NULL }, -#define EVT_LIST_DELETE_ITEM(id, fn) { wxEVT_COMMAND_LIST_DELETE_ITEM, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxListEventFunction) & fn, NULL }, -#define EVT_LIST_DELETE_ALL_ITEMS(id, fn) { wxEVT_COMMAND_LIST_DELETE_ALL_ITEMS, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxListEventFunction) & fn, NULL }, -#define EVT_LIST_GET_INFO(id, fn) { wxEVT_COMMAND_LIST_GET_INFO, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxListEventFunction) & fn, NULL }, -#define EVT_LIST_SET_INFO(id, fn) { wxEVT_COMMAND_LIST_SET_INFO, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxListEventFunction) & fn, NULL }, -#define EVT_LIST_ITEM_SELECTED(id, fn) { wxEVT_COMMAND_LIST_ITEM_SELECTED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxListEventFunction) & fn, NULL }, -#define EVT_LIST_ITEM_DESELECTED(id, fn) { wxEVT_COMMAND_LIST_ITEM_DESELECTED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxListEventFunction) & fn, NULL }, -#define EVT_LIST_KEY_DOWN(id, fn) { wxEVT_COMMAND_LIST_KEY_DOWN, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxListEventFunction) & fn, NULL }, -#define EVT_LIST_INSERT_ITEM(id, fn) { wxEVT_COMMAND_LIST_INSERT_ITEM, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxListEventFunction) & fn, NULL }, -#define EVT_LIST_COL_CLICK(id, fn) { wxEVT_COMMAND_LIST_COL_CLICK, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxListEventFunction) & fn, NULL }, - - //----------------------------------------------------------------------------- // wxListItemData (internal) //----------------------------------------------------------------------------- -class wxListItemData : public wxObject +class WXDLLEXPORT wxListItemData : public wxObject { DECLARE_DYNAMIC_CLASS(wxListItemData); - protected: + public: wxString m_text; int m_image; long m_data; @@ -267,7 +233,7 @@ class wxListItemData : public wxObject // wxListHeaderData (internal) //----------------------------------------------------------------------------- -class wxListHeaderData : public wxObject +class WXDLLEXPORT wxListHeaderData : public wxObject { DECLARE_DYNAMIC_CLASS(wxListHeaderData); @@ -302,29 +268,29 @@ class wxListHeaderData : public wxObject // wxListLineData (internal) //----------------------------------------------------------------------------- -class wxListLineData : public wxObject +class WXDLLEXPORT wxListLineData : public wxObject { DECLARE_DYNAMIC_CLASS(wxListLineData); - protected: + public: wxList m_items; - wxRectangle m_bound_all; - wxRectangle m_bound_label; - wxRectangle m_bound_icon; - wxRectangle m_bound_hilight; + wxRect m_bound_all; + wxRect m_bound_label; + wxRect m_bound_icon; + wxRect m_bound_hilight; int m_mode; bool m_hilighted; wxBrush *m_hilightBrush; int m_spacing; wxListMainWindow *m_owner; - void DoDraw( wxPaintDC *dc, bool hilight, bool paintBG ); + void DoDraw( wxDC *dc, bool hilight, bool paintBG ); public: wxListLineData( void ) {}; wxListLineData( wxListMainWindow *owner, int mode, wxBrush *hilightBrush ); - void CalculateSize( wxPaintDC *dc, int spacing ); - void SetPosition( wxPaintDC *dc, int x, int y, int window_width ); + void CalculateSize( wxDC *dc, int spacing ); + void SetPosition( wxDC *dc, int x, int y, int window_width ); void SetColumnPosition( int index, int x ); void GetSize( int &width, int &height ); void GetExtent( int &x, int &y, int &width, int &height ); @@ -336,22 +302,22 @@ class wxListLineData : public wxObject void GetText( int index, wxString &s ); void SetText( int index, const wxString s ); int GetImage( int index ); - void GetRect( wxRectangle &rect ); + void GetRect( wxRect &rect ); void Hilight( bool on ); void ReverseHilight( void ); - void DrawRubberBand( wxPaintDC *dc, bool on ); - void Draw( wxPaintDC *dc ); - bool IsInRect( int x, int y, const wxRectangle &rect ); + void DrawRubberBand( wxDC *dc, bool on ); + void Draw( wxDC *dc ); + bool IsInRect( int x, int y, const wxRect &rect ); bool IsHilighted( void ); - void AssignRect( wxRectangle &dest, int x, int y, int width, int height ); - void AssignRect( wxRectangle &dest, const wxRectangle &source ); + void AssignRect( wxRect &dest, int x, int y, int width, int height ); + void AssignRect( wxRect &dest, const wxRect &source ); }; //----------------------------------------------------------------------------- // wxListHeaderWindow (internal) //----------------------------------------------------------------------------- -class wxListHeaderWindow : public wxWindow +class WXDLLEXPORT wxListHeaderWindow : public wxWindow { DECLARE_DYNAMIC_CLASS(wxListHeaderWindow) @@ -359,14 +325,20 @@ class wxListHeaderWindow : public wxWindow wxListMainWindow *m_owner; wxCursor *m_currentCursor; wxCursor *m_resizeCursor; + bool m_isDragging; + int m_column; + int m_minX; + int m_currentX; public: wxListHeaderWindow( void ); + ~wxListHeaderWindow( void ); wxListHeaderWindow( wxWindow *win, wxWindowID id, wxListMainWindow *owner, const wxPoint &pos = wxDefaultPosition, const wxSize &size = wxDefaultSize, long style = 0, const wxString &name = "columntitles" ); - void DoDrawRect( wxPaintDC *dc, int x, int y, int w, int h ); + void DoDrawRect( wxDC *dc, int x, int y, int w, int h ); void OnPaint( wxPaintEvent &event ); + void DrawCurrent(); void OnMouse( wxMouseEvent &event ); void OnSetFocus( wxFocusEvent &event ); @@ -377,7 +349,7 @@ class wxListHeaderWindow : public wxWindow // wxListRenameTimer (internal) //----------------------------------------------------------------------------- -class wxListRenameTimer: public wxTimer +class WXDLLEXPORT wxListRenameTimer: public wxTimer { private: wxListMainWindow *m_owner; @@ -391,7 +363,7 @@ class wxListRenameTimer: public wxTimer // wxListTextCtrl (internal) //----------------------------------------------------------------------------- -class wxListTextCtrl: public wxTextCtrl +class WXDLLEXPORT wxListTextCtrl: public wxTextCtrl { DECLARE_DYNAMIC_CLASS(wxListTextCtrl); @@ -399,6 +371,7 @@ class wxListTextCtrl: public wxTextCtrl bool *m_accept; wxString *m_res; wxListMainWindow *m_owner; + wxString m_startValue; public: wxListTextCtrl(void) {}; @@ -418,7 +391,7 @@ class wxListTextCtrl: public wxTextCtrl // wxListMainWindow (internal) //----------------------------------------------------------------------------- -class wxListMainWindow: public wxScrolledWindow +class WXDLLEXPORT wxListMainWindow: public wxScrolledWindow { DECLARE_DYNAMIC_CLASS(wxListMainWindow); @@ -427,10 +400,10 @@ class wxListMainWindow: public wxScrolledWindow wxList m_lines; wxList m_columns; wxListLineData *m_current; + wxListLineData *m_currentEdit; int m_visibleLines; wxBrush *m_hilightBrush; wxColour *m_hilightColour; - wxFont *m_myFont; int m_xScroll,m_yScroll; bool m_dirty; wxImageList *m_small_image_list; @@ -441,41 +414,42 @@ class wxListMainWindow: public wxScrolledWindow bool m_usedKeys; bool m_lastOnSame; wxTimer *m_renameTimer; -// wxListTextCtrl *m_text; bool m_renameAccept; wxString m_renameRes; bool m_isCreated; int m_dragCount; public: - wxListMainWindow(void); + wxListMainWindow(); wxListMainWindow( wxWindow *parent, wxWindowID id, const wxPoint &pos = wxDefaultPosition, const wxSize &size = wxDefaultSize, long style = 0, const wxString &name = "listctrl" ); - ~wxListMainWindow(void); + ~wxListMainWindow(); void RefreshLine( wxListLineData *line ); void OnPaint( wxPaintEvent &event ); void HilightAll( bool on ); - void ActivateLine( wxListLineData *line ); void SendNotify( wxListLineData *line, wxEventType command ); void FocusLine( wxListLineData *line ); void UnfocusLine( wxListLineData *line ); void SelectLine( wxListLineData *line ); void DeselectLine( wxListLineData *line ); void DeleteLine( wxListLineData *line ); - void RenameLine( wxListLineData *line, const wxString &newName ); - void StartLabelEdit( wxListLineData *line ); - void OnRenameTimer(void); - void OnRenameAccept(void); + + void EditLabel( long item ); + void Edit( long item ) { EditLabel(item); } // deprecated + void OnRenameTimer(); + void OnRenameAccept(); + void OnMouse( wxMouseEvent &event ); - void MoveToFocus( void ); + void MoveToFocus(); void OnArrowChar( wxListLineData *newCurrent, bool shiftDown ); void OnChar( wxKeyEvent &event ); + void OnKeyDown( wxKeyEvent &event ); void OnSetFocus( wxFocusEvent &event ); void OnKillFocus( wxFocusEvent &event ); void OnSize( wxSizeEvent &event ); - wxFont *GetMyFont( void ); - void DrawImage( int index, wxPaintDC *dc, int x, int y ); + + void DrawImage( int index, wxDC *dc, int x, int y ); void GetImageSize( int index, int &width, int &height ); int GetIndexOfLine( const wxListLineData *line ); int GetTextLength( wxString &s ); // should be const @@ -487,35 +461,34 @@ class wxListMainWindow: public wxScrolledWindow void SetColumnWidth( int col, int width ); void GetColumn( int col, wxListItem &item ); int GetColumnWidth( int vol ); - int GetColumnCount( void ); - int GetCountPerPage( void ); + int GetColumnCount(); + int GetCountPerPage(); void SetItem( wxListItem &item ); void GetItem( wxListItem &item ); void SetItemState( long item, long state, long stateMask ); int GetItemState( long item, long stateMask ); - int GetItemCount( void ); - void GetItemRect( long index, wxRectangle &rect ); - bool GetItemPosition(long item, wxPoint& pos); - int GetSelectedItemCount( void ); + int GetItemCount(); + void GetItemRect( long index, wxRect &rect ); + bool GetItemPosition( long item, wxPoint& pos ); + int GetSelectedItemCount(); void SetMode( long mode ); - long GetMode( void ) const; - void CalculatePositions( void ); - void RealizeChanges(void); + long GetMode() const; + void CalculatePositions(); + void RealizeChanges(); long GetNextItem( long item, int geometry, int state ); void DeleteItem( long index ); - void DeleteAllItems( void ); + void DeleteAllItems(); void DeleteColumn( int col ); - void DeleteEverything( void ); + void DeleteEverything(); void EnsureVisible( long index ); - long FindItem(long start, const wxString& str, bool partial = FALSE ); - long FindItem(long start, long data); + long FindItem( long start, const wxString& str, bool partial = FALSE ); + long FindItem( long start, long data); long HitTest( int x, int y, int &flags ); void InsertItem( wxListItem &item ); // void AddItem( wxListItem &item ); void InsertColumn( long col, wxListItem &item ); // void AddColumn( wxListItem &item ); void SortItems( wxListCtrlCompare fn, long data ); - virtual bool OnListNotify( wxListEvent &event ); DECLARE_EVENT_TABLE() }; @@ -524,98 +497,111 @@ class wxListMainWindow: public wxScrolledWindow // wxListCtrl //----------------------------------------------------------------------------- -class wxListCtrl: public wxControl +class WXDLLEXPORT wxListCtrl: public wxControl { DECLARE_DYNAMIC_CLASS(wxListCtrl); public: - - wxListCtrl(void); - wxListCtrl( wxWindow *parent, wxWindowID id, + wxListCtrl(); + wxListCtrl( wxWindow *parent, wxWindowID id = -1, const wxPoint &pos = wxDefaultPosition, const wxSize &size = wxDefaultSize, - long style = 0, const wxString &name = "listctrl" ); - ~wxListCtrl(void); - bool Create( wxWindow *parent, wxWindowID id, + long style = wxLC_ICON, const wxValidator& validator = wxDefaultValidator, + const wxString &name = "listctrl" ) + { + Create(parent, id, pos, size, style, validator, name); + } + ~wxListCtrl(); + bool Create( wxWindow *parent, wxWindowID id = -1, const wxPoint &pos = wxDefaultPosition, const wxSize &size = wxDefaultSize, - long style = 0, const wxString &name = "listctrl" ); + long style = wxLC_ICON, const wxValidator& validator = wxDefaultValidator, + const wxString &name = "listctrl" ); void OnSize( wxSizeEvent &event ); - bool GetColumn( int col, wxListItem& item ); + bool GetColumn( int col, wxListItem& item ) const; bool SetColumn( int col, wxListItem& item ); - int GetColumnWidth( int col ); + int GetColumnWidth( int col ) const; bool SetColumnWidth( int col, int width); - int GetCountPerPage(void); // not the same in wxGLC as in Windows, I think -// wxText& GetEditControl(void) const; // not supported in wxGLC - bool GetItem( wxListItem& info ); + int GetCountPerPage() const; // not the same in wxGLC as in Windows, I think + bool GetItem( wxListItem& info ) const; bool SetItem( wxListItem& info ) ; long SetItem( long index, int col, const wxString& label, int imageId = -1 ); - int GetItemState( long item, long stateMask ); + int GetItemState( long item, long stateMask ) const; bool SetItemState( long item, long state, long stateMask); bool SetItemImage( long item, int image, int selImage); - wxString GetItemText( long item ); + wxString GetItemText( long item ) const; void SetItemText( long item, const wxString& str ); - long GetItemData( long item ); + long GetItemData( long item ) const; bool SetItemData( long item, long data ); - bool GetItemRect( long item, wxRectangle& rect, int code = wxLIST_RECT_BOUNDS ); - bool GetItemPosition( long item, wxPoint& pos ); + bool GetItemRect( long item, wxRect& rect, int code = wxLIST_RECT_BOUNDS ) const; + bool GetItemPosition( long item, wxPoint& pos ) const; bool SetItemPosition( long item, const wxPoint& pos ); // not supported in wxGLC - int GetItemCount(void); + int GetItemCount() const; + int GetColumnCount() const; void SetItemSpacing( int spacing, bool isSmall = FALSE ); - int GetItemSpacing( bool isSmall ); - int GetSelectedItemCount(void); -// wxColour GetTextColour(void) const; // wxGLC has colours for every Item (see wxListItem) + int GetItemSpacing( bool isSmall ) const; + int GetSelectedItemCount() const; +// wxColour GetTextColour() const; // wxGLC has colours for every Item (see wxListItem) // void SetTextColour(const wxColour& col); - long GetTopItem(void); + long GetTopItem() const; void SetSingleStyle( long style, bool add = TRUE ) ; - void SetWindowStyleFlag(long style); - void RecreateWindow(void) {}; - long GetNextItem(long item, int geometry = wxLIST_NEXT_ALL, int state = wxLIST_STATE_DONTCARE) const; - wxImageList *GetImageList(int which); - void SetImageList(wxImageList *imageList, int which) ; + void SetWindowStyleFlag( long style ); + void RecreateWindow() {} + long GetNextItem( long item, int geometry = wxLIST_NEXT_ALL, int state = wxLIST_STATE_DONTCARE ) const; + wxImageList *GetImageList( int which ) const; + void SetImageList( wxImageList *imageList, int which ); bool Arrange( int flag = wxLIST_ALIGN_DEFAULT ); // always wxLIST_ALIGN_LEFT in wxGLC + + void ClearAll(); bool DeleteItem( long item ); - bool DeleteAllItems(void) ; + bool DeleteAllItems(); + bool DeleteAllColumns(); bool DeleteColumn( int col ); -// wxText& Edit(long item) ; // not supported in wxGLC + + void EditLabel( long item ) { Edit(item); } + void Edit( long item ); + bool EnsureVisible( long item ); - long FindItem(long start, const wxString& str, bool partial = FALSE ); - long FindItem(long start, long data); - long FindItem(long start, const wxPoint& pt, int direction); // not supported in wxGLC - long HitTest(const wxPoint& point, int& flags); + long FindItem( long start, const wxString& str, bool partial = FALSE ); + long FindItem( long start, long data ); + long FindItem( long start, const wxPoint& pt, int direction ); // not supported in wxGLC + long HitTest( const wxPoint& point, int& flags); long InsertItem(wxListItem& info); - long InsertItem(long index, const wxString& label); - long InsertItem(long index, int imageIndex); - long InsertItem(long index, const wxString& label, int imageIndex); - long InsertColumn(long col, wxListItem& info); - long InsertColumn(long col, const wxString& heading, int format = wxLIST_FORMAT_LEFT, - int width = -1); - bool ScrollList(int dx, int dy); - bool SortItems(wxListCtrlCompare fn, long data); - bool Update(long item); - virtual bool OnListNotify(wxListEvent& WXUNUSED(event)) { return FALSE; } + long InsertItem( long index, const wxString& label ); + long InsertItem( long index, int imageIndex ); + long InsertItem( long index, const wxString& label, int imageIndex ); + long InsertColumn( long col, wxListItem& info ); + long InsertColumn( long col, const wxString& heading, int format = wxLIST_FORMAT_LEFT, + int width = -1 ); + bool ScrollList( int dx, int dy ); + bool SortItems( wxListCtrlCompare fn, long data ); + bool Update( long item ); void OnIdle( wxIdleEvent &event ); // We have to hand down a few functions + bool SetBackgroundColour( const wxColour &colour ); + bool SetForegroundColour( const wxColour &colour ); + bool SetFont( const wxFont &font ); + +#if wxUSE_DRAG_AND_DROP void SetDropTarget( wxDropTarget *dropTarget ) { m_mainWin->SetDropTarget( dropTarget ); } wxDropTarget *GetDropTarget() const { return m_mainWin->GetDropTarget(); } - void SetCursor( const wxCursor &cursor ) - { m_mainWin->SetCursor( cursor); } +#endif + + bool SetCursor( const wxCursor &cursor ) + { return m_mainWin ? m_mainWin->wxWindow::SetCursor(cursor) : FALSE; } wxColour GetBackgroundColour() const - { return m_mainWin->GetBackgroundColour(); } - void SetBackgroundColour( const wxColour &colour ) - { m_mainWin->SetBackgroundColour( colour ); } + { return m_mainWin ? m_mainWin->GetBackgroundColour() : wxColour(); } wxColour GetForegroundColour() const - { return m_mainWin->GetForegroundColour(); } - void SetForegroundColour( const wxColour &colour ) - { m_mainWin->SetForegroundColour( colour ); } - bool PopupMenu( wxMenu *menu, int x, int y ) + { return m_mainWin ? m_mainWin->GetForegroundColour() : wxColour(); } + bool DoPopupMenu( wxMenu *menu, int x, int y ) { return m_mainWin->PopupMenu( menu, x, y ); } + void SetFocus() + { m_mainWin->SetFocus(); } - protected: - -// wxListTextCtrl m_textCtrl; + // implementation + wxImageList *m_imageListNormal; wxImageList *m_imageListSmall; wxImageList *m_imageListState; // what's that ?