[gtk+/gtk-3-22] Refine the listbox dnd example
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/gtk-3-22] Refine the listbox dnd example
- Date: Sat, 22 Apr 2017 12:07:58 +0000 (UTC)
commit 7ab48458a0fe894eb1ee9e629c68b34b2d1c9205
Author: Matthias Clasen <mclasen redhat com>
Date: Sat Apr 22 08:03:00 2017 -0400
Refine the listbox dnd example
Add a drag handle, and demonstrate broken offsets.
tests/testlist3.c | 31 ++++++++++++++++++++-----------
1 files changed, 20 insertions(+), 11 deletions(-)
---
diff --git a/tests/testlist3.c b/tests/testlist3.c
index 96c6945..32558dc 100644
--- a/tests/testlist3.c
+++ b/tests/testlist3.c
@@ -9,17 +9,23 @@ drag_begin (GtkWidget *widget,
GdkDragContext *context,
gpointer data)
{
+ GtkWidget *row;
GtkAllocation alloc;
cairo_surface_t *surface;
cairo_t *cr;
+ int x, y;
- gtk_widget_get_allocation (widget, &alloc);
+ row = gtk_widget_get_ancestor (widget, GTK_TYPE_LIST_BOX_ROW);
+ gtk_widget_get_allocation (row, &alloc);
surface = cairo_image_surface_create (CAIRO_FORMAT_ARGB32, alloc.width, alloc.height);
cr = cairo_create (surface);
- gtk_style_context_add_class (gtk_widget_get_style_context (widget), "during-dnd");
- gtk_widget_draw (widget, cr);
- gtk_style_context_remove_class (gtk_widget_get_style_context (widget), "during-dnd");
+ gtk_style_context_add_class (gtk_widget_get_style_context (row), "during-dnd");
+ gtk_widget_draw (row, cr);
+ gtk_style_context_remove_class (gtk_widget_get_style_context (row), "during-dnd");
+
+ gtk_widget_translate_coordinates (widget, row, 0, 0, &x, &y);
+ cairo_surface_set_device_offset (surface, -x, -y);
gtk_drag_set_icon_surface (context, surface);
cairo_destroy (cr);
@@ -58,7 +64,7 @@ drag_data_received (GtkWidget *widget,
GtkWidget *source;
int pos;
- target = gtk_widget_get_ancestor (widget, GTK_TYPE_LIST_BOX_ROW);
+ target = widget;
pos = gtk_list_box_row_get_index (GTK_LIST_BOX_ROW (target));
row = (gpointer)* (gpointer*)gtk_selection_data_get_data (selection_data);
@@ -73,22 +79,25 @@ drag_data_received (GtkWidget *widget,
static GtkWidget *
create_row (const gchar *text)
{
- GtkWidget *row, *ebox, *box, *label;
+ GtkWidget *row, *ebox, *box, *label, *image;
row = gtk_list_box_row_new ();
ebox = gtk_event_box_new ();
+ image = gtk_image_new_from_icon_name ("open-menu-symbolic", 1);
+ gtk_container_add (GTK_CONTAINER (ebox), image);
box = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 10);
+ g_object_set (box, "margin-start", 10, "margin-end", 10, NULL);
label = gtk_label_new (text);
- gtk_container_add (GTK_CONTAINER (row), ebox);
- gtk_container_add (GTK_CONTAINER (ebox), box);
- gtk_container_add (GTK_CONTAINER (box), label);
+ gtk_container_add (GTK_CONTAINER (row), box);
+ gtk_box_pack_start (GTK_BOX (box), label, TRUE, FALSE, 0);
+ gtk_container_add (GTK_CONTAINER (box), ebox);
gtk_drag_source_set (ebox, GDK_BUTTON1_MASK, entries, 1, GDK_ACTION_MOVE);
g_signal_connect (ebox, "drag-begin", G_CALLBACK (drag_begin), NULL);
g_signal_connect (ebox, "drag-data-get", G_CALLBACK (drag_data_get), NULL);
- gtk_drag_dest_set (ebox, GTK_DEST_DEFAULT_ALL, entries, 1, GDK_ACTION_MOVE);
- g_signal_connect (ebox, "drag-data-received", G_CALLBACK (drag_data_received), NULL);
+ gtk_drag_dest_set (row, GTK_DEST_DEFAULT_ALL, entries, 1, GDK_ACTION_MOVE);
+ g_signal_connect (row, "drag-data-received", G_CALLBACK (drag_data_received), NULL);
return row;
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]