Gtk2::Ex::TreeModelFilter::DragDest -- drag destination mix-in for TreeModelFilter subclasses
package MyNewFilterModel; use Gtk2; use base 'Gtk2::Ex::TreeModelFilter::DragDest'; use Glib::Object::Subclass Gtk2::TreeModelFilter::, interfaces => [ 'Gtk2::TreeDragDest' ];
Gtk2::Ex::TreeModelFilter::DragDest provides the following two functions to implement the Gtk2::TreeDragDest interface in a sub-class of Gtk2::TreeModelFilter.
Gtk2::Ex::TreeModelFilter::DragDest
Gtk2::TreeDragDest
Gtk2::TreeModelFilter
ROW_DROP_POSSIBLE DRAG_DATA_RECEIVED
They're designed as a multiple-inheritance mix-in, so you put Gtk2::Ex::TreeModelFilter::DragDest in your @ISA, then add Gtk2::TreeDragDest to the interfaces in your use Glib::Object::Subclass (or register_object).
@ISA
interfaces
use Glib::Object::Subclass
register_object
For simple filter draggability you'll probably find Gtk2::Ex::TreeModelFilter::Draggable enough, but DragDest lets you add draggability to sub-sub-classes of TreeModelFilter.
Gtk2::Ex::TreeModelFilter::Draggable
DragDest
The drop strategy is simply to delegate to the filter's child-model. If it's not a TreeDragDest, but is another Gtk2::TreeModelFilter, then its child-model is tried, and so downwards to the first TreeDragDest capable child. The destination path position is converted as necessary.
child-model
If the drag source is the filter itself (which is usual for say dragging in a Gtk2::TreeView) then the source row ends up being from the first non-filter child model. The above drop strategy ends up on that same child, which is important for instance for a Gtk2::ListStore since it only allows drags within itself.
Gtk2::TreeView
Gtk2::ListStore
There's probably no reason GtkTreeModelFilter itself couldn't do this sort of drop, but as of Gtk 2.12 it doesn't. Perhaps by the time you read this it will, and you won't need this code.
GtkTreeModelFilter
If your filter's "visible" function decides a newly dropped row shouldn't appear then the drop still works, but it'll look to the user like the source just disappeared. That might be confusing; or if the destination is some designated "hidden track" then it be what you want.
Gtk2::TreeModelFilter, Gtk2::TreeModel
http://user42.tuxfamily.org/gtk2-ex-treemodelfilter-dragdest/
Copyright 2008, 2009, 2010 Kevin Ryde
Gtk2-Ex-TreeModelFilter-DragDest is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3, or (at your option) any later version.
Gtk2-Ex-TreeModelFilter-DragDest is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with Gtk2-Ex-TreeModelFilter-DragDest. If not, see http://www.gnu.org/licenses/.
To install Gtk2::Ex::TreeModelFilter::DragDest, copy and paste the appropriate command in to your terminal.
cpanm
cpanm Gtk2::Ex::TreeModelFilter::DragDest
CPAN shell
perl -MCPAN -e shell install Gtk2::Ex::TreeModelFilter::DragDest
For more information on module installation, please visit the detailed CPAN module installation guide.