|  |  |  | GDK Reference Manual |  | 
|---|---|---|---|---|
| Top | Description | Object Hierarchy | ||||
#include <gdk/gdk.h>
                    GdkDragContext;
GdkAtom             gdk_drag_get_selection              (GdkDragContext *context);
void                gdk_drag_abort                      (GdkDragContext *context,
                                                         guint32 time_);
void                gdk_drop_reply                      (GdkDragContext *context,
                                                         gboolean accepted,
                                                         guint32 time_);
void                gdk_drag_drop                       (GdkDragContext *context,
                                                         guint32 time_);
void                gdk_drag_find_window_for_screen     (GdkDragContext *context,
                                                         GdkWindow *drag_window,
                                                         GdkScreen *screen,
                                                         gint x_root,
                                                         gint y_root,
                                                         GdkWindow **dest_window,
                                                         GdkDragProtocol *protocol);
GdkDragContext *    gdk_drag_begin                      (GdkWindow *window,
                                                         GList *targets);
GdkDragContext *    gdk_drag_begin_for_device           (GdkWindow *window,
                                                         GdkDevice *device,
                                                         GList *targets);
gboolean            gdk_drag_motion                     (GdkDragContext *context,
                                                         GdkWindow *dest_window,
                                                         GdkDragProtocol protocol,
                                                         gint x_root,
                                                         gint y_root,
                                                         GdkDragAction suggested_action,
                                                         GdkDragAction possible_actions,
                                                         guint32 time_);
void                gdk_drop_finish                     (GdkDragContext *context,
                                                         gboolean success,
                                                         guint32 time_);
GdkNativeWindow     gdk_drag_get_protocol_for_display   (GdkDisplay *display,
                                                         GdkNativeWindow xid,
                                                         GdkDragProtocol *protocol);
enum                GdkDragProtocol;
enum                GdkDragAction;
void                gdk_drag_status                     (GdkDragContext *context,
                                                         GdkDragAction action,
                                                         guint32 time_);
gboolean            gdk_drag_drop_succeeded             (GdkDragContext *context);
GdkDragAction       gdk_drag_context_get_actions        (GdkDragContext *context);
GdkDragAction       gdk_drag_context_get_suggested_action
                                                        (GdkDragContext *context);
GdkDragAction       gdk_drag_context_get_selected_action
                                                        (GdkDragContext *context);
GList *             gdk_drag_context_list_targets       (GdkDragContext *context);
GdkDevice *         gdk_drag_context_get_device         (GdkDragContext *context);
void                gdk_drag_context_set_device         (GdkDragContext *context,
                                                         GdkDevice *device);
GdkWindow *         gdk_drag_context_get_source_window  (GdkDragContext *context);
GdkWindow *         gdk_drag_context_get_dest_window    (GdkDragContext *context);
GdkDragProtocol     gdk_drag_context_get_protocol       (GdkDragContext *context);
These functions provide a low level interface for drag and drop. The X backend of GDK supports both the Xdnd and Motif drag and drop protocols transparently, the Win32 backend supports the WM_DROPFILES protocol.
GTK+ provides a higher level abstraction based on top of these functions, and so they are not normally needed in GTK+ applications. See the Drag and Drop section of the GTK+ documentation for more information.
GdkAtom             gdk_drag_get_selection              (GdkDragContext *context);
Returns the selection atom for the current source window.
| 
 | a GdkDragContext. | 
| Returns : | the selection atom, or GDK_NONE | 
void gdk_drag_abort (GdkDragContext *context,guint32 time_);
Aborts a drag without dropping.
This function is called by the drag source.
| 
 | a GdkDragContext | 
| 
 | the timestamp for this operation | 
void gdk_drop_reply (GdkDragContext *context,gboolean accepted,guint32 time_);
Accepts or rejects a drop.
This function is called by the drag destination in response to a drop initiated by the drag source.
| 
 | a GdkDragContext | 
| 
 | TRUEif the drop is accepted | 
| 
 | the timestamp for this operation | 
void gdk_drag_drop (GdkDragContext *context,guint32 time_);
Drops on the current destination.
This function is called by the drag source.
| 
 | a GdkDragContext | 
| 
 | the timestamp for this operation | 
void gdk_drag_find_window_for_screen (GdkDragContext *context,GdkWindow *drag_window,GdkScreen *screen,gint x_root,gint y_root,GdkWindow **dest_window,GdkDragProtocol *protocol);
Finds the destination window and DND protocol to use at the given pointer position.
This function is called by the drag source to obtain the
dest_window and protocol parameters for gdk_drag_motion().
| 
 | a GdkDragContext | 
| 
 | a window which may be at the pointer position, but should be ignored, since it is put up by the drag source as an icon | 
| 
 | the screen where the destination window is sought | 
| 
 | the x position of the pointer in root coordinates | 
| 
 | the y position of the pointer in root coordinates | 
| 
 | location to store the destination window in. [out] | 
| 
 | location to store the DND protocol in. [out] | 
Since 2.2
GdkDragContext * gdk_drag_begin (GdkWindow *window,GList *targets);
Starts a drag and creates a new drag context for it.
This function assumes that the drag is controlled by the
client pointer device, use gdk_drag_begin_for_device() to
begin a drag with a different device.
This function is called by the drag source.
| 
 | the source window for this drag. | 
| 
 | the offered targets, as list of GdkAtoms. [transfer none][element-type GdkAtom] | 
| Returns : | a newly created GdkDragContext. [transfer full] | 
GdkDragContext * gdk_drag_begin_for_device (GdkWindow *window,GdkDevice *device,GList *targets);
Starts a drag and creates a new drag context for it.
This function is called by the drag source.
| 
 | the source window for this drag | 
| 
 | the device that controls this drag | 
| 
 | the offered targets, as list of GdkAtoms. [transfer none][element-type GdkAtom] | 
| Returns : | a newly created GdkDragContext. [transfer full] | 
gboolean gdk_drag_motion (GdkDragContext *context,GdkWindow *dest_window,GdkDragProtocol protocol,gint x_root,gint y_root,GdkDragAction suggested_action,GdkDragAction possible_actions,guint32 time_);
Updates the drag context when the pointer moves or the set of actions changes.
This function is called by the drag source.
| 
 | a GdkDragContext | 
| 
 | the new destination window, obtained by gdk_drag_find_window() | 
| 
 | the DND protocol in use, obtained by gdk_drag_find_window() | 
| 
 | the x position of the pointer in root coordinates | 
| 
 | the y position of the pointer in root coordinates | 
| 
 | the suggested action | 
| 
 | the possible actions | 
| 
 | the timestamp for this operation | 
| Returns : | 
void gdk_drop_finish (GdkDragContext *context,gboolean success,guint32 time_);
Ends the drag operation after a drop.
This function is called by the drag destination.
| 
 | a GtkDragContext | 
| 
 | TRUEif the data was successfully received | 
| 
 | the timestamp for this operation | 
GdkNativeWindow gdk_drag_get_protocol_for_display (GdkDisplay *display,GdkNativeWindow xid,GdkDragProtocol *protocol);
Finds out the DND protocol supported by a window.
| 
 | the GdkDisplay where the destination window resides | 
| 
 | the windowing system id of the destination window. | 
| 
 | location where the supported DND protocol is returned. | 
| Returns : | the windowing system id of the window where the drop
   should happen. This may be xidor the id of a proxy window,
   or zero ifxiddoes not support Drag and Drop. | 
Since 2.2
typedef enum
{
  GDK_DRAG_PROTO_MOTIF,
  GDK_DRAG_PROTO_XDND,
  GDK_DRAG_PROTO_ROOTWIN,
  GDK_DRAG_PROTO_NONE,
  GDK_DRAG_PROTO_WIN32_DROPFILES,
  GDK_DRAG_PROTO_OLE2,
  GDK_DRAG_PROTO_LOCAL
} GdkDragProtocol;
Used in GdkDragContext to indicate the protocol according to which DND is done.
| The Motif DND protocol. | |
| The Xdnd protocol. | |
| An extension to the Xdnd protocol for unclaimed root window drops. | |
| no protocol. | |
| The simple WM_DROPFILES protocol. | |
| The complex OLE2 DND protocol (not implemented). | |
| Intra-application DND. | 
typedef enum
{
  GDK_ACTION_DEFAULT = 1 << 0,
  GDK_ACTION_COPY    = 1 << 1,
  GDK_ACTION_MOVE    = 1 << 2,
  GDK_ACTION_LINK    = 1 << 3,
  GDK_ACTION_PRIVATE = 1 << 4,
  GDK_ACTION_ASK     = 1 << 5
} GdkDragAction;
Used in GdkDragContext to indicate what the destination should do with the dropped data.
| Means nothing, and should not be used. | |
| Copy the data. | |
| Move the data, i.e. first copy it, then delete it from the source using the DELETE target of the X selection protocol. | |
| Add a link to the data. Note that this is only useful if source and destination agree on what it means. | |
| Special action which tells the source that the destination will do something that the source doesn't understand. | |
| Ask the user what to do with the data. | 
void gdk_drag_status (GdkDragContext *context,GdkDragAction action,guint32 time_);
Selects one of the actions offered by the drag source.
This function is called by the drag destination in response to
gdk_drag_motion() called by the drag source.
| 
 | a GdkDragContext | 
| 
 | the selected action which will be taken when a drop happens, or 0 to indicate that a drop will not be accepted | 
| 
 | the timestamp for this operation | 
gboolean            gdk_drag_drop_succeeded             (GdkDragContext *context);
Returns whether the dropped data has been successfully
transferred. This function is intended to be used while
handling a GDK_DROP_FINISHED event, its return value is
meaningless at other times.
| 
 | a GdkDragContext | 
| Returns : | TRUEif the drop was successful. | 
Since 2.6
GdkDragAction       gdk_drag_context_get_actions        (GdkDragContext *context);
Determines the bitmask of actions proposed by the source if
gdk_drag_context_suggested_action() returns GDK_ACTION_ASK.
| 
 | a GdkDragContext | 
| Returns : | the GdkDragAction flags | 
Since 2.22
GdkDragAction       gdk_drag_context_get_suggested_action
                                                        (GdkDragContext *context);
Determines the suggested drag action of the context.
| 
 | a GdkDragContext | 
| Returns : | a GdkDragAction value | 
Since 2.22
GdkDragAction       gdk_drag_context_get_selected_action
                                                        (GdkDragContext *context);
Determines the action chosen by the drag destination.
| 
 | a GdkDragContext | 
| Returns : | a GdkDragAction value | 
Since 2.22
GList *             gdk_drag_context_list_targets       (GdkDragContext *context);
Retrieves the list of targets of the context.
| 
 | a GdkDragContext | 
| Returns : | a GList of targets. [transfer none][element-type GdkAtom] | 
Since 2.22
GdkDevice *         gdk_drag_context_get_device         (GdkDragContext *context);
Returns the GdkDevice associated to the drag context.
| 
 | a GdkDragContext | 
| Returns : | The GdkDevice associated to context. [transfer none] | 
void gdk_drag_context_set_device (GdkDragContext *context,GdkDevice *device);
Associates a GdkDevice to context, so all Drag and Drop events
for context are emitted as if they came from this device.
| 
 | a GdkDragContext | 
| 
 | a GdkDevice | 
GdkWindow *         gdk_drag_context_get_source_window  (GdkDragContext *context);
Returns the GdkWindow where the DND operation started.
| 
 | a GdkDragContext | 
| Returns : | a GdkWindow. [transfer none] | 
Since 2.22
GdkWindow *         gdk_drag_context_get_dest_window    (GdkDragContext *context);
Returns the destination windw for the DND operation.
| 
 | a GdkDragContext | 
| Returns : | a GdkWindow. [transfer none] | 
Since 3.0
GdkDragProtocol     gdk_drag_context_get_protocol       (GdkDragContext *context);
Returns the drag protocol thats used by this context.
| 
 | a GdkDragContext | 
| Returns : | the drag protocol | 
Since 3.0