Top |
RbTreeDragSource | |
struct | RbTreeDragSourceIface |
RbTreeDragDest | |
struct | RbTreeDragDestIface |
enum | RbTreeDestFlag |
RbTreeDragSource is implemented by RBDisplayPageModel, RhythmDBPropertyModel and RhythmDBQueryModel.
RbTreeDragDest is implemented by RBDisplayPageModel and RhythmDBQueryModel.
Provides support for drag and drop operations to and from GtkTreeView widgets that can include multiple rows. The model backing the tree view widgets must implement the RbTreeDragSource and RbTreeDragDest interfaces.
gboolean rb_tree_drag_source_row_draggable (RbTreeDragSource *drag_source
,GList *path_list
);
Asks the RbTreeDragSource whether a particular row can be used as the source of a DND operation. If the source doesn't implement this interface, the row is assumed draggable.
gboolean rb_tree_drag_source_drag_data_delete (RbTreeDragSource *drag_source
,GList *path_list
);
Asks the RbTreeDragSource to delete the row at path
, because
it was moved somewhere else via drag-and-drop. Returns FALSE
if the deletion fails because path
no longer exists, or for
some model-specific reason. Should robustly handle a path
no
longer found in the model!
gboolean rb_tree_drag_source_drag_data_get (RbTreeDragSource *drag_source
,GList *path_list
,GtkSelectionData *selection_data
);
Asks the RbTreeDragSource to fill in selection_data
with a
representation of the row at path
. selection_data->target
gives
the required type of the data. Should robustly handle a path
no
longer found in the model!
drag_source |
||
path_list |
row that was dragged |
|
selection_data |
a GtkSelectionData to fill with data from the dragged row |
gboolean rb_tree_drag_dest_drag_data_received (RbTreeDragDest *drag_dest
,GtkTreePath *dest
,GtkTreeViewDropPosition pos
,GtkSelectionData *selection_data
);
Asks a RbTreeDragDest to accept some drag and drop data.
drag_dest |
||
dest |
the GtkTreePath on which the data was dropped |
|
pos |
the drop position relative to the row identified by |
|
selection_data |
a GtkSelectionData containing the drag data |
gboolean rb_tree_drag_dest_row_drop_possible (RbTreeDragDest *drag_dest
,GtkTreePath *dest_path
,GtkTreeViewDropPosition pos
,GtkSelectionData *selection_data
);
Asks the RbTreeDragDest whether data can be dropped on a particular row. This should probably check based on the format and the row.
drag_dest |
||
dest_path |
the GtkTreePath on which the data may be dropped |
|
pos |
the drop position relative to the row identified by |
|
selection_data |
a GtkSelectionData containing the drag data |
gboolean rb_tree_drag_dest_row_drop_position (RbTreeDragDest *drag_dest
,GtkTreePath *dest_path
,GList *targets
,GtkTreeViewDropPosition *pos
);
Asks the RbTreeDragDest which drop position to use relative to the specified row. The drag destination should decide which drop position to use based on the target row and the list of drag targets.
drag_dest |
||
dest_path |
a GtkTreePath describing a possible drop row |
|
targets |
a GList containing possible drop target types |
|
pos |
returns the GtkTreeViewDropPosition to use relative to the row |
void rb_tree_dnd_add_drag_dest_support (GtkTreeView *tree_view
,RbTreeDestFlag flags
,const GtkTargetEntry *targets
,gint n_targets
,GdkDragAction actions
);
Adds event handlers to perform multi-row drag and drop operations to the specified GtkTreeView. The model backing the tree view should implement the RbTreeDragDest interface. This should be called immediately after the tree view is created.
tree_view |
a GtkTreeView that wants to be a drag destination |
|
flags |
RbTreeDestFlags for this drag destination |
|
targets |
an array of GtkTargetEntry structures describing the allowed drag targets |
|
n_targets |
the number of elements in |
|
actions |
the allowable drag actions for this destination |
void rb_tree_dnd_add_drag_source_support (GtkTreeView *tree_view
,GdkModifierType start_button_mask
,const GtkTargetEntry *targets
,gint n_targets
,GdkDragAction actions
);
Adds event handlers to perform multi-row drag and drop operations from the specified GtkTreeView widget. The model backing the GtkTreeView must implement the RbTreeDragSource interface. This should be called immediately after the tree view is created.
tree_view |
a GtkTreeView that wants to be a drag source |
|
start_button_mask |
a mask describing modifier keys to handle when dragging |
|
targets |
an array of GtkTargetEntry structures describing drag data types |
|
n_targets |
the number of elements in |
|
actions |
a mask describing drag actions that are allowed from this source |
struct RbTreeDragSourceIface { GTypeInterface g_iface; /* VTable - not signals */ gboolean (* rb_row_draggable) (RbTreeDragSource *drag_source, GList *path_list); gboolean (* rb_drag_data_get) (RbTreeDragSource *drag_source, GList *path_list, GtkSelectionData *selection_data); gboolean (* rb_drag_data_delete) (RbTreeDragSource *drag_source, GList *path_list); };
struct RbTreeDragDestIface { GTypeInterface g_iface; /* VTable - not signals */ gboolean (* rb_drag_data_received) (RbTreeDragDest *drag_dest, GtkTreePath *dest, GtkTreeViewDropPosition pos, GtkSelectionData *selection_data); gboolean (* rb_row_drop_possible) (RbTreeDragDest *drag_dest, GtkTreePath *dest_path, GtkTreeViewDropPosition pos, GtkSelectionData *selection_data); gboolean (* rb_row_drop_position) (RbTreeDragDest *drag_dest, GtkTreePath *dest_path, GList *targets, GtkTreeViewDropPosition *pos); /* optional */ GdkAtom (* rb_get_drag_target) (RbTreeDragDest *drag_dest, GtkWidget *widget, GdkDragContext *context, GtkTreePath *dest_path, GtkTargetList *target_list); };