2014-02-28 13:15:01 -05:00
|
|
|
/**
|
|
|
|
* _Internal Class_, not generally used outside of the engine's internals.
|
|
|
|
*
|
|
|
|
* @class Mouse
|
|
|
|
*/
|
|
|
|
|
2014-02-19 09:15:05 -05:00
|
|
|
var Mouse;
|
|
|
|
|
|
|
|
(function() {
|
|
|
|
|
2014-02-28 13:15:01 -05:00
|
|
|
/**
|
|
|
|
* Description
|
|
|
|
* @param {HTMLElement} element
|
|
|
|
*/
|
2014-02-19 09:15:05 -05:00
|
|
|
Mouse = function(element) {
|
|
|
|
var mouse = this;
|
|
|
|
|
2014-03-26 07:46:43 -04:00
|
|
|
this.element = element || document.body;
|
2014-05-03 13:45:48 -04:00
|
|
|
this.absolute = { x: 0, y: 0 };
|
2014-02-19 09:15:05 -05:00
|
|
|
this.position = { x: 0, y: 0 };
|
|
|
|
this.mousedownPosition = { x: 0, y: 0 };
|
|
|
|
this.mouseupPosition = { x: 0, y: 0 };
|
2014-05-01 08:40:45 -04:00
|
|
|
this.offset = { x: 0, y: 0 };
|
2014-05-03 13:45:48 -04:00
|
|
|
this.scale = { x: 1, y: 1 };
|
2014-02-19 09:15:05 -05:00
|
|
|
this.button = -1;
|
2014-03-14 15:36:58 -04:00
|
|
|
|
|
|
|
this.sourceEvents = {
|
|
|
|
mousemove: null,
|
|
|
|
mousedown: null,
|
|
|
|
mouseup: null
|
|
|
|
};
|
2014-02-19 09:15:05 -05:00
|
|
|
|
2014-03-26 07:46:43 -04:00
|
|
|
this.mousemove = function(event) {
|
|
|
|
var position = _getRelativeMousePosition(event, mouse.element),
|
2014-02-19 09:15:05 -05:00
|
|
|
touches = event.changedTouches;
|
|
|
|
|
|
|
|
if (touches) {
|
|
|
|
mouse.button = 0;
|
|
|
|
event.preventDefault();
|
|
|
|
}
|
|
|
|
|
2014-05-03 13:45:48 -04:00
|
|
|
mouse.absolute.x = position.x;
|
|
|
|
mouse.absolute.y = position.y;
|
2014-05-04 07:37:04 -04:00
|
|
|
mouse.position.x = mouse.absolute.x * mouse.scale.x + mouse.offset.x;
|
|
|
|
mouse.position.y = mouse.absolute.y * mouse.scale.y + mouse.offset.y;
|
2014-03-14 15:36:58 -04:00
|
|
|
mouse.sourceEvents.mousemove = event;
|
2014-02-19 09:15:05 -05:00
|
|
|
};
|
|
|
|
|
2014-03-26 07:46:43 -04:00
|
|
|
this.mousedown = function(event) {
|
|
|
|
var position = _getRelativeMousePosition(event, mouse.element),
|
2014-02-19 09:15:05 -05:00
|
|
|
touches = event.changedTouches;
|
|
|
|
|
|
|
|
if (touches) {
|
|
|
|
mouse.button = 0;
|
|
|
|
event.preventDefault();
|
|
|
|
} else {
|
|
|
|
mouse.button = event.button;
|
|
|
|
}
|
|
|
|
|
2014-05-03 13:45:48 -04:00
|
|
|
mouse.absolute.x = position.x;
|
|
|
|
mouse.absolute.y = position.y;
|
2014-05-04 07:37:04 -04:00
|
|
|
mouse.position.x = mouse.absolute.x * mouse.scale.x + mouse.offset.x;
|
|
|
|
mouse.position.y = mouse.absolute.y * mouse.scale.y + mouse.offset.y;
|
2014-05-03 13:45:48 -04:00
|
|
|
mouse.mousedownPosition.x = mouse.position.x;
|
|
|
|
mouse.mousedownPosition.y = mouse.position.y;
|
2014-03-14 15:36:58 -04:00
|
|
|
mouse.sourceEvents.mousedown = event;
|
2014-02-19 09:15:05 -05:00
|
|
|
};
|
|
|
|
|
2014-03-26 07:46:43 -04:00
|
|
|
this.mouseup = function(event) {
|
|
|
|
var position = _getRelativeMousePosition(event, mouse.element),
|
2014-02-19 09:15:05 -05:00
|
|
|
touches = event.changedTouches;
|
|
|
|
|
|
|
|
if (touches) {
|
|
|
|
event.preventDefault();
|
|
|
|
}
|
|
|
|
|
|
|
|
mouse.button = -1;
|
2014-05-03 13:45:48 -04:00
|
|
|
mouse.absolute.x = position.x;
|
|
|
|
mouse.absolute.y = position.y;
|
2014-05-04 07:37:04 -04:00
|
|
|
mouse.position.x = mouse.absolute.x * mouse.scale.x + mouse.offset.x;
|
|
|
|
mouse.position.y = mouse.absolute.y * mouse.scale.y + mouse.offset.y;
|
2014-05-03 13:45:48 -04:00
|
|
|
mouse.mouseupPosition.x = mouse.position.x;
|
|
|
|
mouse.mouseupPosition.y = mouse.position.y;
|
2014-03-14 15:36:58 -04:00
|
|
|
mouse.sourceEvents.mouseup = event;
|
2014-02-19 09:15:05 -05:00
|
|
|
};
|
2014-03-26 07:46:43 -04:00
|
|
|
|
|
|
|
Mouse.setElement(mouse, mouse.element);
|
2014-02-19 09:15:05 -05:00
|
|
|
};
|
|
|
|
|
2014-02-28 13:15:01 -05:00
|
|
|
/**
|
|
|
|
* Description
|
|
|
|
* @method create
|
|
|
|
* @param {HTMLElement} element
|
|
|
|
* @return {mouse} A new mouse
|
|
|
|
*/
|
2014-02-19 09:15:05 -05:00
|
|
|
Mouse.create = function(element) {
|
|
|
|
return new Mouse(element);
|
|
|
|
};
|
2014-03-14 15:36:58 -04:00
|
|
|
|
2014-03-26 07:46:43 -04:00
|
|
|
/**
|
|
|
|
* Sets the element the mouse is bound to (and relative to)
|
|
|
|
* @method setElement
|
|
|
|
* @param {mouse} mouse
|
|
|
|
* @param {HTMLElement} element
|
|
|
|
*/
|
|
|
|
Mouse.setElement = function(mouse, element) {
|
|
|
|
mouse.element = element;
|
|
|
|
|
|
|
|
element.addEventListener('mousemove', mouse.mousemove);
|
|
|
|
element.addEventListener('mousedown', mouse.mousedown);
|
|
|
|
element.addEventListener('mouseup', mouse.mouseup);
|
|
|
|
|
|
|
|
element.addEventListener('touchmove', mouse.mousemove);
|
|
|
|
element.addEventListener('touchstart', mouse.mousedown);
|
|
|
|
element.addEventListener('touchend', mouse.mouseup);
|
|
|
|
};
|
|
|
|
|
2014-03-14 15:36:58 -04:00
|
|
|
/**
|
|
|
|
* Clears all captured source events
|
2014-04-01 08:45:15 -04:00
|
|
|
* @method clearSourceEvents
|
2014-03-14 15:36:58 -04:00
|
|
|
* @param {mouse} mouse
|
|
|
|
*/
|
|
|
|
Mouse.clearSourceEvents = function(mouse) {
|
|
|
|
mouse.sourceEvents.mousemove = null;
|
|
|
|
mouse.sourceEvents.mousedown = null;
|
|
|
|
mouse.sourceEvents.mouseup = null;
|
|
|
|
};
|
2014-05-03 13:45:48 -04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the offset
|
|
|
|
* @method setOffset
|
|
|
|
* @param {mouse} mouse
|
|
|
|
*/
|
|
|
|
Mouse.setOffset = function(mouse, offset) {
|
|
|
|
mouse.offset.x = offset.x;
|
|
|
|
mouse.offset.y = offset.y;
|
2014-05-04 07:37:04 -04:00
|
|
|
mouse.position.x = mouse.absolute.x * mouse.scale.x + mouse.offset.x;
|
|
|
|
mouse.position.y = mouse.absolute.y * mouse.scale.y + mouse.offset.y;
|
2014-05-03 13:45:48 -04:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the scale
|
|
|
|
* @method setScale
|
|
|
|
* @param {mouse} mouse
|
|
|
|
*/
|
|
|
|
Mouse.setScale = function(mouse, scale) {
|
|
|
|
mouse.scale.x = scale.x;
|
|
|
|
mouse.scale.y = scale.y;
|
2014-05-04 07:37:04 -04:00
|
|
|
mouse.position.x = mouse.absolute.x * mouse.scale.x + mouse.offset.x;
|
|
|
|
mouse.position.y = mouse.absolute.y * mouse.scale.y + mouse.offset.y;
|
2014-05-03 13:45:48 -04:00
|
|
|
};
|
2014-02-19 09:15:05 -05:00
|
|
|
|
2014-02-28 13:15:01 -05:00
|
|
|
/**
|
|
|
|
* Description
|
|
|
|
* @method _getRelativeMousePosition
|
|
|
|
* @private
|
|
|
|
* @param {} event
|
|
|
|
* @param {} element
|
|
|
|
* @return ObjectExpression
|
|
|
|
*/
|
2014-02-19 09:15:05 -05:00
|
|
|
var _getRelativeMousePosition = function(event, element) {
|
|
|
|
var elementBounds = element.getBoundingClientRect(),
|
2014-05-04 07:37:04 -04:00
|
|
|
rootNode = (document.documentElement || document.body.parentNode || document.body),
|
|
|
|
scrollX = (window.pageXOffset !== undefined) ? window.pageXOffset : rootNode.scrollLeft,
|
|
|
|
scrollY = (window.pageYOffset !== undefined) ? window.pageYOffset : rootNode.scrollTop,
|
2014-02-19 09:15:05 -05:00
|
|
|
touches = event.changedTouches,
|
|
|
|
x, y;
|
|
|
|
|
|
|
|
if (touches) {
|
|
|
|
x = touches[0].pageX - elementBounds.left - scrollX;
|
|
|
|
y = touches[0].pageY - elementBounds.top - scrollY;
|
|
|
|
} else {
|
|
|
|
x = event.pageX - elementBounds.left - scrollX;
|
|
|
|
y = event.pageY - elementBounds.top - scrollY;
|
|
|
|
}
|
|
|
|
|
|
|
|
return {
|
|
|
|
x: x / (element.clientWidth / element.width),
|
|
|
|
y: y / (element.clientHeight / element.height)
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
})();
|