Merge pull request #224 from jorix/3402-touch_logic_to_superclass
Move some touch logic to the `handler` base class
This commit is contained in:
@@ -669,6 +669,64 @@
|
||||
map.destroy();
|
||||
}
|
||||
|
||||
function test_touchstart(t) {
|
||||
// a test to verify that the touchstart function does
|
||||
// unregister the mouse listeners when it's called the
|
||||
// first time
|
||||
|
||||
t.plan(7);
|
||||
|
||||
// set up
|
||||
|
||||
var map = new OpenLayers.Map("map", {
|
||||
controls: []
|
||||
});
|
||||
var control = new OpenLayers.Control({});
|
||||
var handler = new OpenLayers.Handler.Click(control, {});
|
||||
control.handler = handler;
|
||||
map.addControl(control);
|
||||
handler.activate();
|
||||
|
||||
function allRegistered() {
|
||||
var eventTypes = ['mousedown', 'mouseup', 'click', 'dblclick'],
|
||||
eventType,
|
||||
listeners,
|
||||
listener,
|
||||
flag;
|
||||
for(var i=0, ilen=eventTypes.length; i<ilen; i++) {
|
||||
flag = false;
|
||||
eventType = eventTypes[i];
|
||||
listeners = map.events.listeners[eventType];
|
||||
for(var j=0, jlen=listeners.length; j<jlen; j++) {
|
||||
listener = listeners[j];
|
||||
if(listener.func === handler[eventType] && listener.obj === handler) {
|
||||
flag = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
if(!flag) {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
// test
|
||||
|
||||
t.ok(allRegistered(), 'mouse listeners are registered');
|
||||
handler.touchstart({xy: new OpenLayers.Pixel(0, 0)});
|
||||
t.eq(map.events.listeners.mousedown.length, 0,"mousedown is not registered");
|
||||
t.eq(map.events.listeners.mouseup.length, 0,"mouseup is not registered");
|
||||
t.eq(map.events.listeners.click.length, 0,"click is not registered");
|
||||
t.eq(map.events.listeners.dblclick.length, 0,"dblclick is not registered");
|
||||
|
||||
t.ok(handler.touch, 'handler.touch is set');
|
||||
|
||||
handler.deactivate();
|
||||
t.ok(!handler.touch, 'handler.touch is not set');
|
||||
|
||||
map.destroy();
|
||||
}
|
||||
</script>
|
||||
</head>
|
||||
<body>
|
||||
|
||||
@@ -288,7 +288,7 @@
|
||||
// "touchend" events set expected states in the drag handler.
|
||||
// We also verify that we prevent the default as appropriate.
|
||||
|
||||
t.plan(14);
|
||||
t.plan(19);
|
||||
|
||||
// set up
|
||||
|
||||
@@ -318,6 +318,11 @@
|
||||
t.eq(h.start.y, 0, '[touchstart] start.y is correct');
|
||||
t.eq(log.length, 1, '[touchstart] one item in log');
|
||||
t.ok(log[0] === e, "touchstart", '[touchstart] event is stopped');
|
||||
t.eq(m.events.listeners.mousedown.length, 0,"mousedown is not registered");
|
||||
t.eq(m.events.listeners.mouseup.length, 0,"mouseup is not registered");
|
||||
t.eq(m.events.listeners.mousemove.length, 0,"mousemove is not registered");
|
||||
t.eq(m.events.listeners.click.length, 0,"click is not registered");
|
||||
t.eq(m.events.listeners.mouseout.length, 0,"mouseout is not registered");
|
||||
|
||||
e = {xy: new Px(1, 1)};
|
||||
m.events.triggerEvent('touchmove', e);
|
||||
|
||||
@@ -280,9 +280,10 @@
|
||||
handler.mousedown = function() {}; // mock mousedown
|
||||
handler.activate();
|
||||
|
||||
var eventTypes = ['mousedown', 'mouseup', 'mousemove', 'click', 'dblclick'];
|
||||
|
||||
function allRegistered() {
|
||||
var eventTypes = ['mousedown', 'mouseup', 'mousemove', 'click', 'dblclick'],
|
||||
eventType,
|
||||
var eventType,
|
||||
listeners,
|
||||
listener,
|
||||
flag;
|
||||
@@ -305,21 +306,18 @@
|
||||
}
|
||||
|
||||
function noneRegistered() {
|
||||
var eventTypes = ['mousedown', 'mouseup', 'mousemove', 'click', 'dblclick'],
|
||||
eventType,
|
||||
listeners,
|
||||
listener;
|
||||
var eventType,
|
||||
times,
|
||||
flag = false;
|
||||
for(var i=0, ilen=eventTypes.length; i<ilen; i++) {
|
||||
eventType = eventTypes[i];
|
||||
listeners = map.events.listeners[eventType];
|
||||
for(var j=0, jlen=listeners.length; j<jlen; j++) {
|
||||
listener = listeners[j];
|
||||
if(listener.func === handler[eventType] && listener.obj === handler) {
|
||||
return false;
|
||||
}
|
||||
times = map.events.listeners[eventType].length;
|
||||
if (times != 0) {
|
||||
t.fail(eventType + " is registered " + times + " times");
|
||||
flag = true;
|
||||
}
|
||||
}
|
||||
return true;
|
||||
return !flag;
|
||||
}
|
||||
|
||||
// test
|
||||
|
||||
@@ -407,7 +407,8 @@
|
||||
// set up
|
||||
|
||||
var map = new OpenLayers.Map("map", {
|
||||
resolutions: [1]
|
||||
resolutions: [1],
|
||||
controls: []
|
||||
});
|
||||
var layer = new OpenLayers.Layer.Vector("foo", {
|
||||
maxExtent: new OpenLayers.Bounds(-10, -10, 10, 10),
|
||||
@@ -421,9 +422,11 @@
|
||||
map.setCenter(new OpenLayers.LonLat(0, 0), 0);
|
||||
handler.activate();
|
||||
|
||||
var eventTypes = ['mousedown', 'mouseup', 'mousemove', 'click', 'dblclick',
|
||||
'mouseout'];
|
||||
|
||||
function allRegistered() {
|
||||
var eventTypes = ['mousedown', 'mouseup', 'mousemove', 'click', 'dblclick'],
|
||||
eventType,
|
||||
var eventType,
|
||||
listeners,
|
||||
listener,
|
||||
flag;
|
||||
@@ -446,23 +449,21 @@
|
||||
}
|
||||
|
||||
function noneRegistered() {
|
||||
var eventTypes = ['mousedown', 'mouseup', 'mousemove', 'click', 'dblclick'],
|
||||
eventType,
|
||||
listeners,
|
||||
listener;
|
||||
var eventType,
|
||||
times,
|
||||
flag = false;
|
||||
for(var i=0, ilen=eventTypes.length; i<ilen; i++) {
|
||||
eventType = eventTypes[i];
|
||||
listeners = map.events.listeners[eventType];
|
||||
for(var j=0, jlen=listeners.length; j<jlen; j++) {
|
||||
listener = listeners[j];
|
||||
if(listener.func === handler[eventType] && listener.obj === handler) {
|
||||
return false;
|
||||
}
|
||||
times = map.events.listeners[eventType].length;
|
||||
if (times != 0) {
|
||||
t.fail(eventType + " is registered " + times + " times");
|
||||
flag = true;
|
||||
}
|
||||
}
|
||||
return true;
|
||||
return !flag;
|
||||
}
|
||||
|
||||
|
||||
// test
|
||||
|
||||
t.ok(allRegistered(), 'mouse listeners are registered');
|
||||
|
||||
Reference in New Issue
Block a user