phaser/v3/src/input/global/GlobalInputManager.js

215 lines
5.5 KiB
JavaScript
Raw Normal View History

// Phaser.Input.GlobalInputManager
var Class = require('../../utils/Class');
var EventDispatcher = require('../../events/EventDispatcher');
2017-09-09 02:17:13 +00:00
var Gamepad = require('../gamepad/GamepadManager');
var GetTransformedPoint = require('./inc/GetTransformedPoint');
var HitTest = require('./inc/HitTest');
var Keyboard = require('../keyboard/KeyboardManager');
var Mouse = require('../mouse/MouseManager');
var MouseEvent = require('../mouse/events/');
var Pointer = require('../Pointer');
var PointScreenToWorldHitTest = require('./inc/PointScreenToWorldHitTest');
var PointWithinGameObject = require('./inc/PointWithinGameObject');
2017-09-09 02:17:13 +00:00
var Touch = require('../touch/TouchManager');
var TransformMatrix = require('../../gameobjects/components/TransformMatrix');
var GlobalInputManager = new Class({
initialize:
function GlobalInputManager (game, config)
{
this.game = game;
2017-06-14 00:20:01 +00:00
this.canvas;
this.config = config;
2017-06-14 00:20:01 +00:00
this.enabled = true;
2017-06-14 00:20:01 +00:00
this.events = new EventDispatcher();
// Standard FIFO queue
this.queue = [];
2017-09-09 02:17:13 +00:00
// Listeners (will be based on config)
this.keyboard = new Keyboard(this);
this.mouse = new Mouse(this);
this.touch = new Touch(this);
2017-09-09 02:17:13 +00:00
this.gamepad = new Gamepad(this);
this.activePointer = new Pointer(this, 0);
this.scale = { x: 1, y: 1 };
this.bounds;
this._tempMatrix = new TransformMatrix();
this._tempPoint = { x: 0, y: 0 };
this._tempHitTest = [];
},
/**
* The Boot handler is called by Phaser.Game when it first starts up.
* The renderer is available by now.
*/
boot: function ()
{
this.canvas = this.game.canvas;
this.updateBounds();
this.keyboard.boot();
this.mouse.boot();
this.touch.boot();
2017-09-09 02:17:13 +00:00
this.gamepad.boot();
},
updateBounds: function ()
{
var bounds = this.canvas.getBoundingClientRect();
if (window.scrollX)
{
bounds.left += window.scrollX;
}
if (window.scrollY)
{
bounds.top += window.scrollY;
}
this.bounds = bounds;
},
update: function (time, delta)
{
this.keyboard.update();
2017-09-09 02:17:13 +00:00
this.gamepad.update();
2017-06-14 00:20:01 +00:00
var len = this.queue.length;
// Currently just 1 pointer supported
var pointer = this.activePointer;
pointer.reset();
2017-06-14 00:20:01 +00:00
if (!this.enabled || len === 0)
{
return;
}
this.updateBounds();
this.scale.x = this.game.config.width / this.bounds.width;
this.scale.y = this.game.config.height / this.bounds.height;
2017-06-14 00:20:01 +00:00
// Clears the queue array, and also means we don't work on array data that could potentially
// be modified during the processing phase
var queue = this.queue.splice(0, len);
// Process the event queue, dispatching all of the events that have stored up
for (var i = 0; i < len; i++)
{
var event = queue[i];
// TODO: Move to CONSTs so we can do integer comparisons instead of strings.
// TODO: Remove the MouseEvent events. Devs should use Pointer events instead.
2017-06-14 00:20:01 +00:00
switch (event.type)
{
case 'mousemove':
2017-07-27 02:40:58 +00:00
pointer.move(event, time);
2017-06-14 00:20:01 +00:00
this.events.dispatch(new MouseEvent.MOVE(event));
break;
case 'mousedown':
2017-07-27 02:40:58 +00:00
pointer.down(event, time);
2017-06-14 00:20:01 +00:00
this.events.dispatch(new MouseEvent.DOWN(event));
break;
case 'mouseup':
2017-07-27 02:40:58 +00:00
pointer.up(event, time);
2017-06-14 00:20:01 +00:00
this.events.dispatch(new MouseEvent.UP(event));
break;
case 'pointerlockchange':
this.events.dispatch(new MouseEvent.POINTER_LOCK_CHANGE(event, this.mouse.locked));
break;
case 'touchmove':
pointer.touchmove(event, time);
break;
case 'touchstart':
pointer.touchstart(event, time);
break;
case 'touchend':
pointer.touchend(event, time);
break;
2017-06-14 00:20:01 +00:00
}
}
},
getTransformedPoint: function (gameObject, x, y)
{
return GetTransformedPoint(this._tempMatrix, gameObject, x, y, this._tempPoint);
},
pointWithinGameObject: function (gameObject, x, y)
{
return PointWithinGameObject(gameObject, x, y);
},
hitTest: function (gameObjects, x, y, camera)
{
return HitTest(this._tempMatrix, x, y, gameObjects, camera, this._tempHitTest);
},
pointScreenToWorldHitTest: function (gameObjects, x, y, camera)
{
return PointScreenToWorldHitTest(this._tempMatrix, x, y, gameObjects, camera, this._tempHitTest);
},
transformX: function (pageX)
{
return (pageX - this.bounds.left) * this.scale.x;
},
transformY: function (pageY)
{
return (pageY - this.bounds.top) * this.scale.y;
},
getOffsetX: function ()
{
return this.bounds.left;
},
getOffsetY: function ()
{
return this.bounds.top;
},
getScaleX: function ()
{
return this.game.config.width / this.bounds.width;
},
getScaleY: function ()
{
return this.game.config.height / this.bounds.height;
}
});
module.exports = GlobalInputManager;