Move event generation code for multiple selection mode to common code
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@53715 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -97,9 +97,6 @@ public:
|
|||||||
|
|
||||||
void GtkDisableEvents();
|
void GtkDisableEvents();
|
||||||
void GtkEnableEvents();
|
void GtkEnableEvents();
|
||||||
|
|
||||||
wxArrayInt m_oldSelection;
|
|
||||||
void GtkUpdateOldSelection();
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual void DoClear();
|
virtual void DoClear();
|
||||||
|
@@ -94,6 +94,11 @@ public:
|
|||||||
// returns the item number at a point or wxNOT_FOUND
|
// returns the item number at a point or wxNOT_FOUND
|
||||||
int HitTest(const wxPoint& point) const { return DoListHitTest(point); }
|
int HitTest(const wxPoint& point) const { return DoListHitTest(point); }
|
||||||
|
|
||||||
|
// For generating events in multiple and extended mode
|
||||||
|
wxArrayInt m_oldSelections;
|
||||||
|
void UpdateOldSelections();
|
||||||
|
void CalcAndSendEvent();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual void DoSetFirstItem(int n) = 0;
|
virtual void DoSetFirstItem(int n) = 0;
|
||||||
|
|
||||||
|
@@ -82,6 +82,112 @@ void wxListBoxBase::DeselectAll(int itemToLeaveSelected)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void wxListBoxBase::UpdateOldSelections()
|
||||||
|
{
|
||||||
|
if (HasFlag(wxLB_MULTIPLE) || HasFlag(wxLB_EXTENDED))
|
||||||
|
GetSelections( m_oldSelections );
|
||||||
|
}
|
||||||
|
|
||||||
|
static void LBSendEvent( wxCommandEvent &event, wxListBoxBase *listbox, int item )
|
||||||
|
{
|
||||||
|
event.SetInt( item );
|
||||||
|
event.SetString( listbox->GetString( item ) );
|
||||||
|
if ( listbox->HasClientObjectData() )
|
||||||
|
event.SetClientObject( listbox->GetClientObject(item) );
|
||||||
|
else if ( listbox->HasClientUntypedData() )
|
||||||
|
event.SetClientData( listbox->GetClientData(item) );
|
||||||
|
listbox->HandleWindowEvent( event );
|
||||||
|
}
|
||||||
|
|
||||||
|
void wxListBoxBase::CalcAndSendEvent()
|
||||||
|
{
|
||||||
|
wxCommandEvent event(wxEVT_COMMAND_LISTBOX_SELECTED, GetId() );
|
||||||
|
event.SetEventObject( this );
|
||||||
|
|
||||||
|
wxArrayInt selections;
|
||||||
|
GetSelections( selections );
|
||||||
|
|
||||||
|
if ((selections.GetCount() == 0) && (m_oldSelections.GetCount() == 0))
|
||||||
|
{
|
||||||
|
// nothing changed, just leave
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (selections.GetCount() == m_oldSelections.GetCount())
|
||||||
|
{
|
||||||
|
bool changed = false;
|
||||||
|
size_t idx;
|
||||||
|
for (idx = 0; idx < selections.GetCount(); idx++)
|
||||||
|
{
|
||||||
|
if (selections[idx] != m_oldSelections[idx])
|
||||||
|
{
|
||||||
|
changed = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// nothing changed, just leave
|
||||||
|
if (!changed)
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (selections.GetCount() == 0)
|
||||||
|
{
|
||||||
|
// indicate that this is a deselection
|
||||||
|
event.SetExtraLong( 0 );
|
||||||
|
int item = m_oldSelections[0];
|
||||||
|
m_oldSelections = selections;
|
||||||
|
LBSendEvent( event, this, item );
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
int item;
|
||||||
|
// Now test if any new item is selected
|
||||||
|
bool any_new_selected = false;
|
||||||
|
size_t idx;
|
||||||
|
for (idx = 0; idx < selections.GetCount(); idx++)
|
||||||
|
{
|
||||||
|
item = selections[idx];
|
||||||
|
if (m_oldSelections.Index(item) == wxNOT_FOUND)
|
||||||
|
{
|
||||||
|
any_new_selected = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (any_new_selected)
|
||||||
|
{
|
||||||
|
// indicate that this is a selection
|
||||||
|
event.SetExtraLong( 1 );
|
||||||
|
m_oldSelections = selections;
|
||||||
|
LBSendEvent( event, this, item );
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Now test if any new item is deselected
|
||||||
|
bool any_new_deselected = false;
|
||||||
|
for (idx = 0; idx < m_oldSelections.GetCount(); idx++)
|
||||||
|
{
|
||||||
|
item = m_oldSelections[idx];
|
||||||
|
if (selections.Index(item) == wxNOT_FOUND)
|
||||||
|
{
|
||||||
|
any_new_deselected = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (any_new_deselected)
|
||||||
|
{
|
||||||
|
// indicate that this is a selection
|
||||||
|
event.SetExtraLong( 0 );
|
||||||
|
m_oldSelections = selections;
|
||||||
|
LBSendEvent( event, this, item );
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
wxLogError( wxT("Wrong wxListBox selection") );
|
||||||
|
}
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// misc
|
// misc
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
@@ -112,17 +112,6 @@ gtk_listbox_row_activated_callback(GtkTreeView * WXUNUSED(treeview),
|
|||||||
// "changed"
|
// "changed"
|
||||||
//-----------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------
|
||||||
|
|
||||||
static void SendEvent( wxCommandEvent &event, wxListBox *listbox, int item )
|
|
||||||
{
|
|
||||||
event.SetInt( item );
|
|
||||||
event.SetString( listbox->GetString( item ) );
|
|
||||||
if ( listbox->HasClientObjectData() )
|
|
||||||
event.SetClientObject( listbox->GetClientObject(item) );
|
|
||||||
else if ( listbox->HasClientUntypedData() )
|
|
||||||
event.SetClientData( listbox->GetClientData(item) );
|
|
||||||
listbox->HandleWindowEvent( event );
|
|
||||||
}
|
|
||||||
|
|
||||||
extern "C" {
|
extern "C" {
|
||||||
static void
|
static void
|
||||||
gtk_listitem_changed_callback(GtkTreeSelection * WXUNUSED(selection),
|
gtk_listitem_changed_callback(GtkTreeSelection * WXUNUSED(selection),
|
||||||
@@ -130,96 +119,15 @@ gtk_listitem_changed_callback(GtkTreeSelection * WXUNUSED(selection),
|
|||||||
{
|
{
|
||||||
if (g_blockEventsOnDrag) return;
|
if (g_blockEventsOnDrag) return;
|
||||||
|
|
||||||
wxCommandEvent event(wxEVT_COMMAND_LISTBOX_SELECTED, listbox->GetId() );
|
|
||||||
event.SetEventObject( listbox );
|
|
||||||
|
|
||||||
if (listbox->HasFlag(wxLB_MULTIPLE) || listbox->HasFlag(wxLB_EXTENDED))
|
if (listbox->HasFlag(wxLB_MULTIPLE) || listbox->HasFlag(wxLB_EXTENDED))
|
||||||
{
|
{
|
||||||
wxArrayInt selections;
|
listbox->CalcAndSendEvent();
|
||||||
listbox->GetSelections( selections );
|
|
||||||
|
|
||||||
if ((selections.GetCount() == 0) && (listbox->m_oldSelection.GetCount() == 0))
|
|
||||||
{
|
|
||||||
// nothing changed, just leave
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (selections.GetCount() == listbox->m_oldSelection.GetCount())
|
|
||||||
{
|
|
||||||
bool changed = false;
|
|
||||||
size_t idx;
|
|
||||||
for (idx = 0; idx < selections.GetCount(); idx++)
|
|
||||||
{
|
|
||||||
if (selections[idx] != listbox->m_oldSelection[idx])
|
|
||||||
{
|
|
||||||
changed = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// nothing changed, just leave
|
|
||||||
if (!changed)
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (selections.GetCount() == 0)
|
|
||||||
{
|
|
||||||
// indicate that this is a deselection
|
|
||||||
event.SetExtraLong( 0 );
|
|
||||||
int item = listbox->m_oldSelection[0];
|
|
||||||
listbox->m_oldSelection = selections;
|
|
||||||
SendEvent( event, listbox, item );
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
int item;
|
|
||||||
// Now test if any new item is selected
|
|
||||||
bool any_new_selected = false;
|
|
||||||
size_t idx;
|
|
||||||
for (idx = 0; idx < selections.GetCount(); idx++)
|
|
||||||
{
|
|
||||||
item = selections[idx];
|
|
||||||
if (listbox->m_oldSelection.Index(item) == wxNOT_FOUND)
|
|
||||||
{
|
|
||||||
any_new_selected = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (any_new_selected)
|
|
||||||
{
|
|
||||||
// indicate that this is a selection
|
|
||||||
event.SetExtraLong( 1 );
|
|
||||||
listbox->m_oldSelection = selections;
|
|
||||||
SendEvent( event, listbox, item );
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Now test if any new item is deselected
|
|
||||||
bool any_new_deselected = false;
|
|
||||||
for (idx = 0; idx < listbox->m_oldSelection.GetCount(); idx++)
|
|
||||||
{
|
|
||||||
item = listbox->m_oldSelection[idx];
|
|
||||||
if (selections.Index(item) == wxNOT_FOUND)
|
|
||||||
{
|
|
||||||
any_new_deselected = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (any_new_deselected)
|
|
||||||
{
|
|
||||||
// indicate that this is a selection
|
|
||||||
event.SetExtraLong( 0 );
|
|
||||||
listbox->m_oldSelection = selections;
|
|
||||||
SendEvent( event, listbox, item );
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
wxLogError( wxT("Wrong wxListBox selection") );
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
wxCommandEvent event(wxEVT_COMMAND_LISTBOX_SELECTED, listbox->GetId() );
|
||||||
|
event.SetEventObject( listbox );
|
||||||
|
|
||||||
int index = listbox->GetSelection();
|
int index = listbox->GetSelection();
|
||||||
if (index == wxNOT_FOUND)
|
if (index == wxNOT_FOUND)
|
||||||
{
|
{
|
||||||
@@ -588,7 +496,7 @@ void wxListBox::GtkEnableEvents()
|
|||||||
g_signal_handlers_unblock_by_func(selection,
|
g_signal_handlers_unblock_by_func(selection,
|
||||||
(gpointer) gtk_listitem_changed_callback, this);
|
(gpointer) gtk_listitem_changed_callback, this);
|
||||||
|
|
||||||
GtkUpdateOldSelection();
|
UpdateOldSelections();
|
||||||
}
|
}
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
@@ -853,7 +761,7 @@ int wxListBox::GetSelections( wxArrayInt& aSelections ) const
|
|||||||
|
|
||||||
aSelections.Empty();
|
aSelections.Empty();
|
||||||
|
|
||||||
int i = 0;
|
int i = 0;
|
||||||
GtkTreeIter iter;
|
GtkTreeIter iter;
|
||||||
GtkTreeSelection* selection = gtk_tree_view_get_selection(m_treeview);
|
GtkTreeSelection* selection = gtk_tree_view_get_selection(m_treeview);
|
||||||
|
|
||||||
@@ -920,12 +828,6 @@ void wxListBox::DoSetSelection( int n, bool select )
|
|||||||
GtkEnableEvents();
|
GtkEnableEvents();
|
||||||
}
|
}
|
||||||
|
|
||||||
void wxListBox::GtkUpdateOldSelection()
|
|
||||||
{
|
|
||||||
if (HasFlag(wxLB_MULTIPLE) || HasFlag(wxLB_EXTENDED))
|
|
||||||
GetSelections( m_oldSelection );
|
|
||||||
}
|
|
||||||
|
|
||||||
void wxListBox::DoScrollToCell(int n, float alignY, float alignX)
|
void wxListBox::DoScrollToCell(int n, float alignY, float alignX)
|
||||||
{
|
{
|
||||||
wxCHECK_RET( m_treeview, wxT("invalid listbox") );
|
wxCHECK_RET( m_treeview, wxT("invalid listbox") );
|
||||||
|
Reference in New Issue
Block a user