0
0
Fork 0
mirror of https://github.com/liabru/matter-js.git synced 2025-01-06 15:25:41 -05:00
liabru-matter-js/src/core/Mouse.js

149 lines
4.5 KiB
JavaScript
Raw Normal View History

/**
* _Internal Class_, not generally used outside of the engine's internals.
*
* @class Mouse
*/
2014-02-19 09:15:05 -05:00
var Mouse;
(function() {
/**
* 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-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 };
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-01 06:52:50 -04:00
mouse.position.x = position.x;
mouse.position.y = position.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-01 06:52:50 -04:00
mouse.position.x = position.x;
mouse.position.y = position.y;
mouse.mousedownPosition.x = position.x;
mouse.mousedownPosition.y = 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-01 06:52:50 -04:00
mouse.position.x = position.x;
mouse.position.y = position.y;
mouse.mouseupPosition.x = position.x;
mouse.mouseupPosition.y = 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
};
/**
* 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-02-19 09:15:05 -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(),
scrollX = (window.pageXOffset !== undefined) ? window.pageXOffset : (document.documentElement || document.body.parentNode || document.body).scrollLeft,
scrollY = (window.pageYOffset !== undefined) ? window.pageYOffset : (document.documentElement || document.body.parentNode || document.body).scrollTop,
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)
};
};
})();