Store pointers in wxDataViewItem in the sample, no any artifical int ID
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@47494 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -65,22 +65,20 @@ WX_DEFINE_ARRAY_PTR( MyMusicModelNode*, MyMusicModelNodes );
|
|||||||
class MyMusicModelNode
|
class MyMusicModelNode
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
MyMusicModelNode( MyMusicModelNode* parent, const wxUint32 id,
|
MyMusicModelNode( MyMusicModelNode* parent,
|
||||||
const wxString &title, const wxString &artist, const wxString &year )
|
const wxString &title, const wxString &artist, const wxString &year )
|
||||||
{
|
{
|
||||||
m_parent = parent;
|
m_parent = parent;
|
||||||
m_id = id;
|
|
||||||
m_title = title;
|
m_title = title;
|
||||||
m_artist = artist;
|
m_artist = artist;
|
||||||
m_year = year;
|
m_year = year;
|
||||||
m_isContainer = false;
|
m_isContainer = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
MyMusicModelNode( MyMusicModelNode* parent, const wxUint32 id,
|
MyMusicModelNode( MyMusicModelNode* parent,
|
||||||
const wxString &branch )
|
const wxString &branch )
|
||||||
{
|
{
|
||||||
m_parent = parent;
|
m_parent = parent;
|
||||||
m_id = id;
|
|
||||||
m_title = branch;
|
m_title = branch;
|
||||||
m_isContainer = true;
|
m_isContainer = true;
|
||||||
}
|
}
|
||||||
@@ -96,7 +94,6 @@ public:
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
wxUint32 GetID() { return m_id; }
|
|
||||||
bool IsContainer() { return m_isContainer; }
|
bool IsContainer() { return m_isContainer; }
|
||||||
|
|
||||||
MyMusicModelNode* GetParent() { return m_parent; }
|
MyMusicModelNode* GetParent() { return m_parent; }
|
||||||
@@ -114,7 +111,6 @@ public:
|
|||||||
private:
|
private:
|
||||||
MyMusicModelNode *m_parent;
|
MyMusicModelNode *m_parent;
|
||||||
MyMusicModelNodes m_children;
|
MyMusicModelNodes m_children;
|
||||||
wxUint32 m_id;
|
|
||||||
bool m_isContainer;
|
bool m_isContainer;
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -127,19 +123,18 @@ public:
|
|||||||
|
|
||||||
MyMusicModel()
|
MyMusicModel()
|
||||||
{
|
{
|
||||||
m_idCounter = 0;
|
m_root = new MyMusicModelNode( NULL, "My Music" );
|
||||||
m_root = new MyMusicModelNode( NULL, GetNewId(), "My Music" );
|
m_pop = new MyMusicModelNode( m_root, "Pop music" );
|
||||||
m_pop = new MyMusicModelNode( m_root, GetNewId(), "Pop music" );
|
|
||||||
m_root->Append( m_pop );
|
m_root->Append( m_pop );
|
||||||
m_pop->Append( new MyMusicModelNode( m_pop, GetNewId(),
|
m_pop->Append( new MyMusicModelNode( m_pop,
|
||||||
"You are not alone", "Michael Jackson", "1995" ) );
|
"You are not alone", "Michael Jackson", "1995" ) );
|
||||||
m_pop->Append( new MyMusicModelNode( m_pop, GetNewId(),
|
m_pop->Append( new MyMusicModelNode( m_pop,
|
||||||
"Take a bow", "Madonna", "1994" ) );
|
"Take a bow", "Madonna", "1994" ) );
|
||||||
m_classical = new MyMusicModelNode( m_root, GetNewId(), "Classical music" );
|
m_classical = new MyMusicModelNode( m_root, "Classical music" );
|
||||||
m_root->Append( m_classical );
|
m_root->Append( m_classical );
|
||||||
m_classical->Append( new MyMusicModelNode( m_classical, GetNewId(),
|
m_classical->Append( new MyMusicModelNode( m_classical,
|
||||||
"Ninth symphony", "Ludwig van Beethoven", "1824" ) );
|
"Ninth symphony", "Ludwig van Beethoven", "1824" ) );
|
||||||
m_classical->Append( new MyMusicModelNode( m_classical, GetNewId(),
|
m_classical->Append( new MyMusicModelNode( m_classical,
|
||||||
"German Requiem", "Johannes Brahms", "1868" ) );
|
"German Requiem", "Johannes Brahms", "1868" ) );
|
||||||
m_classicalMusicIsKnownToControl = false;
|
m_classicalMusicIsKnownToControl = false;
|
||||||
}
|
}
|
||||||
@@ -150,21 +145,21 @@ public:
|
|||||||
{
|
{
|
||||||
// add to data
|
// add to data
|
||||||
MyMusicModelNode *child_node =
|
MyMusicModelNode *child_node =
|
||||||
new MyMusicModelNode( m_classical, GetNewId(), title, artist, year );
|
new MyMusicModelNode( m_classical, title, artist, year );
|
||||||
m_classical->Append( child_node );
|
m_classical->Append( child_node );
|
||||||
|
|
||||||
if (m_classicalMusicIsKnownToControl)
|
if (m_classicalMusicIsKnownToControl)
|
||||||
{
|
{
|
||||||
// notify control
|
// notify control
|
||||||
wxDataViewItem child( (void*) child_node->GetID() );
|
wxDataViewItem child( (void*) child_node );
|
||||||
wxDataViewItem parent( (void*) m_classical->GetID() );
|
wxDataViewItem parent( (void*) m_classical );
|
||||||
ItemAdded( parent, child );
|
ItemAdded( parent, child );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Delete( const wxDataViewItem &item )
|
void Delete( const wxDataViewItem &item )
|
||||||
{
|
{
|
||||||
MyMusicModelNode *node = FindNode( item );
|
MyMusicModelNode *node = (MyMusicModelNode*) item.GetID();
|
||||||
node->GetParent()->GetChildren().Remove( node );
|
node->GetParent()->GetChildren().Remove( node );
|
||||||
delete node;
|
delete node;
|
||||||
|
|
||||||
@@ -187,7 +182,7 @@ public:
|
|||||||
virtual void GetValue( wxVariant &variant,
|
virtual void GetValue( wxVariant &variant,
|
||||||
const wxDataViewItem &item, unsigned int col ) const
|
const wxDataViewItem &item, unsigned int col ) const
|
||||||
{
|
{
|
||||||
MyMusicModelNode *node = FindNode( item );
|
MyMusicModelNode *node = (MyMusicModelNode*) item.GetID();
|
||||||
switch (col)
|
switch (col)
|
||||||
{
|
{
|
||||||
case 0: variant = node->m_title; break;
|
case 0: variant = node->m_title; break;
|
||||||
@@ -200,7 +195,7 @@ public:
|
|||||||
virtual bool SetValue( const wxVariant &variant,
|
virtual bool SetValue( const wxVariant &variant,
|
||||||
const wxDataViewItem &item, unsigned int col )
|
const wxDataViewItem &item, unsigned int col )
|
||||||
{
|
{
|
||||||
MyMusicModelNode *node = FindNode( item );
|
MyMusicModelNode *node = (MyMusicModelNode*) item.GetID();
|
||||||
switch (col)
|
switch (col)
|
||||||
{
|
{
|
||||||
case 0: node->m_title = variant.GetString(); break;
|
case 0: node->m_title = variant.GetString(); break;
|
||||||
@@ -212,19 +207,18 @@ public:
|
|||||||
|
|
||||||
virtual bool HasChildren( const wxDataViewItem &item ) const
|
virtual bool HasChildren( const wxDataViewItem &item ) const
|
||||||
{
|
{
|
||||||
if (item.GetID() == 0)
|
MyMusicModelNode *node = (MyMusicModelNode*) item.GetID();
|
||||||
|
if (!node)
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
MyMusicModelNode *node = FindNode( item );
|
|
||||||
return node->IsContainer();
|
return node->IsContainer();
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual wxDataViewItem GetFirstChild( const wxDataViewItem &parent ) const
|
virtual wxDataViewItem GetFirstChild( const wxDataViewItem &parent ) const
|
||||||
{
|
{
|
||||||
if (parent.GetID() == 0)
|
MyMusicModelNode *node = (MyMusicModelNode*) parent.GetID();
|
||||||
return wxDataViewItem( (void*) m_root->GetID() );
|
if (!node)
|
||||||
|
return wxDataViewItem( (void*) m_root );
|
||||||
MyMusicModelNode *node = FindNode( parent );
|
|
||||||
|
|
||||||
if (node->GetChildCount() == 0)
|
if (node->GetChildCount() == 0)
|
||||||
return wxDataViewItem( 0 );
|
return wxDataViewItem( 0 );
|
||||||
@@ -236,12 +230,12 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
MyMusicModelNode *first_child = node->GetChildren().Item( 0 );
|
MyMusicModelNode *first_child = node->GetChildren().Item( 0 );
|
||||||
return wxDataViewItem( (void*) first_child->GetID() );
|
return wxDataViewItem( (void*) first_child );
|
||||||
}
|
}
|
||||||
|
|
||||||
virtual wxDataViewItem GetNextSibling( const wxDataViewItem &item ) const
|
virtual wxDataViewItem GetNextSibling( const wxDataViewItem &item ) const
|
||||||
{
|
{
|
||||||
MyMusicModelNode *node = FindNode( item );
|
MyMusicModelNode *node = (MyMusicModelNode*) item.GetID();
|
||||||
MyMusicModelNode *parent = node->GetParent();
|
MyMusicModelNode *parent = node->GetParent();
|
||||||
if (!parent)
|
if (!parent)
|
||||||
return wxDataViewItem(0);
|
return wxDataViewItem(0);
|
||||||
@@ -254,45 +248,14 @@ public:
|
|||||||
return wxDataViewItem(0);
|
return wxDataViewItem(0);
|
||||||
|
|
||||||
node = parent->GetChildren().Item( pos+1 );
|
node = parent->GetChildren().Item( pos+1 );
|
||||||
return wxDataViewItem( (void*) node->GetID() );
|
return wxDataViewItem( (void*) node );
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
wxUint32 GetNewId() { m_idCounter++; return m_idCounter; }
|
|
||||||
|
|
||||||
MyMusicModelNode *FindNodeRec( MyMusicModelNode *node, const wxDataViewItem &item ) const
|
|
||||||
{
|
|
||||||
if (node->GetID() == (wxUint32) item.GetID())
|
|
||||||
return node;
|
|
||||||
|
|
||||||
size_t count = node->GetChildCount();
|
|
||||||
size_t i;
|
|
||||||
for (i = 0; i < count; i++)
|
|
||||||
{
|
|
||||||
MyMusicModelNode *child = node->GetChildren().Item( i );
|
|
||||||
MyMusicModelNode *node2 = FindNodeRec( child, item );
|
|
||||||
if (node2)
|
|
||||||
return node2;
|
|
||||||
}
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
MyMusicModelNode *FindNode( const wxDataViewItem &item ) const
|
|
||||||
{
|
|
||||||
if (item.GetID() == 0)
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
if (!m_root)
|
|
||||||
return NULL;
|
|
||||||
|
|
||||||
return FindNodeRec( m_root, item );
|
|
||||||
}
|
|
||||||
|
|
||||||
MyMusicModelNode* m_root;
|
MyMusicModelNode* m_root;
|
||||||
MyMusicModelNode* m_pop;
|
MyMusicModelNode* m_pop;
|
||||||
MyMusicModelNode* m_classical;
|
MyMusicModelNode* m_classical;
|
||||||
bool m_classicalMusicIsKnownToControl;
|
bool m_classicalMusicIsKnownToControl;
|
||||||
wxUint32 m_idCounter;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
// -------------------------------------
|
// -------------------------------------
|
||||||
|
Reference in New Issue
Block a user