# HG changeset patch # User nenolod # Date 1147630201 25200 # Node ID d122e3abf61cdaadf135ea80c982513109575510 # Parent 286156196e16c3b04a2794a30ee617edc811b404 [svn] - make mainwin moveable again diff -r 286156196e16 -r d122e3abf61c audacious/mainwin.c --- a/audacious/mainwin.c Sun May 14 10:31:46 2006 -0700 +++ b/audacious/mainwin.c Sun May 14 11:10:01 2006 -0700 @@ -998,10 +998,9 @@ gdk_flush(); - if (mainwin_menurow->mr_doublesize_selected) { - event->x /= 2; - event->y /= 2; - } + gtk_object_remove_data(GTK_OBJECT(mainwin), "is_moving"); + gtk_object_remove_data(GTK_OBJECT(mainwin), "offset_x"); + gtk_object_remove_data(GTK_OBJECT(mainwin), "offset_y"); handle_release_cb(mainwin_wlist, widget, event); @@ -1037,8 +1036,25 @@ state = event->state; } - handle_motion_cb(mainwin_wlist, widget, event); - draw_main_window(FALSE); + if (gtk_object_get_data(GTK_OBJECT(mainwin), "is_moving")) + { + gint offset_x, offset_y, mx, my; + + offset_x = GPOINTER_TO_INT(gtk_object_get_data(GTK_OBJECT(mainwin), "offset_x")); + offset_y = GPOINTER_TO_INT(gtk_object_get_data(GTK_OBJECT(mainwin), "offset_y")); + + gdk_window_get_pointer(NULL, &x, &y, NULL); + + mx = x - offset_x; + my = y - offset_y; + + gtk_window_move(GTK_WINDOW(mainwin), mx, my); + } + else + { + handle_motion_cb(mainwin_wlist, widget, event); + draw_main_window(FALSE); + } gdk_flush(); @@ -1118,7 +1134,16 @@ grab = FALSE; } else + { + gint mx, my; + + gdk_window_get_pointer(GDK_WINDOW(mainwin->window), &mx, &my, NULL); + gtk_object_set_data(GTK_OBJECT(mainwin), "offset_x", GINT_TO_POINTER(mx)); + gtk_object_set_data(GTK_OBJECT(mainwin), "offset_y", GINT_TO_POINTER(my)); + + gtk_object_set_data(GTK_OBJECT(mainwin), "is_moving", GINT_TO_POINTER(1)); gtk_window_present(GTK_WINDOW(mainwin)); + } } else if (event->button == 1 && event->type == GDK_2BUTTON_PRESS && event->y < 14 && !inside_sensitive_widgets(event->x, event->y)) {