Consider the case of a draggable div in a scrollable region. When you touch inside the div, further finger movements should drag the div around the region. When you touch outside the div, further finger movements should pan the scrollable region.
I have a JSFiddle which illustrates this. With the mouse, I can drag the div around easily, but touch events don't seem to work as well.
Note: I'm using pointer events in the fiddle, so if you're using a browser that doesn't support them, it might seem like the fiddle is broken.
Does anyone know how to properly implement this interaction?
http://jsfiddle.net/mrmills/13t34jsv/
HTML:
<div id="scroll-outer">
<div id="scroll-inner">
<div id="handle">
</div>
</div>
</div>
CSS:
#scroll-outer { width: 400px; height: 400px; overflow: auto }
#scroll-inner { width: 2000px; height: 2000px }
#handle { width: 44px; height: 44px; background-color: rgba(0,0,0,0.5) }
JS:
function pointerDown(ev) {
scrollInner.addEventListener("pointermove", pointerMove);
scrollInner.addEventListener("pointerup", pointerUp);
dragStartX = ev.pageX; dragStartY = ev.pageY;
}
function pointerMove(ev) {
handle.style.transform = "translate3d(" +
(x + ev.pageX - dragStartX) + "px, " +
(y + ev.pageY - dragStartY) + "px, 0)";
}
function pointerUp(ev) {
scrollInner.removeEventListener("pointermove", pointerMove);
scrollInner.removeEventListener("pointerup", pointerUp);
x = x + ev.pageX - dragStartX;
y = y + ev.pageY - dragStartY;
}
var x = 0;
var y = 0;
var dragStartX = 0;
var dragStartY = 0;
var handle = document.getElementById("handle");
var scrollInner = document.getElementById("scroll-inner");
handle.addEventListener("pointerdown", pointerDown);