X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/e487524e492809638b7e335937c41fd432458a54..306dfc2b3d49ca45445bdfb2164fe1eea45ab321:/include/wx/generic/listctrl.h diff --git a/include/wx/generic/listctrl.h b/include/wx/generic/listctrl.h index 96ac43a453..697ce88046 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,26 +25,30 @@ #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 WXDLLEXPORT wxListRenameTimer; //class wxListTextCtrl; //----------------------------------------------------------------------------- @@ -164,7 +168,7 @@ enum { // wxListItem //----------------------------------------------------------------------------- -class wxListItem: public wxObject +class WXDLLEXPORT wxListItem: public wxObject { DECLARE_DYNAMIC_CLASS(wxListItem) @@ -190,7 +194,7 @@ class wxListItem: public wxObject // wxListEvent //----------------------------------------------------------------------------- -class WXDLLEXPORT wxListEvent: public wxCommandEvent +class WXDLLEXPORT wxListEvent: public wxNotifyEvent { DECLARE_DYNAMIC_CLASS(wxListEvent) @@ -222,13 +226,15 @@ typedef void (wxEvtHandler::*wxListEventFunction)(wxListEvent&); #define EVT_LIST_KEY_DOWN(id, fn) { wxEVT_COMMAND_LIST_KEY_DOWN, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxListEventFunction) & fn, (wxObject *) NULL }, #define EVT_LIST_INSERT_ITEM(id, fn) { wxEVT_COMMAND_LIST_INSERT_ITEM, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxListEventFunction) & fn, (wxObject *) NULL }, #define EVT_LIST_COL_CLICK(id, fn) { wxEVT_COMMAND_LIST_COL_CLICK, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxListEventFunction) & fn, (wxObject *) NULL }, - +#define EVT_LIST_ITEM_RIGHT_CLICK(id, fn) { wxEVT_COMMAND_LIST_ITEM_RIGHT_CLICK, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxListEventFunction) & fn, (wxObject *) NULL }, +#define EVT_LIST_ITEM_MIDDLE_CLICK(id, fn) { wxEVT_COMMAND_LIST_ITEM_MIDDLE_CLICK, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxListEventFunction) & fn, (wxObject *) NULL }, +#define EVT_LIST_ITEM_ACTIVATED(id, fn) { wxEVT_COMMAND_LIST_ITEM_ACTIVATED, id, -1, (wxObjectEventFunction) (wxEventFunction) (wxListEventFunction) & fn, (wxObject *) NULL }, //----------------------------------------------------------------------------- // wxListItemData (internal) //----------------------------------------------------------------------------- -class wxListItemData : public wxObject +class WXDLLEXPORT wxListItemData : public wxObject { DECLARE_DYNAMIC_CLASS(wxListItemData); @@ -267,7 +273,7 @@ class wxListItemData : public wxObject // wxListHeaderData (internal) //----------------------------------------------------------------------------- -class wxListHeaderData : public wxObject +class WXDLLEXPORT wxListHeaderData : public wxObject { DECLARE_DYNAMIC_CLASS(wxListHeaderData); @@ -302,29 +308,29 @@ class wxListHeaderData : public wxObject // wxListLineData (internal) //----------------------------------------------------------------------------- -class wxListLineData : public wxObject +class WXDLLEXPORT wxListLineData : public wxObject { DECLARE_DYNAMIC_CLASS(wxListLineData); 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 +342,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) @@ -370,7 +376,7 @@ class wxListHeaderWindow : public wxWindow 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 ); @@ -383,7 +389,7 @@ class wxListHeaderWindow : public wxWindow // wxListRenameTimer (internal) //----------------------------------------------------------------------------- -class wxListRenameTimer: public wxTimer +class WXDLLEXPORT wxListRenameTimer: public wxTimer { private: wxListMainWindow *m_owner; @@ -397,7 +403,7 @@ class wxListRenameTimer: public wxTimer // wxListTextCtrl (internal) //----------------------------------------------------------------------------- -class wxListTextCtrl: public wxTextCtrl +class WXDLLEXPORT wxListTextCtrl: public wxTextCtrl { DECLARE_DYNAMIC_CLASS(wxListTextCtrl); @@ -424,7 +430,7 @@ class wxListTextCtrl: public wxTextCtrl // wxListMainWindow (internal) //----------------------------------------------------------------------------- -class wxListMainWindow: public wxScrolledWindow +class WXDLLEXPORT wxListMainWindow: public wxScrolledWindow { DECLARE_DYNAMIC_CLASS(wxListMainWindow); @@ -461,7 +467,6 @@ class wxListMainWindow: public wxScrolledWindow 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 ); @@ -479,7 +484,7 @@ class wxListMainWindow: public wxScrolledWindow void OnSetFocus( wxFocusEvent &event ); void OnKillFocus( wxFocusEvent &event ); void OnSize( wxSizeEvent &event ); - 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 @@ -498,7 +503,7 @@ class wxListMainWindow: public wxScrolledWindow void SetItemState( long item, long state, long stateMask ); int GetItemState( long item, long stateMask ); int GetItemCount( void ); - void GetItemRect( long index, wxRectangle &rect ); + void GetItemRect( long index, wxRect &rect ); bool GetItemPosition(long item, wxPoint& pos); int GetSelectedItemCount( void ); void SetMode( long mode ); @@ -519,7 +524,6 @@ class wxListMainWindow: public wxScrolledWindow void InsertColumn( long col, wxListItem &item ); // void AddColumn( wxListItem &item ); void SortItems( wxListCtrlCompare fn, long data ); - virtual bool OnListNotify( wxListEvent &event ); DECLARE_EVENT_TABLE() }; @@ -528,7 +532,7 @@ class wxListMainWindow: public wxScrolledWindow // wxListCtrl //----------------------------------------------------------------------------- -class wxListCtrl: public wxControl +class WXDLLEXPORT wxListCtrl: public wxControl { DECLARE_DYNAMIC_CLASS(wxListCtrl); @@ -564,10 +568,11 @@ class wxListCtrl: public wxControl void SetItemText( long item, const wxString& str ); long GetItemData( long item ) const; bool SetItemData( long item, long data ); - bool GetItemRect( long item, wxRectangle& rect, int code = wxLIST_RECT_BOUNDS ) const; + 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) const; + int GetColumnCount(void) const; void SetItemSpacing( int spacing, bool isSmall = FALSE ); int GetItemSpacing( bool isSmall ) const; int GetSelectedItemCount(void) const; @@ -581,9 +586,10 @@ class wxListCtrl: public wxControl 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) ; - void DeleteAllColumns(void) ; + bool DeleteAllItems(void); + bool DeleteAllColumns(void); bool DeleteColumn( int col ); // wxText& Edit(long item) ; // not supported in wxGLC bool EnsureVisible( long item ); @@ -601,7 +607,6 @@ class wxListCtrl: public wxControl bool ScrollList(int dx, int dy); bool SortItems(wxListCtrlCompare fn, long data); bool Update(long item); - virtual bool OnListNotify(wxListEvent& WXUNUSED(event)) { return FALSE; } void OnIdle( wxIdleEvent &event ); // We have to hand down a few functions @@ -610,10 +615,13 @@ class wxListCtrl: public wxControl void SetForegroundColour( const wxColour &colour ); void SetFont( const wxFont &font ); +#if wxUSE_DRAG_AND_DROP void SetDropTarget( wxDropTarget *dropTarget ) { m_mainWin->SetDropTarget( dropTarget ); } wxDropTarget *GetDropTarget() const { return m_mainWin->GetDropTarget(); } +#endif + void SetCursor( const wxCursor &cursor ) { if (m_mainWin) m_mainWin->wxWindow::SetCursor( cursor); } wxColour GetBackgroundColour() const @@ -624,6 +632,8 @@ class wxListCtrl: public wxControl else return wxColour(); } bool PopupMenu( wxMenu *menu, int x, int y ) { return m_mainWin->PopupMenu( menu, x, y ); } + void SetFocus() + { m_mainWin->SetFocus(); } // implementation