mirror of
https://github.com/openseadragon/openseadragon.git
synced 2024-11-22 21:26:10 +03:00
Initial commit - Multi-touch, pointer event MouseTracker
This commit is contained in:
parent
13fa798e52
commit
c7ea247baa
2294
src/mousetracker.js
2294
src/mousetracker.js
File diff suppressed because it is too large
Load Diff
@ -998,6 +998,21 @@ window.OpenSeadragon = window.OpenSeadragon || function( options ){
|
|||||||
},
|
},
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Determines if a point is within the bounding rectangle of the given element (hit-test).
|
||||||
|
* @function
|
||||||
|
* @param {Element|String} element
|
||||||
|
* @param {OpenSeadragon.Point} point
|
||||||
|
* @returns {Boolean}
|
||||||
|
*/
|
||||||
|
pointInElement: function( element, point ) {
|
||||||
|
element = $.getElement( element );
|
||||||
|
var offset = $.getElementOffset( element ),
|
||||||
|
size = $.getElementSize( element );
|
||||||
|
return point.x >= offset.x && point.x < offset.x + size.x && point.y < offset.y + size.y && point.y >= offset.y;
|
||||||
|
},
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the latest event, really only useful internally since its
|
* Gets the latest event, really only useful internally since its
|
||||||
* specific to IE behavior.
|
* specific to IE behavior.
|
||||||
|
@ -270,7 +270,14 @@ $.Viewer = function( options ) {
|
|||||||
style.position = "absolute";
|
style.position = "absolute";
|
||||||
style.top = "0px";
|
style.top = "0px";
|
||||||
style.left = "0px";
|
style.left = "0px";
|
||||||
}( this.canvas.style ));
|
// Disable browser default touch handling
|
||||||
|
if (style["touch-action"] !== undefined) {
|
||||||
|
style["touch-action"] = "none";
|
||||||
|
}
|
||||||
|
else if (style["-ms-touch-action"] !== undefined) {
|
||||||
|
style["-ms-touch-action"] = "none";
|
||||||
|
}
|
||||||
|
}(this.canvas.style));
|
||||||
|
|
||||||
//the container is created through applying the ControlDock constructor above
|
//the container is created through applying the ControlDock constructor above
|
||||||
this.container.className = "openseadragon-container";
|
this.container.className = "openseadragon-container";
|
||||||
@ -378,7 +385,8 @@ $.Viewer = function( options ) {
|
|||||||
clickHandler: $.delegate( this, onCanvasClick ),
|
clickHandler: $.delegate( this, onCanvasClick ),
|
||||||
dragHandler: $.delegate( this, onCanvasDrag ),
|
dragHandler: $.delegate( this, onCanvasDrag ),
|
||||||
releaseHandler: $.delegate( this, onCanvasRelease ),
|
releaseHandler: $.delegate( this, onCanvasRelease ),
|
||||||
scrollHandler: $.delegate( this, onCanvasScroll )
|
scrollHandler: $.delegate( this, onCanvasScroll ),
|
||||||
|
pinchHandler: $.delegate( this, onCanvasPinch )
|
||||||
}).setTracking( this.mouseNavEnabled ? true : false ); // default state
|
}).setTracking( this.mouseNavEnabled ? true : false ); // default state
|
||||||
|
|
||||||
this.outerTracker = new $.MouseTracker({
|
this.outerTracker = new $.MouseTracker({
|
||||||
@ -1817,7 +1825,7 @@ function onCanvasScroll( event ) {
|
|||||||
this.viewport.applyConstraints();
|
this.viewport.applyConstraints();
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
* Raised when a scroll event occurs on the {@link OpenSeadragon.Viewer#canvas} element (mouse wheel, touch pinch, etc.).
|
* Raised when a scroll event occurs on the {@link OpenSeadragon.Viewer#canvas} element (mouse wheel).
|
||||||
*
|
*
|
||||||
* @event canvas-scroll
|
* @event canvas-scroll
|
||||||
* @memberof OpenSeadragon.Viewer
|
* @memberof OpenSeadragon.Viewer
|
||||||
@ -1841,7 +1849,41 @@ function onCanvasScroll( event ) {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
function onContainerExit( event ) {
|
function onCanvasPinch(event) {
|
||||||
|
if (!event.preventDefaultAction && this.viewport) {
|
||||||
|
//TODO This is temporary for testing. Zoom should track pinch gesture one-to-one, around center point!
|
||||||
|
this.viewport.zoomBy(
|
||||||
|
( event.delta > 0 ) ? 1.2 : 0.8,
|
||||||
|
this.viewport.pointFromPixel(event.position, true)
|
||||||
|
);
|
||||||
|
this.viewport.applyConstraints();
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* Raised when a pinch event occurs on the {@link OpenSeadragon.Viewer#canvas} element.
|
||||||
|
*
|
||||||
|
* @event canvas-pinch
|
||||||
|
* @memberof OpenSeadragon.Viewer
|
||||||
|
* @type {object}
|
||||||
|
* @property {OpenSeadragon.Viewer} eventSource - A reference to the Viewer which raised this event.
|
||||||
|
* @property {OpenSeadragon.MouseTracker} tracker - A reference to the MouseTracker which originated this event.
|
||||||
|
* @property {OpenSeadragon.Point} position - The position of the event relative to the tracked element.
|
||||||
|
* @property {Number} delta - The pinch delta for the event.
|
||||||
|
* @property {Boolean} shift - True if the shift key was pressed during this event.
|
||||||
|
* @property {Object} originalEvent - The original DOM event.
|
||||||
|
* @property {?Object} userData - Arbitrary subscriber-defined object.
|
||||||
|
*/
|
||||||
|
this.raiseEvent('canvas-pinch', {
|
||||||
|
tracker: event.eventSource,
|
||||||
|
position: event.position,
|
||||||
|
delta: event.delta,
|
||||||
|
shift: event.shift,
|
||||||
|
originalEvent: event.originalEvent
|
||||||
|
});
|
||||||
|
//cancels event
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
function onContainerExit(event) {
|
||||||
if ( !event.insideElementPressed ) {
|
if ( !event.insideElementPressed ) {
|
||||||
THIS[ this.hash ].mouseInside = false;
|
THIS[ this.hash ].mouseInside = false;
|
||||||
if ( !THIS[ this.hash ].animating ) {
|
if ( !THIS[ this.hash ].animating ) {
|
||||||
|
Loading…
Reference in New Issue
Block a user