Gtk.DropTarget¶
- Subclasses:
None
Methods¶
- Inherited:
- Structs:
class |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Virtual Methods¶
- Inherited:
Properties¶
- Inherited:
Name |
Type |
Flags |
Short Description |
|---|---|---|---|
r/w/en |
|||
r |
|||
d/r |
|
||
r/w/co |
|||
r/w/en |
|||
r |
Signals¶
- Inherited:
Name |
Short Description |
|---|---|
Emitted on the drop site when a drop operation is about to begin. |
|
Emitted on the drop site when the user drops the data onto the widget. |
|
Emitted on the drop site when the pointer enters the widget. |
|
Emitted on the drop site when the pointer leaves the widget. |
|
Emitted while the pointer is moving over the drop target. |
Fields¶
- Inherited:
Class Details¶
- class Gtk.DropTarget(**kwargs)¶
- Bases:
- Abstract:
No
- Structure:
An event controller to receive Drag-and-Drop operations.
The most basic way to use a
GtkDropTargetto receive drops on a widget is to create it via [ctor`Gtk`.DropTarget.new], passing in theGTypeof the data you want to receive and connect to the [signal`Gtk`.DropTarget::drop] signal to receive the data:```c static
boolon_drop (Gtk.DropTarget*target, constGObject.Value*value, double x, double y,objectdata) { MyWidget *self = data;// Call the appropriate setter depending on the type of data // that we received if (G_VALUE_HOLDS (value, G_TYPE_FILE)) my_widget_set_file (self,
GObject.Value.get_object(value)); else if (G_VALUE_HOLDS (value, GDK_TYPE_PIXBUF)) my_widget_set_pixbuf (self,GObject.Value.get_object(value)); else returnFalse;return
True; }static void my_widget_init (MyWidget *self) {
Gtk.DropTarget*target =Gtk.DropTarget.new(GObject.TYPE_INVALID,Gdk.DragAction.COPY);// This widget accepts two types of drop types:
Gio.Fileobjects // andGdkPixbuf.PixbufobjectsGtk.DropTarget.set_gtypes(target, (GObject.GType[2]) { G_TYPE_FILE, GDK_TYPE_PIXBUF, }, 2);g_signal_connect (target, “drop”, G_CALLBACK (on_drop), self);
Gtk.Widget.add_controller(GTK_WIDGET (self), GTK_EVENT_CONTROLLER (target)); } ```GtkDropTargetsupports more options, such as:rejecting potential drops via the [signal`Gtk`.DropTarget::accept] signal and the [method`Gtk`.DropTarget.reject] function to let other drop targets handle the drop
tracking an ongoing drag operation before the drop via the [signal`Gtk`.DropTarget::enter], [signal`Gtk`.DropTarget::motion] and [signal`Gtk`.DropTarget::leave] signals
configuring how to receive data by setting the [property`Gtk`.DropTarget:preload] property and listening for its availability via the [property`Gtk`.DropTarget:value] property
However,
GtkDropTargetis ultimately modeled in a synchronous way and only supports data transferred viaGType. If you want full control over an ongoing drop, the [class`Gtk`.DropTargetAsync] object gives you this ability.While a pointer is dragged over the drop target’s widget and the drop has not been rejected, that widget will receive the
Gtk.StateFlags.DROP_ACTIVEstate, which can be used to style the widget.If you are not interested in receiving the drop, but just want to update UI state during a Drag-and-Drop operation (e.g. switching tabs), you can use [class`Gtk`.DropControllerMotion].
- classmethod new(type, actions)[source]¶
- Parameters:
type (
GObject.GType) – The supported type orGObject.TYPE_INVALIDactions (
Gdk.DragAction) – the supported actions
- Returns:
the new
GtkDropTarget- Return type:
Creates a new
GtkDropTargetobject.If the drop target should support more than 1 type, pass
GObject.TYPE_INVALIDfor type and then call [method`Gtk`.DropTarget.set_gtypes].
- get_actions()[source]¶
- Returns:
the actions that this drop target supports
- Return type:
Gets the actions that this drop target supports.
- get_current_drop()[source]¶
-
Gets the currently handled drop operation.
If no drop operation is going on,
Noneis returned.New in version 4.4.
- get_drop()[source]¶
-
Gets the currently handled drop operation.
If no drop operation is going on,
Noneis returned.Deprecated since version 4.4: Use [method`Gtk`.DropTarget.get_current_drop] instead
- get_formats()[source]¶
- Returns:
the supported data formats
- Return type:
Gets the data formats that this drop target accepts.
If the result is
None, all formats are expected to be supported.
- get_gtypes()[source]¶
- Returns:
the
G_TYPE_INVALID-terminated array of types included in formats- Return type:
[
GObject.GType] orNone
Gets the list of supported ``GType``s that can be dropped on the target.
If no types have been set,
NULLwill be returned.
- get_value()[source]¶
- Returns:
The current drop data
- Return type:
Gets the current drop data, as a
GValue.
- reject()[source]¶
Rejects the ongoing drop operation.
If no drop operation is ongoing, i.e when [property`Gtk`.DropTarget:current-drop] is
None, this function does nothing.This function should be used when delaying the decision on whether to accept a drag or not until after reading the data.
- set_actions(actions)[source]¶
- Parameters:
actions (
Gdk.DragAction) – the supported actions
Sets the actions that this drop target supports.
Signal Details¶
- Gtk.DropTarget.signals.accept(drop_target, drop)¶
- Signal Name:
accept- Flags:
- Parameters:
drop_target (
Gtk.DropTarget) – The object which received the signaldrop (
Gdk.Drop) – theGdkDrop
- Returns:
Trueif drop is accepted- Return type:
Emitted on the drop site when a drop operation is about to begin.
If the drop is not accepted,
Falsewill be returned and the drop target will ignore the drop. IfTrueis returned, the drop is accepted for now but may be rejected later via a call to [method`Gtk`.DropTarget.reject] or ultimately by returningFalsefrom a [signal`Gtk`.DropTarget::drop] handler.The default handler for this signal decides whether to accept the drop based on the formats provided by the drop.
If the decision whether the drop will be accepted or rejected depends on the data, this function should return
True, the [property`Gtk`.DropTarget:preload] property should be set and the value should be inspected via the::notify:valuesignal, calling [method`Gtk`.DropTarget.reject] if required.
- Gtk.DropTarget.signals.drop(drop_target, value, x, y)¶
- Signal Name:
drop- Flags:
- Parameters:
drop_target (
Gtk.DropTarget) – The object which received the signalvalue (
GObject.Value) – theGValuebeing droppedx (
float) – the x coordinate of the current pointer positiony (
float) – the y coordinate of the current pointer position
- Returns:
whether the drop was accepted at the given pointer position
- Return type:
Emitted on the drop site when the user drops the data onto the widget.
The signal handler must determine whether the pointer position is in a drop zone or not. If it is not in a drop zone, it returns
Falseand no further processing is necessary.Otherwise, the handler returns
True. In this case, this handler will accept the drop. The handler is responsible for using the given value and performing the drop operation.
- Gtk.DropTarget.signals.enter(drop_target, x, y)¶
- Signal Name:
enter- Flags:
- Parameters:
drop_target (
Gtk.DropTarget) – The object which received the signalx (
float) – the x coordinate of the current pointer positiony (
float) – the y coordinate of the current pointer position
- Returns:
Preferred action for this drag operation or 0 if dropping is not supported at the current x,`y` location.
- Return type:
Emitted on the drop site when the pointer enters the widget.
It can be used to set up custom highlighting.
- Gtk.DropTarget.signals.leave(drop_target)¶
- Signal Name:
leave- Flags:
- Parameters:
drop_target (
Gtk.DropTarget) – The object which received the signal
Emitted on the drop site when the pointer leaves the widget.
Its main purpose it to undo things done in [signal`Gtk`.DropTarget::enter].
- Gtk.DropTarget.signals.motion(drop_target, x, y)¶
- Signal Name:
motion- Flags:
- Parameters:
drop_target (
Gtk.DropTarget) – The object which received the signalx (
float) – the x coordinate of the current pointer positiony (
float) – the y coordinate of the current pointer position
- Returns:
Preferred action for this drag operation or 0 if dropping is not supported at the current x,`y` location.
- Return type:
Emitted while the pointer is moving over the drop target.
Property Details¶
- Gtk.DropTarget.props.actions¶
- Name:
actions- Type:
- Default Value:
0- Flags:
The
GdkDragActionsthat this drop target supports.
- Gtk.DropTarget.props.current_drop¶
-
The
GdkDropthat is currently being performed.New in version 4.4.
- Gtk.DropTarget.props.drop¶
- Name:
drop- Type:
- Default Value:
- Flags:
The
GdkDropthat is currently being performed.Deprecated since version 4.4: Use [property`Gtk`.DropTarget:current-drop] instead
- Gtk.DropTarget.props.formats¶
- Name:
formats- Type:
- Default Value:
- Flags:
The
GdkContentFormatsthat determine the supported data formats.
- Gtk.DropTarget.props.preload¶
- Name:
preload- Type:
- Default Value:
- Flags:
Whether the drop data should be preloaded when the pointer is only hovering over the widget but has not been released.
Setting this property allows finer grained reaction to an ongoing drop at the cost of loading more data.
The default value for this property is
Falseto avoid downloading huge amounts of data by accident.For example, if somebody drags a full document of gigabytes of text from a text editor across a widget with a preloading drop target, this data will be downloaded, even if the data is ultimately dropped elsewhere.
For a lot of data formats, the amount of data is very small (like %GDK_TYPE_RGBA), so enabling this property does not hurt at all. And for local-only Drag-and-Drop operations, no data transfer is done, so enabling it there is free.
- Gtk.DropTarget.props.value¶
- Name:
value- Type:
- Default Value:
- Flags:
The value for this drop operation.
This is
Noneif the data has not been loaded yet or no drop operation is going on.Data may be available before the [signal`Gtk`.DropTarget::drop] signal gets emitted - for example when the [property`Gtk`.DropTarget:preload] property is set. You can use the
::notifysignal to be notified of available data.