Commit a4ec2f5c authored by samhed's avatar samhed

Limited the double click fix to touch devices.

parent b2f1961a
...@@ -491,7 +491,7 @@ var that = {}, // Public API methods ...@@ -491,7 +491,7 @@ var that = {}, // Public API methods
mouseCaptured = false; mouseCaptured = false;
var doubleClickTimer = null, var doubleClickTimer = null,
lastClickPos = null; lastTouchPos = null;
// Configuration attributes // Configuration attributes
Util.conf_defaults(conf, that, defaults, [ Util.conf_defaults(conf, that, defaults, [
...@@ -537,29 +537,29 @@ function onMouseButton(e, down) { ...@@ -537,29 +537,29 @@ function onMouseButton(e, down) {
evt = (e ? e : window.event); evt = (e ? e : window.event);
pos = Util.getEventPosition(e, conf.target, conf.scale); pos = Util.getEventPosition(e, conf.target, conf.scale);
// When two clicks occur within 500 ms of each other and are if (e.touches || e.changedTouches) {
// Touch device
// When two touches occur within 500 ms of each other and are
// closer than 50 pixels together a double click is triggered. // closer than 50 pixels together a double click is triggered.
if (down == 1) { if (down == 1) {
if (doubleClickTimer == null) { if (doubleClickTimer == null) {
lastClickPos = pos; lastTouchPos = pos;
} else { } else {
clearTimeout(doubleClickTimer); clearTimeout(doubleClickTimer);
var xs = lastClickPos.x - pos.x; var xs = lastTouchPos.x - pos.x;
var ys = lastClickPos.y - pos.y; var ys = lastTouchPos.y - pos.y;
var d = Math.sqrt((xs * xs) + (ys * ys)); var d = Math.sqrt((xs * xs) + (ys * ys));
// When the distance between the two clicks is less than 50 pixels // When the distance between the two touches is less than 50 pixels
// force the position of the latter click to the position of the first // force the position of the latter touch to the position of the first
if (d < 50) { if (d < 50) {
pos = lastClickPos; pos = lastTouchPos;
} }
} }
doubleClickTimer = setTimeout(resetDoubleClickTimer, 500); doubleClickTimer = setTimeout(resetDoubleClickTimer, 500);
} }
if (e.touches || e.changedTouches) {
// Touch device
bmask = conf.touchButton; bmask = conf.touchButton;
// If bmask is set // If bmask is set
} else if (evt.which) { } else if (evt.which) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment