Allow dropping data outside of item area in wxDataViewCtrl.
Implement this change for the generic and the native GTK versions and document it. Closes #16152. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@76416 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
555e57912e
commit
cbe6495307
@ -36,6 +36,7 @@ All (GUI):
|
|||||||
- Add wxFD_NO_FOLLOW style for wxFileDialog (Luca Bacci).
|
- Add wxFD_NO_FOLLOW style for wxFileDialog (Luca Bacci).
|
||||||
- Add support for embedding bitmaps in generated SVG in wxSVGFileDC (iwbnwif).
|
- Add support for embedding bitmaps in generated SVG in wxSVGFileDC (iwbnwif).
|
||||||
- Add support for sorting wxDataViewCtrl by multiple columns (Trigve).
|
- Add support for sorting wxDataViewCtrl by multiple columns (Trigve).
|
||||||
|
- Allow dropping data on wxDataViewCtrl background (Laurent Poujoulat).
|
||||||
- Add wxHtmlWindow::SetDefaultHTMLCursor() (Jeff A. Marr).
|
- Add wxHtmlWindow::SetDefaultHTMLCursor() (Jeff A. Marr).
|
||||||
- Add default ctor and Create() to wxContextHelpButton (Hanmac).
|
- Add default ctor and Create() to wxContextHelpButton (Hanmac).
|
||||||
- Send events when toggling wxPropertyGrid nodes from keyboard (Armel Asselin).
|
- Send events when toggling wxPropertyGrid nodes from keyboard (Armel Asselin).
|
||||||
|
@ -3483,7 +3483,13 @@ public:
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
Returns the item affected by the event.
|
||||||
|
|
||||||
|
Notice that for @c wxEVT_DATAVIEW_ITEM_DROP_POSSIBLE and @c
|
||||||
|
wxEVT_DATAVIEW_ITEM_DROP event handlers, the item may be invalid,
|
||||||
|
indicating that the drop is about to happen outside of the item area.
|
||||||
|
*/
|
||||||
wxDataViewItem GetItem() const;
|
wxDataViewItem GetItem() const;
|
||||||
void SetItem( const wxDataViewItem &item );
|
void SetItem( const wxDataViewItem &item );
|
||||||
void SetEditCanceled(bool editCancelled);
|
void SetEditCanceled(bool editCancelled);
|
||||||
|
@ -862,8 +862,8 @@ void MyFrame::OnDropPossible( wxDataViewEvent &event )
|
|||||||
{
|
{
|
||||||
wxDataViewItem item( event.GetItem() );
|
wxDataViewItem item( event.GetItem() );
|
||||||
|
|
||||||
// only allow drags for item, not containers
|
// only allow drags for item or background, not containers
|
||||||
if (m_music_model->IsContainer( item ) )
|
if ( item.IsOk() && m_music_model->IsContainer( item ) )
|
||||||
event.Veto();
|
event.Veto();
|
||||||
|
|
||||||
if (event.GetDataFormat() != wxDF_UNICODETEXT)
|
if (event.GetDataFormat() != wxDF_UNICODETEXT)
|
||||||
@ -875,7 +875,7 @@ void MyFrame::OnDrop( wxDataViewEvent &event )
|
|||||||
wxDataViewItem item( event.GetItem() );
|
wxDataViewItem item( event.GetItem() );
|
||||||
|
|
||||||
// only allow drops for item, not containers
|
// only allow drops for item, not containers
|
||||||
if (m_music_model->IsContainer( item ) )
|
if ( item.IsOk() && m_music_model->IsContainer( item ) )
|
||||||
{
|
{
|
||||||
event.Veto();
|
event.Veto();
|
||||||
return;
|
return;
|
||||||
@ -890,7 +890,10 @@ void MyFrame::OnDrop( wxDataViewEvent &event )
|
|||||||
wxTextDataObject obj;
|
wxTextDataObject obj;
|
||||||
obj.SetData( wxDF_UNICODETEXT, event.GetDataSize(), event.GetDataBuffer() );
|
obj.SetData( wxDF_UNICODETEXT, event.GetDataSize(), event.GetDataBuffer() );
|
||||||
|
|
||||||
wxLogMessage( "Text dropped: %s", obj.GetText() );
|
if ( item.IsOk() )
|
||||||
|
wxLogMessage( "Text dropped on item %s: %s", m_music_model->GetTitle( item ), obj.GetText() );
|
||||||
|
else
|
||||||
|
wxLogMessage( "Text dropped on background: %s", obj.GetText() );
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // wxUSE_DRAG_AND_DROP
|
#endif // wxUSE_DRAG_AND_DROP
|
||||||
|
@ -1608,13 +1608,10 @@ wxDragResult wxDataViewMainWindow::OnDragOver( wxDataFormat format, wxCoord x,
|
|||||||
m_owner->CalcUnscrolledPosition( xx, yy, &xx, &yy );
|
m_owner->CalcUnscrolledPosition( xx, yy, &xx, &yy );
|
||||||
unsigned int row = GetLineAt( yy );
|
unsigned int row = GetLineAt( yy );
|
||||||
|
|
||||||
if ((row >= GetRowCount()) || (xx > GetEndOfLastCol()))
|
wxDataViewItem item;
|
||||||
{
|
|
||||||
RemoveDropHint();
|
|
||||||
return wxDragNone;
|
|
||||||
}
|
|
||||||
|
|
||||||
wxDataViewItem item = GetItemByRow( row );
|
if ( row < GetRowCount() && xx <= GetEndOfLastCol() )
|
||||||
|
item = GetItemByRow( row );
|
||||||
|
|
||||||
wxDataViewModel *model = GetModel();
|
wxDataViewModel *model = GetModel();
|
||||||
|
|
||||||
@ -1624,24 +1621,24 @@ wxDragResult wxDataViewMainWindow::OnDragOver( wxDataFormat format, wxCoord x,
|
|||||||
event.SetModel( model );
|
event.SetModel( model );
|
||||||
event.SetDataFormat( format );
|
event.SetDataFormat( format );
|
||||||
event.SetDropEffect( def );
|
event.SetDropEffect( def );
|
||||||
if (!m_owner->HandleWindowEvent( event ))
|
if ( !m_owner->HandleWindowEvent( event ) || !event.IsAllowed() )
|
||||||
{
|
{
|
||||||
RemoveDropHint();
|
RemoveDropHint();
|
||||||
return wxDragNone;
|
return wxDragNone;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!event.IsAllowed())
|
if ( item.IsOk() )
|
||||||
{
|
{
|
||||||
RemoveDropHint();
|
|
||||||
return wxDragNone;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
if (m_dropHint && (row != m_dropHintLine))
|
if (m_dropHint && (row != m_dropHintLine))
|
||||||
RefreshRow( m_dropHintLine );
|
RefreshRow( m_dropHintLine );
|
||||||
m_dropHint = true;
|
m_dropHint = true;
|
||||||
m_dropHintLine = row;
|
m_dropHintLine = row;
|
||||||
RefreshRow( row );
|
RefreshRow( row );
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
RemoveDropHint();
|
||||||
|
}
|
||||||
|
|
||||||
return def;
|
return def;
|
||||||
}
|
}
|
||||||
@ -1655,10 +1652,10 @@ bool wxDataViewMainWindow::OnDrop( wxDataFormat format, wxCoord x, wxCoord y )
|
|||||||
m_owner->CalcUnscrolledPosition( xx, yy, &xx, &yy );
|
m_owner->CalcUnscrolledPosition( xx, yy, &xx, &yy );
|
||||||
unsigned int row = GetLineAt( yy );
|
unsigned int row = GetLineAt( yy );
|
||||||
|
|
||||||
if ((row >= GetRowCount()) || (xx > GetEndOfLastCol()))
|
wxDataViewItem item;
|
||||||
return false;
|
|
||||||
|
|
||||||
wxDataViewItem item = GetItemByRow( row );
|
if ( row < GetRowCount() && xx <= GetEndOfLastCol())
|
||||||
|
item = GetItemByRow( row );
|
||||||
|
|
||||||
wxDataViewModel *model = GetModel();
|
wxDataViewModel *model = GetModel();
|
||||||
|
|
||||||
@ -1667,10 +1664,7 @@ bool wxDataViewMainWindow::OnDrop( wxDataFormat format, wxCoord x, wxCoord y )
|
|||||||
event.SetItem( item );
|
event.SetItem( item );
|
||||||
event.SetModel( model );
|
event.SetModel( model );
|
||||||
event.SetDataFormat( format );
|
event.SetDataFormat( format );
|
||||||
if (!m_owner->HandleWindowEvent( event ))
|
if (!m_owner->HandleWindowEvent( event ) || !event.IsAllowed())
|
||||||
return false;
|
|
||||||
|
|
||||||
if (!event.IsAllowed())
|
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
@ -1684,10 +1678,10 @@ wxDragResult wxDataViewMainWindow::OnData( wxDataFormat format, wxCoord x, wxCoo
|
|||||||
m_owner->CalcUnscrolledPosition( xx, yy, &xx, &yy );
|
m_owner->CalcUnscrolledPosition( xx, yy, &xx, &yy );
|
||||||
unsigned int row = GetLineAt( yy );
|
unsigned int row = GetLineAt( yy );
|
||||||
|
|
||||||
if ((row >= GetRowCount()) || (xx > GetEndOfLastCol()))
|
wxDataViewItem item;
|
||||||
return wxDragNone;
|
|
||||||
|
|
||||||
wxDataViewItem item = GetItemByRow( row );
|
if ( row < GetRowCount() && xx <= GetEndOfLastCol() )
|
||||||
|
item = GetItemByRow( row );
|
||||||
|
|
||||||
wxDataViewModel *model = GetModel();
|
wxDataViewModel *model = GetModel();
|
||||||
|
|
||||||
@ -1701,10 +1695,7 @@ wxDragResult wxDataViewMainWindow::OnData( wxDataFormat format, wxCoord x, wxCoo
|
|||||||
event.SetDataSize( obj->GetSize() );
|
event.SetDataSize( obj->GetSize() );
|
||||||
event.SetDataBuffer( obj->GetData() );
|
event.SetDataBuffer( obj->GetData() );
|
||||||
event.SetDropEffect( def );
|
event.SetDropEffect( def );
|
||||||
if (!m_owner->HandleWindowEvent( event ))
|
if ( !m_owner->HandleWindowEvent( event ) || !event.IsAllowed() )
|
||||||
return wxDragNone;
|
|
||||||
|
|
||||||
if (!event.IsAllowed())
|
|
||||||
return wxDragNone;
|
return wxDragNone;
|
||||||
|
|
||||||
return def;
|
return def;
|
||||||
|
@ -3562,8 +3562,6 @@ wxDataViewCtrlInternal::drag_data_received(GtkTreeDragDest *WXUNUSED(drag_dest),
|
|||||||
GtkSelectionData *selection_data)
|
GtkSelectionData *selection_data)
|
||||||
{
|
{
|
||||||
wxDataViewItem item(GetOwner()->GTKPathToItem(path));
|
wxDataViewItem item(GetOwner()->GTKPathToItem(path));
|
||||||
if ( !item )
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
wxDataViewEvent event( wxEVT_DATAVIEW_ITEM_DROP, m_owner->GetId() );
|
wxDataViewEvent event( wxEVT_DATAVIEW_ITEM_DROP, m_owner->GetId() );
|
||||||
event.SetEventObject( m_owner );
|
event.SetEventObject( m_owner );
|
||||||
@ -3587,8 +3585,6 @@ wxDataViewCtrlInternal::row_drop_possible(GtkTreeDragDest *WXUNUSED(drag_dest),
|
|||||||
GtkSelectionData *selection_data)
|
GtkSelectionData *selection_data)
|
||||||
{
|
{
|
||||||
wxDataViewItem item(GetOwner()->GTKPathToItem(path));
|
wxDataViewItem item(GetOwner()->GTKPathToItem(path));
|
||||||
if ( !item )
|
|
||||||
return FALSE;
|
|
||||||
|
|
||||||
wxDataViewEvent event( wxEVT_DATAVIEW_ITEM_DROP_POSSIBLE, m_owner->GetId() );
|
wxDataViewEvent event( wxEVT_DATAVIEW_ITEM_DROP_POSSIBLE, m_owner->GetId() );
|
||||||
event.SetEventObject( m_owner );
|
event.SetEventObject( m_owner );
|
||||||
|
Loading…
Reference in New Issue
Block a user