2017-07-13 16:21:37 +00:00
|
|
|
// Phaser.Input.Pointer
|
|
|
|
|
|
|
|
var Class = require('../utils/Class');
|
2017-11-23 01:44:58 +00:00
|
|
|
var Vector2 = require('../math/Vector2');
|
2017-07-13 16:21:37 +00:00
|
|
|
|
2017-07-27 02:40:58 +00:00
|
|
|
// DOM event button value:
|
|
|
|
// A number representing a given button:
|
|
|
|
// 0: Main button pressed, usually the left button or the un-initialized state
|
|
|
|
// 1: Auxiliary button pressed, usually the wheel button or the middle button (if present)
|
|
|
|
// 2: Secondary button pressed, usually the right button
|
|
|
|
// 3: Fourth button, typically the Browser Back button
|
|
|
|
// 4: Fifth button, typically the Browser Forward button
|
|
|
|
// For a mouse configured for left-handed use, the button actions are reversed. In this case, the values are read from right to left.
|
|
|
|
|
2017-07-13 16:21:37 +00:00
|
|
|
var Pointer = new Class({
|
|
|
|
|
|
|
|
initialize:
|
|
|
|
|
2017-07-21 02:39:55 +00:00
|
|
|
function Pointer (manager, id)
|
2017-07-13 16:21:37 +00:00
|
|
|
{
|
|
|
|
this.manager = manager;
|
|
|
|
|
2017-07-21 02:39:55 +00:00
|
|
|
this.id = id;
|
|
|
|
|
2017-07-18 01:36:45 +00:00
|
|
|
this.event;
|
|
|
|
|
2017-07-29 00:55:17 +00:00
|
|
|
// The camera the Pointer interacted with during its last update
|
|
|
|
// A Pointer can only ever interact with 1 camera at once, which will be the top-most camera
|
|
|
|
// in the list should multiple cameras be positioned on-top of each other.
|
|
|
|
this.camera = null;
|
|
|
|
|
2017-07-25 11:33:53 +00:00
|
|
|
// 0 : No button or un-initialized
|
|
|
|
// 1 : Left button
|
|
|
|
// 2 : Right button
|
|
|
|
// 4 : Wheel button or middle button
|
|
|
|
// 8 : 4th button (typically the "Browser Back" button)
|
|
|
|
// 16 : 5th button (typically the "Browser Forward" button)
|
|
|
|
this.buttons = 0;
|
2017-07-17 22:38:43 +00:00
|
|
|
|
2017-11-23 01:44:58 +00:00
|
|
|
this.position = new Vector2();
|
2017-07-13 16:21:37 +00:00
|
|
|
|
2017-07-27 02:40:58 +00:00
|
|
|
// Coordinates and time of the pointer when Button 1 (left button), or Touch, was pressed, used for dragging objects
|
|
|
|
this.downX = 0;
|
|
|
|
this.downY = 0;
|
|
|
|
this.downTime = 0;
|
|
|
|
|
|
|
|
// Coordinates and time of the pointer when Button 1 (left button), or Touch, was released, used for dragging objects
|
|
|
|
this.upX = 0;
|
|
|
|
this.upY = 0;
|
|
|
|
this.upTime = 0;
|
|
|
|
|
|
|
|
// Is the primary button down? (usually button 0, the left mouse button)
|
|
|
|
this.primaryDown = false;
|
|
|
|
|
|
|
|
// 0 = Not dragging anything
|
|
|
|
// 1 = Being checked if dragging
|
|
|
|
// 2 = Dragging something
|
|
|
|
this.dragState = 0;
|
|
|
|
|
|
|
|
// Is *any* button on this pointer considered as being down?
|
2017-07-13 16:21:37 +00:00
|
|
|
this.isDown = false;
|
2017-07-14 00:38:21 +00:00
|
|
|
|
|
|
|
this.dirty = false;
|
|
|
|
|
|
|
|
this.justDown = false;
|
|
|
|
this.justUp = false;
|
|
|
|
this.justMoved = false;
|
2017-12-08 23:05:05 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @property {number} movementX - If the mouse is locked, the horizontal relative movement
|
|
|
|
* of the Pointer in pixels since last frame.
|
|
|
|
*/
|
|
|
|
this.movementX = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @property {number} movementY - If the mouse is locked, the vertical relative movement of
|
|
|
|
* the Pointer in pixels since last frame.
|
|
|
|
*/
|
|
|
|
this.movementY = 0;
|
2017-07-14 00:38:21 +00:00
|
|
|
},
|
|
|
|
|
2017-11-28 11:16:35 +00:00
|
|
|
positionToCamera: function (camera, output)
|
|
|
|
{
|
2017-11-29 22:23:58 +00:00
|
|
|
return camera.getWorldPoint(this.position, output);
|
2017-11-28 11:16:35 +00:00
|
|
|
},
|
|
|
|
|
2017-11-23 01:44:58 +00:00
|
|
|
x: {
|
|
|
|
|
|
|
|
get: function ()
|
|
|
|
{
|
|
|
|
return this.position.x;
|
|
|
|
},
|
|
|
|
|
|
|
|
set: function (value)
|
|
|
|
{
|
|
|
|
this.position.x = value;
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
y: {
|
|
|
|
|
|
|
|
get: function ()
|
|
|
|
{
|
|
|
|
return this.position.y;
|
|
|
|
},
|
|
|
|
|
|
|
|
set: function (value)
|
|
|
|
{
|
|
|
|
this.position.y = value;
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2017-07-14 00:38:21 +00:00
|
|
|
reset: function ()
|
|
|
|
{
|
2017-07-25 11:33:53 +00:00
|
|
|
this.buttons = 0;
|
|
|
|
|
2017-07-14 00:38:21 +00:00
|
|
|
this.dirty = false;
|
2017-07-18 16:22:14 +00:00
|
|
|
this.isDown = false;
|
2017-07-14 00:38:21 +00:00
|
|
|
this.justDown = false;
|
|
|
|
this.justUp = false;
|
|
|
|
this.justMoved = false;
|
2017-12-08 23:05:05 +00:00
|
|
|
this.movementX = 0;
|
|
|
|
this.movementY = 0;
|
2017-07-13 16:21:37 +00:00
|
|
|
},
|
|
|
|
|
2017-07-28 02:28:10 +00:00
|
|
|
touchmove: function (event, time)
|
|
|
|
{
|
|
|
|
this.event = event;
|
|
|
|
|
|
|
|
this.x = this.manager.transformX(event.changedTouches[0].pageX);
|
|
|
|
this.y = this.manager.transformY(event.changedTouches[0].pageY);
|
|
|
|
|
|
|
|
this.justMoved = true;
|
|
|
|
|
|
|
|
this.dirty = true;
|
|
|
|
},
|
|
|
|
|
2017-07-27 02:40:58 +00:00
|
|
|
move: function (event, time)
|
2017-07-13 16:21:37 +00:00
|
|
|
{
|
2017-07-25 11:33:53 +00:00
|
|
|
if (event.buttons)
|
2017-07-17 22:38:43 +00:00
|
|
|
{
|
2017-07-25 11:33:53 +00:00
|
|
|
this.buttons = event.buttons;
|
2017-07-17 22:38:43 +00:00
|
|
|
}
|
2017-07-14 00:38:21 +00:00
|
|
|
|
2017-07-18 01:36:45 +00:00
|
|
|
this.event = event;
|
2017-07-14 00:38:21 +00:00
|
|
|
|
2017-07-17 22:38:43 +00:00
|
|
|
this.x = this.manager.transformX(event.pageX);
|
|
|
|
this.y = this.manager.transformY(event.pageY);
|
|
|
|
|
2017-12-08 23:05:05 +00:00
|
|
|
if (this.manager.mouse.locked)
|
|
|
|
{
|
|
|
|
// Potentially multiple DOM events within one frame, but only one Phaser event will fire
|
|
|
|
this.movementX += event.movementX || event.mozMovementX || event.webkitMovementX || 0;
|
|
|
|
this.movementY += event.movementY || event.mozMovementY || event.webkitMovementY || 0;
|
|
|
|
}
|
|
|
|
|
2017-07-14 00:38:21 +00:00
|
|
|
this.justMoved = true;
|
2017-07-18 16:22:14 +00:00
|
|
|
|
|
|
|
this.dirty = true;
|
2017-07-14 00:38:21 +00:00
|
|
|
},
|
|
|
|
|
2017-07-27 02:40:58 +00:00
|
|
|
down: function (event, time)
|
2017-07-14 00:38:21 +00:00
|
|
|
{
|
2017-07-25 11:33:53 +00:00
|
|
|
if (event.buttons)
|
2017-07-18 01:36:45 +00:00
|
|
|
{
|
2017-07-25 11:33:53 +00:00
|
|
|
this.buttons = event.buttons;
|
2017-07-18 01:36:45 +00:00
|
|
|
}
|
2017-07-14 00:38:21 +00:00
|
|
|
|
2017-07-18 01:36:45 +00:00
|
|
|
this.event = event;
|
|
|
|
|
|
|
|
this.x = this.manager.transformX(event.pageX);
|
|
|
|
this.y = this.manager.transformY(event.pageY);
|
|
|
|
|
2017-07-27 02:40:58 +00:00
|
|
|
// 0: Main button pressed, usually the left button or the un-initialized state
|
|
|
|
if (event.button === 0)
|
|
|
|
{
|
|
|
|
this.primaryDown = true;
|
|
|
|
this.downX = this.x;
|
|
|
|
this.downY = this.y;
|
|
|
|
this.downTime = time;
|
|
|
|
}
|
|
|
|
|
2017-07-14 00:38:21 +00:00
|
|
|
this.justDown = true;
|
2017-07-18 16:22:14 +00:00
|
|
|
this.isDown = true;
|
|
|
|
|
|
|
|
this.dirty = true;
|
2017-07-14 00:38:21 +00:00
|
|
|
},
|
|
|
|
|
2017-07-28 02:28:10 +00:00
|
|
|
touchstart: function (event, time)
|
|
|
|
{
|
|
|
|
this.buttons = 1;
|
|
|
|
|
|
|
|
this.event = event;
|
|
|
|
|
|
|
|
this.x = this.manager.transformX(event.changedTouches[0].pageX);
|
|
|
|
this.y = this.manager.transformY(event.changedTouches[0].pageY);
|
|
|
|
|
|
|
|
this.primaryDown = true;
|
|
|
|
this.downX = this.x;
|
|
|
|
this.downY = this.y;
|
|
|
|
this.downTime = time;
|
|
|
|
|
|
|
|
this.justDown = true;
|
|
|
|
this.isDown = true;
|
|
|
|
|
|
|
|
this.dirty = true;
|
|
|
|
},
|
|
|
|
|
2017-07-27 02:40:58 +00:00
|
|
|
up: function (event, time)
|
2017-07-14 00:38:21 +00:00
|
|
|
{
|
2017-07-25 11:33:53 +00:00
|
|
|
if (event.buttons)
|
2017-07-18 01:36:45 +00:00
|
|
|
{
|
2017-07-25 11:33:53 +00:00
|
|
|
this.buttons = event.buttons;
|
2017-07-18 01:36:45 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
this.event = event;
|
|
|
|
|
|
|
|
this.x = this.manager.transformX(event.pageX);
|
|
|
|
this.y = this.manager.transformY(event.pageY);
|
2017-07-14 00:38:21 +00:00
|
|
|
|
2017-07-27 02:40:58 +00:00
|
|
|
// 0: Main button pressed, usually the left button or the un-initialized state
|
|
|
|
if (event.button === 0)
|
|
|
|
{
|
|
|
|
this.primaryDown = false;
|
|
|
|
this.upX = this.x;
|
|
|
|
this.upY = this.y;
|
|
|
|
this.upTime = time;
|
|
|
|
}
|
|
|
|
|
2017-07-14 00:38:21 +00:00
|
|
|
this.justUp = true;
|
2017-07-18 16:22:14 +00:00
|
|
|
this.isDown = false;
|
|
|
|
|
|
|
|
this.dirty = true;
|
2017-07-25 11:33:53 +00:00
|
|
|
},
|
|
|
|
|
2017-07-28 02:28:10 +00:00
|
|
|
touchend: function (event, time)
|
|
|
|
{
|
|
|
|
this.buttons = 0;
|
|
|
|
|
|
|
|
this.event = event;
|
|
|
|
|
|
|
|
this.x = this.manager.transformX(event.changedTouches[0].pageX);
|
|
|
|
this.y = this.manager.transformY(event.changedTouches[0].pageY);
|
|
|
|
|
|
|
|
this.primaryDown = false;
|
|
|
|
this.upX = this.x;
|
|
|
|
this.upY = this.y;
|
|
|
|
this.upTime = time;
|
|
|
|
|
|
|
|
this.justUp = true;
|
|
|
|
this.isDown = false;
|
|
|
|
|
|
|
|
this.dirty = true;
|
|
|
|
},
|
|
|
|
|
2017-07-25 11:33:53 +00:00
|
|
|
noButtonDown: function ()
|
|
|
|
{
|
|
|
|
return (this.buttons === 0);
|
|
|
|
},
|
|
|
|
|
|
|
|
leftButtonDown: function ()
|
|
|
|
{
|
|
|
|
return (this.buttons & 1);
|
|
|
|
},
|
|
|
|
|
|
|
|
rightButtonDown: function ()
|
|
|
|
{
|
|
|
|
return (this.buttons & 2);
|
|
|
|
},
|
|
|
|
|
|
|
|
middleButtonDown: function ()
|
|
|
|
{
|
|
|
|
return (this.buttons & 4);
|
|
|
|
},
|
|
|
|
|
|
|
|
backButtonDown: function ()
|
|
|
|
{
|
|
|
|
return (this.buttons & 8);
|
|
|
|
},
|
|
|
|
|
|
|
|
forwardButtonDown: function ()
|
|
|
|
{
|
|
|
|
return (this.buttons & 16);
|
2017-07-13 16:21:37 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
module.exports = Pointer;
|