When we get a motion notify event, only set of a drag in the core if the mouse has moved at least 5px from where it was pressed.

svn path=/trunk/netsurf/; revision=11076
This commit is contained in:
Michael Drake 2010-12-16 20:30:10 +00:00
parent b067265bd3
commit ad7283780d

View File

@ -25,6 +25,7 @@
#include <gdk/gdkkeysyms.h> #include <gdk/gdkkeysyms.h>
#include <gtk/gtk.h> #include <gtk/gtk.h>
#include <stdio.h> #include <stdio.h>
#include <limits.h>
#include "desktop/tree.h" #include "desktop/tree.h"
#include "desktop/tree_url_node.h" #include "desktop/tree_url_node.h"
@ -41,6 +42,7 @@ struct nsgtk_treeview {
GtkDrawingArea *drawing_area; GtkDrawingArea *drawing_area;
int mouse_pressed_x; int mouse_pressed_x;
int mouse_pressed_y; int mouse_pressed_y;
int last_x, last_y;
browser_mouse_state mouse_state; browser_mouse_state mouse_state;
struct tree *tree; struct tree *tree;
}; };
@ -265,6 +267,11 @@ gboolean nsgtk_tree_window_button_press_event(GtkWidget *widget,
if (event->state & GDK_MOD1_MASK) if (event->state & GDK_MOD1_MASK)
tw->mouse_state |= BROWSER_MOUSE_MOD_3; tw->mouse_state |= BROWSER_MOUSE_MOD_3;
/* Record where we pressed, for use when determining whether to start
* a drag in motion notify events. */
tw->last_x = event->x;
tw->last_y = event->y;
tree_mouse_action(tree, tw->mouse_state, event->x, event->y); tree_mouse_action(tree, tw->mouse_state, event->x, event->y);
return TRUE; return TRUE;
@ -335,6 +342,17 @@ gboolean nsgtk_tree_window_motion_notify_event(GtkWidget *widget,
struct nsgtk_treeview *tw = (struct nsgtk_treeview *) g; struct nsgtk_treeview *tw = (struct nsgtk_treeview *) g;
struct tree *tree = tw->tree; struct tree *tree = tw->tree;
if ((abs(event->x - tw->last_x) < 5) &&
(abs(event->y - tw->last_y) < 5)) {
/* Mouse hasn't moved far enough from press coordinate for this
* to be considered a drag. */
return FALSE;
} else {
/* This is a drag, ensure it's always treated as such, even if
* we drag back over the press location */
tw->last_x = INT_MIN;
tw->last_y = INT_MIN;
}
/* Handle modifiers being removed */ /* Handle modifiers being removed */
if (tw->mouse_state & BROWSER_MOUSE_MOD_1 && !shift) if (tw->mouse_state & BROWSER_MOUSE_MOD_1 && !shift)