X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/03966fcb3f5aeea7d8e6652d40e6804811a785d8..ca91e1eb7f90cbb0d65b2690bda4fe1ae3c3872f:/src/common/treebase.cpp diff --git a/src/common/treebase.cpp b/src/common/treebase.cpp index 548b01fb76..bea5d72e35 100644 --- a/src/common/treebase.cpp +++ b/src/common/treebase.cpp @@ -59,8 +59,7 @@ DEFINE_EVENT_TYPE(wxEVT_COMMAND_TREE_ITEM_MENU) // Tree event // ---------------------------------------------------------------------------- -IMPLEMENT_ABSTRACT_CLASS(wxTreeEvent, wxNotifyEvent) - +IMPLEMENT_DYNAMIC_CLASS(wxTreeEvent, wxNotifyEvent) wxTreeEvent::wxTreeEvent(wxEventType commandType, wxTreeCtrlBase *tree, @@ -110,13 +109,19 @@ void wxTreeCtrlBase::SetItemState(const wxTreeItemId& item, int state) { if ( state == wxTREE_ITEMSTATE_NEXT ) { - state = GetItemState(item) + 1; + int current = GetItemState(item); + if ( current == wxTREE_ITEMSTATE_NONE ) + return; + state = current + 1; if ( m_imageListState && state >= m_imageListState->GetImageCount() ) state = 0; } else if ( state == wxTREE_ITEMSTATE_PREV ) { - state = GetItemState(item) - 1; + int current = GetItemState(item); + if ( current == wxTREE_ITEMSTATE_NONE ) + return; + state = current - 1; if ( state == -1 ) state = m_imageListState ? m_imageListState->GetImageCount() - 1 : 0; }