X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/ef4279890a78cdc9f0f1b8f578ff0e573f922af3..fe5f448f431631c6963e52926e24dfe2901fa71a:/include/wx/dataview.h diff --git a/include/wx/dataview.h b/include/wx/dataview.h index 106829907a..1c5f4d0b97 100644 --- a/include/wx/dataview.h +++ b/include/wx/dataview.h @@ -104,7 +104,8 @@ public: const wxDataViewItem &item, unsigned int col ) = 0; // define hierachy - virtual bool HasChildren( const wxDataViewItem &item ) const = 0; + virtual wxDataViewItem GetParent( const wxDataViewItem &item ) const = 0; + virtual bool IsContainer( const wxDataViewItem &item ) const = 0; virtual wxDataViewItem GetFirstChild( const wxDataViewItem &parent ) const = 0; virtual wxDataViewItem GetNextSibling( const wxDataViewItem &item ) const = 0; @@ -126,7 +127,7 @@ public: void SetSortingColumn( unsigned int col ) { m_sortingColumn = col; } unsigned int GetSortingColumn() { return m_sortingColumn; } - void SetSortOrderAscending( bool ascending ) { m_ascending = true; } + void SetSortOrderAscending( bool ascending ) { m_ascending = ascending; } bool GetSortOrderAscending() { return m_ascending; } @@ -140,13 +141,16 @@ protected: }; // --------------------------------------------------------- -// wxDataViewVirtualListModel +// wxDataViewIndexListModel // --------------------------------------------------------- +// use hash map later +WX_DEFINE_ARRAY_PTR( void*, wxDataViewItemHash ); + class wxDataViewIndexListModel: public wxDataViewModel { public: - wxDataViewIndexListModel(); + wxDataViewIndexListModel( unsigned int initial_size = 0 ); ~wxDataViewIndexListModel(); virtual unsigned int GetRowCount() = 0; @@ -157,16 +161,36 @@ public: virtual bool SetValue( const wxVariant &variant, unsigned int row, unsigned int col ) = 0; - void ItemPrepended(); - void ItemInserted( unsigned int before ); - void ItemAppended(); - void ItemChanged( unsigned int row ); - void ValueChanged( unsigned int row, unsigned int col ); + void RowPrepended(); + void RowInserted( unsigned int before ); + void RowAppended(); + void RowDeleted( unsigned int row ); + void RowChanged( unsigned int row ); + void RowValueChanged( unsigned int row, unsigned int col ); + + // convert to/from row/wxDataViewItem - wxDataViewItem GetItem( unsigned int row ); + unsigned int GetRow( const wxDataViewItem &item ) const; + wxDataViewItem GetItem( unsigned int row ) const; + + // compare based on index virtual int Compare( const wxDataViewItem &item1, const wxDataViewItem &item2 ); + + // implement base methods + + virtual void GetValue( wxVariant &variant, + const wxDataViewItem &item, unsigned int col ) const; + virtual bool SetValue( const wxVariant &variant, + const wxDataViewItem &item, unsigned int col ); + virtual wxDataViewItem GetParent( const wxDataViewItem &item ) const; + virtual bool IsContainer( const wxDataViewItem &item ) const; + virtual wxDataViewItem GetFirstChild( const wxDataViewItem &parent ) const; + virtual wxDataViewItem GetNextSibling( const wxDataViewItem &item ) const; +private: + wxDataViewItemHash m_hash; + unsigned int m_lastIndex; }; // --------------------------------------------------------- @@ -552,7 +576,7 @@ typedef void (wxEvtHandler::*wxDataViewEventFunction)(wxDataViewEvent&); #define EVT_DATAVIEW_COLUMN_HEADER_RIGHT_CLICKED(id, fn) wx__DECLARE_DATAVIEWEVT(COLUMN_HEADER_RIGHT_CLICK, id, fn) #define EVT_DATAVIEW_COLUMN_SORTED(id, fn) wx__DECLARE_DATAVIEWEVT(COLUMN_SORTED, id, fn) -#define EVT_DATAVIEW_MODEL_ITEM_ADDED(id, fn) wx__DECLARE_DATAVIEWEVT(MODEL_ITEM_APPENDED, id, fn) +#define EVT_DATAVIEW_MODEL_ITEM_ADDED(id, fn) wx__DECLARE_DATAVIEWEVT(MODEL_ITEM_ADDED, id, fn) #define EVT_DATAVIEW_MODEL_ITEM_DELETED(id, fn) wx__DECLARE_DATAVIEWEVT(MODEL_ITEM_DELETED, id, fn) #define EVT_DATAVIEW_MODEL_ITEM_CHANGED(id, fn) wx__DECLARE_DATAVIEWEVT(MODEL_ITEM_CHANGED, id, fn) #define EVT_DATAVIEW_MODEL_VALUE_CHANGED(id, fn) wx__DECLARE_DATAVIEWEVT(MODEL_VALUE_CHANGED, id, fn)