sorting support for generic version (patch 1765087 from Bo)

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@47863 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin
2007-08-03 11:47:42 +00:00
parent 2a225ba641
commit d3f00f5993
4 changed files with 58 additions and 6 deletions

View File

@@ -97,7 +97,7 @@ public:
virtual bool ValueChanged( const wxDataViewItem &item, unsigned int col ) = 0;
virtual bool Cleared() = 0;
virtual void Resort() { }
virtual void Resort() = 0;
void SetOwner( wxDataViewModel *owner ) { m_owner = owner; }
wxDataViewModel *GetOwner() { return m_owner; }

View File

@@ -161,11 +161,11 @@ public:
{
MyMusicModelNode *node = (MyMusicModelNode*) item.GetID();
wxDataViewItem parent( node->GetParent() );
node->GetParent()->GetChildren().Remove( node );
delete node;
// notify control
ItemDeleted( parent, item );
node->GetParent()->GetChildren().Remove( node );
delete node;
}
// override sorting to always sort branches ascendingly

View File

@@ -246,8 +246,8 @@ void wxDataViewIndexListModel::RowAppended()
void wxDataViewIndexListModel::RowDeleted( unsigned int row )
{
wxDataViewItem item( m_hash[row] );
m_hash.RemoveAt( row );
wxDataViewModel::ItemDeleted( wxDataViewItem(0), item );
m_hash.RemoveAt( row );
}
void wxDataViewIndexListModel::RowChanged( unsigned int row )

View File

@@ -347,6 +347,30 @@ public:
parent->ChangeSubTreeCount(num);
}
void Resort()
{
wxDataViewTreeNodes nds = nodes;
wxDataViewTreeLeaves lvs = leaves;
nodes.Empty();
leaves.Empty();
int len = nds.GetCount();
if(len > 0)
{
for(int i = 0; i < len; i ++)
nodes.Add(nds[i]);
for(int i = 0; i < len; i ++)
nodes[i]->Resort();
}
len = lvs.GetCount();
if(len > 0)
{
for(int i = 0; i < len; i++)
leaves.Add(lvs[i]);
}
}
private:
wxDataViewTreeNode * parent;
wxDataViewTreeNodes nodes;
@@ -398,6 +422,8 @@ public:
bool ItemChanged( const wxDataViewItem &item );
bool ValueChanged( const wxDataViewItem &item, unsigned int col );
bool Cleared();
void Resort()
{ g_model = GetOwner()->GetModel(); m_root->Resort(); UpdateDisplay(); }
void SetOwner( wxDataViewCtrl* owner ) { m_owner = owner; }
wxDataViewCtrl *GetOwner() { return m_owner; }
@@ -528,6 +554,8 @@ public:
{ return m_mainWindow->ValueChanged( item, col ); }
virtual bool Cleared()
{ return m_mainWindow->Cleared(); }
virtual void Resort()
{ return m_mainWindow->Resort(); }
wxDataViewMainWindow *m_mainWindow;
};
@@ -1149,6 +1177,7 @@ void wxDataViewHeaderWindowMSW::UpdateDisplay()
// add the updated array of columns to the header control
unsigned int cols = GetOwner()->GetColumnCount();
unsigned int added = 0;
wxDataViewModel * model = GetOwner()->GetModel();
for (unsigned int i = 0; i < cols; i++)
{
wxDataViewColumn *col = GetColumn( i );
@@ -1282,6 +1311,30 @@ bool wxDataViewHeaderWindowMSW::MSWOnNotify(int idCtrl, WXLPARAM lParam, WXLPARA
case HDN_ITEMCLICK:
{
unsigned int idx = GetColumnIdxFromHeader(nmHDR);
wxDataViewModel * model = GetOwner()->GetModel();
if(nmHDR->iButton == 0)
{
wxDataViewColumn *col = GetColumn(idx);
if(col->IsSortable())
{
if(model && model->GetSortingColumn() == idx)
{
bool order = col->IsSortOrderAscending();
col->SetSortOrder(!order);
model->SetSortOrderAscending(!order);
}
else if(model)
{
model->SetSortingColumn(idx);
model->SetSortOrderAscending(true);
}
}
UpdateDisplay();
if(model)
model->Resort();
}
wxEventType evt = nmHDR->iButton == 0 ?
wxEVT_COMMAND_DATAVIEW_COLUMN_HEADER_CLICK :
wxEVT_COMMAND_DATAVIEW_COLUMN_HEADER_RIGHT_CLICK;
@@ -1923,8 +1976,7 @@ bool wxDataViewMainWindow::ItemDeleted(const wxDataViewItem& parent,
g_model = GetOwner()->GetModel();
wxDataViewTreeNode * node;
wxDataViewItem parent_item = g_model->GetParent( item );
node = FindNode(parent_item);
node = FindNode(parent);
if( node == NULL || node->GetChildren().Index( item.GetID() ) == wxNOT_FOUND )
{