2018-02-12 16:01:20 +00:00
|
|
|
/**
|
|
|
|
* @author Richard Davey <rich@photonstorm.com>
|
|
|
|
* @copyright 2018 Photon Storm Ltd.
|
|
|
|
* @license {@link https://github.com/photonstorm/phaser/blob/master/license.txt|MIT License}
|
|
|
|
*/
|
|
|
|
|
2018-01-16 16:00:37 +00:00
|
|
|
var Class = require('../utils/Class');
|
2018-05-29 23:33:51 +00:00
|
|
|
var CONST = require('./const');
|
2018-01-12 17:09:09 +00:00
|
|
|
var EventEmitter = require('eventemitter3');
|
2018-12-05 16:01:39 +00:00
|
|
|
var Keyboard = require('./keyboard/KeyboardManager');
|
2018-01-16 16:00:37 +00:00
|
|
|
var Mouse = require('./mouse/MouseManager');
|
|
|
|
var Pointer = require('./Pointer');
|
2018-01-22 12:04:14 +00:00
|
|
|
var Rectangle = require('../geom/rectangle/Rectangle');
|
2018-01-16 16:00:37 +00:00
|
|
|
var Touch = require('./touch/TouchManager');
|
2018-04-09 15:42:51 +00:00
|
|
|
var TransformMatrix = require('../gameobjects/components/TransformMatrix');
|
2018-01-16 16:00:37 +00:00
|
|
|
var TransformXY = require('../math/TransformXY');
|
2017-02-21 01:04:11 +00:00
|
|
|
|
2018-02-07 15:27:21 +00:00
|
|
|
/**
|
|
|
|
* @classdesc
|
2018-06-08 14:15:21 +00:00
|
|
|
* The Input Manager is responsible for handling the pointer related systems in a single Phaser Game instance.
|
2018-06-04 14:19:11 +00:00
|
|
|
*
|
2018-06-08 14:15:21 +00:00
|
|
|
* Based on the Game Config it will create handlers for mouse and touch support.
|
|
|
|
*
|
|
|
|
* Keyboard and Gamepad are plugins, handled directly by the InputPlugin class.
|
2018-06-04 14:19:11 +00:00
|
|
|
*
|
|
|
|
* It then manages the event queue, pointer creation and general hit test related operations.
|
|
|
|
*
|
|
|
|
* You rarely need to interact with the Input Manager directly, and as such, all of its properties and methods
|
|
|
|
* should be considered private. Instead, you should use the Input Plugin, which is a Scene level system, responsible
|
|
|
|
* for dealing with all input events for a Scene.
|
2018-02-07 15:27:21 +00:00
|
|
|
*
|
|
|
|
* @class InputManager
|
2018-10-10 09:49:13 +00:00
|
|
|
* @memberof Phaser.Input
|
2018-02-07 15:27:21 +00:00
|
|
|
* @constructor
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-04 12:24:47 +00:00
|
|
|
* @param {Phaser.Game} game - The Game instance that owns the Input Manager.
|
|
|
|
* @param {object} config - The Input Configuration object, as set in the Game Config.
|
2018-02-07 15:27:21 +00:00
|
|
|
*/
|
2018-01-16 16:14:21 +00:00
|
|
|
var InputManager = new Class({
|
2017-02-21 01:04:11 +00:00
|
|
|
|
2017-06-30 14:47:51 +00:00
|
|
|
initialize:
|
2017-02-21 01:04:11 +00:00
|
|
|
|
2018-01-16 16:14:21 +00:00
|
|
|
function InputManager (game, config)
|
2017-06-30 14:47:51 +00:00
|
|
|
{
|
2018-01-26 06:55:15 +00:00
|
|
|
/**
|
2018-06-04 12:24:47 +00:00
|
|
|
* The Game instance that owns the Input Manager.
|
|
|
|
* A Game only maintains on instance of the Input Manager at any time.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
2018-02-13 01:13:12 +00:00
|
|
|
* @name Phaser.Input.InputManager#game
|
|
|
|
* @type {Phaser.Game}
|
2018-10-09 12:40:00 +00:00
|
|
|
* @readonly
|
2018-01-26 06:55:15 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-06-30 14:47:51 +00:00
|
|
|
this.game = game;
|
2017-06-14 00:20:01 +00:00
|
|
|
|
2018-01-26 06:55:15 +00:00
|
|
|
/**
|
2018-06-04 12:24:47 +00:00
|
|
|
* The Canvas that is used for all DOM event input listeners.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
2018-02-13 01:13:12 +00:00
|
|
|
* @name Phaser.Input.InputManager#canvas
|
|
|
|
* @type {HTMLCanvasElement}
|
2018-01-26 06:55:15 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-07-17 22:38:43 +00:00
|
|
|
this.canvas;
|
|
|
|
|
2018-01-26 06:55:15 +00:00
|
|
|
/**
|
2018-11-19 15:31:06 +00:00
|
|
|
* The Game Configuration object, as set during the game boot.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
2018-02-13 01:13:12 +00:00
|
|
|
* @name Phaser.Input.InputManager#config
|
2018-11-19 15:31:06 +00:00
|
|
|
* @type {Phaser.Boot.Config}
|
2018-01-26 06:55:15 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-06-30 14:47:51 +00:00
|
|
|
this.config = config;
|
2017-06-14 00:20:01 +00:00
|
|
|
|
2018-01-26 06:55:15 +00:00
|
|
|
/**
|
2018-06-04 12:24:47 +00:00
|
|
|
* If set, the Input Manager will run its update loop every frame.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
2018-02-13 01:13:12 +00:00
|
|
|
* @name Phaser.Input.InputManager#enabled
|
|
|
|
* @type {boolean}
|
2018-01-26 06:55:15 +00:00
|
|
|
* @default true
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-06-30 14:47:51 +00:00
|
|
|
this.enabled = true;
|
2017-06-14 00:20:01 +00:00
|
|
|
|
2018-01-26 06:55:15 +00:00
|
|
|
/**
|
2018-06-04 12:24:47 +00:00
|
|
|
* The Event Emitter instance that the Input Manager uses to emit events from.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
2018-02-13 01:13:12 +00:00
|
|
|
* @name Phaser.Input.InputManager#events
|
2018-03-29 12:12:07 +00:00
|
|
|
* @type {Phaser.Events.EventEmitter}
|
2018-01-26 06:55:15 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-12 17:09:09 +00:00
|
|
|
this.events = new EventEmitter();
|
2017-06-14 01:20:55 +00:00
|
|
|
|
2018-01-26 06:55:15 +00:00
|
|
|
/**
|
2018-06-04 12:24:47 +00:00
|
|
|
* A standard FIFO queue for the native DOM events waiting to be handled by the Input Manager.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
2018-02-13 01:13:12 +00:00
|
|
|
* @name Phaser.Input.InputManager#queue
|
|
|
|
* @type {array}
|
2018-01-26 06:55:15 +00:00
|
|
|
* @default []
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-06-30 14:47:51 +00:00
|
|
|
this.queue = [];
|
2017-02-21 01:04:11 +00:00
|
|
|
|
2018-05-29 23:33:51 +00:00
|
|
|
/**
|
|
|
|
* DOM Callbacks container.
|
|
|
|
*
|
|
|
|
* @name Phaser.Input.InputManager#domCallbacks
|
|
|
|
* @private
|
|
|
|
* @type {object}
|
|
|
|
* @since 3.10.0
|
|
|
|
*/
|
|
|
|
this.domCallbacks = { up: [], down: [], move: [], upOnce: [], downOnce: [], moveOnce: [] };
|
|
|
|
|
2018-11-28 13:10:25 +00:00
|
|
|
/**
|
|
|
|
* Are any mouse or touch pointers currently over the game canvas?
|
|
|
|
* This is updated automatically by the canvas over and out handlers.
|
|
|
|
*
|
|
|
|
* @name Phaser.Input.InputManager#isOver
|
|
|
|
* @type {boolean}
|
|
|
|
* @readonly
|
|
|
|
* @since 3.16.0
|
|
|
|
*/
|
|
|
|
this.isOver = true;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* isOver state change property.
|
|
|
|
*
|
|
|
|
* @name Phaser.Input.InputManager#_emitIsOverEvent
|
|
|
|
* @type {boolean}
|
|
|
|
* @private
|
|
|
|
* @since 3.16.0
|
|
|
|
*/
|
|
|
|
this._emitIsOverEvent = false;
|
|
|
|
|
2018-05-29 23:33:51 +00:00
|
|
|
/**
|
|
|
|
* Are there any up callbacks defined?
|
|
|
|
*
|
|
|
|
* @name Phaser.Input.InputManager#_hasUpCallback
|
|
|
|
* @private
|
|
|
|
* @type {boolean}
|
|
|
|
* @since 3.10.0
|
|
|
|
*/
|
|
|
|
this._hasUpCallback = false;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Are there any down callbacks defined?
|
|
|
|
*
|
|
|
|
* @name Phaser.Input.InputManager#_hasDownCallback
|
|
|
|
* @private
|
|
|
|
* @type {boolean}
|
|
|
|
* @since 3.10.0
|
|
|
|
*/
|
|
|
|
this._hasDownCallback = false;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Are there any move callbacks defined?
|
|
|
|
*
|
|
|
|
* @name Phaser.Input.InputManager#_hasMoveCallback
|
|
|
|
* @private
|
|
|
|
* @type {boolean}
|
|
|
|
* @since 3.10.0
|
|
|
|
*/
|
|
|
|
this._hasMoveCallback = false;
|
|
|
|
|
2018-06-11 10:36:02 +00:00
|
|
|
/**
|
|
|
|
* Is a custom cursor currently set? (desktop only)
|
|
|
|
*
|
|
|
|
* @name Phaser.Input.InputManager#_customCursor
|
|
|
|
* @private
|
|
|
|
* @type {string}
|
|
|
|
* @since 3.10.0
|
|
|
|
*/
|
|
|
|
this._customCursor = '';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Custom cursor tracking value.
|
|
|
|
*
|
|
|
|
* 0 - No change.
|
|
|
|
* 1 - Set new cursor.
|
|
|
|
* 2 - Reset cursor.
|
|
|
|
*
|
|
|
|
* @name Phaser.Input.InputManager#_setCursor
|
|
|
|
* @private
|
|
|
|
* @type {integer}
|
|
|
|
* @since 3.10.0
|
|
|
|
*/
|
|
|
|
this._setCursor = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The default CSS cursor to be used when interacting with your game.
|
|
|
|
*
|
|
|
|
* See the `setDefaultCursor` method for more details.
|
|
|
|
*
|
|
|
|
* @name Phaser.Input.InputManager#defaultCursor
|
|
|
|
* @type {string}
|
|
|
|
* @since 3.10.0
|
|
|
|
*/
|
|
|
|
this.defaultCursor = '';
|
2018-06-08 18:04:12 +00:00
|
|
|
|
2018-12-05 11:16:45 +00:00
|
|
|
/**
|
|
|
|
* A reference to the Keyboard Manager class, if enabled via the `input.keyboard` Game Config property.
|
|
|
|
*
|
|
|
|
* @name Phaser.Input.InputManager#keyboard
|
|
|
|
* @type {?Phaser.Input.Keyboard.KeyboardManager}
|
|
|
|
* @since 3.16.0
|
|
|
|
*/
|
|
|
|
this.keyboard = (config.inputKeyboard) ? new Keyboard(this) : null;
|
|
|
|
|
2018-01-26 06:55:15 +00:00
|
|
|
/**
|
2018-05-25 18:28:18 +00:00
|
|
|
* A reference to the Mouse Manager class, if enabled via the `input.mouse` Game Config property.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
2018-02-13 01:13:12 +00:00
|
|
|
* @name Phaser.Input.InputManager#mouse
|
2018-05-25 18:28:18 +00:00
|
|
|
* @type {?Phaser.Input.Mouse.MouseManager}
|
2018-01-26 06:55:15 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-05-25 18:28:18 +00:00
|
|
|
this.mouse = (config.inputMouse) ? new Mouse(this) : null;
|
2018-01-26 06:55:15 +00:00
|
|
|
|
|
|
|
/**
|
2018-05-25 18:28:18 +00:00
|
|
|
* A reference to the Touch Manager class, if enabled via the `input.touch` Game Config property.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
2018-02-13 01:13:12 +00:00
|
|
|
* @name Phaser.Input.InputManager#touch
|
|
|
|
* @type {Phaser.Input.Touch.TouchManager}
|
2018-01-26 06:55:15 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-05-25 18:28:18 +00:00
|
|
|
this.touch = (config.inputTouch) ? new Touch(this) : null;
|
2018-01-26 06:55:15 +00:00
|
|
|
|
|
|
|
/**
|
2018-05-25 18:28:18 +00:00
|
|
|
* An array of Pointers that have been added to the game.
|
2018-05-29 15:55:52 +00:00
|
|
|
* The first entry is reserved for the Mouse Pointer, the rest are Touch Pointers.
|
2018-05-31 14:19:35 +00:00
|
|
|
*
|
2018-05-29 23:33:51 +00:00
|
|
|
* By default there is 1 touch pointer enabled. If you need more use the `addPointer` method to start them,
|
|
|
|
* or set the `input.activePointers` property in the Game Config.
|
2018-05-25 18:28:18 +00:00
|
|
|
*
|
|
|
|
* @name Phaser.Input.InputManager#pointers
|
|
|
|
* @type {Phaser.Input.Pointer[]}
|
|
|
|
* @since 3.10.0
|
|
|
|
*/
|
2018-05-29 23:33:51 +00:00
|
|
|
this.pointers = [];
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The number of touch objects activated and being processed each update.
|
2018-05-31 14:19:35 +00:00
|
|
|
*
|
2018-05-29 23:33:51 +00:00
|
|
|
* You can change this by either calling `addPointer` at run-time, or by
|
|
|
|
* setting the `input.activePointers` property in the Game Config.
|
|
|
|
*
|
|
|
|
* @name Phaser.Input.InputManager#pointersTotal
|
|
|
|
* @type {integer}
|
2018-10-09 12:40:00 +00:00
|
|
|
* @readonly
|
2018-05-29 23:33:51 +00:00
|
|
|
* @since 3.10.0
|
|
|
|
*/
|
|
|
|
this.pointersTotal = config.inputActivePointers;
|
|
|
|
|
2018-06-13 12:51:04 +00:00
|
|
|
if (config.inputTouch && this.pointersTotal === 1)
|
|
|
|
{
|
|
|
|
this.pointersTotal = 2;
|
|
|
|
}
|
|
|
|
|
2018-05-29 23:33:51 +00:00
|
|
|
for (var i = 0; i <= this.pointersTotal; i++)
|
|
|
|
{
|
2018-11-19 15:31:06 +00:00
|
|
|
var pointer = new Pointer(this, i);
|
|
|
|
|
|
|
|
pointer.smoothFactor = config.inputSmoothFactor;
|
|
|
|
|
|
|
|
this.pointers.push(pointer);
|
2018-05-29 23:33:51 +00:00
|
|
|
}
|
2018-05-29 15:55:52 +00:00
|
|
|
|
2018-05-25 18:28:18 +00:00
|
|
|
/**
|
|
|
|
* The mouse has its own unique Pointer object, which you can reference directly if making a _desktop specific game_.
|
|
|
|
* If you are supporting both desktop and touch devices then do not use this property, instead use `activePointer`
|
|
|
|
* which will always map to the most recently interacted pointer.
|
|
|
|
*
|
|
|
|
* @name Phaser.Input.InputManager#mousePointer
|
2018-05-29 15:55:52 +00:00
|
|
|
* @type {?Phaser.Input.Pointer}
|
2018-05-25 18:28:18 +00:00
|
|
|
* @since 3.10.0
|
|
|
|
*/
|
2018-05-29 15:55:52 +00:00
|
|
|
this.mousePointer = (config.inputMouse) ? this.pointers[0] : null;
|
2018-05-25 18:28:18 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The most recently active Pointer object.
|
|
|
|
*
|
|
|
|
* If you've only 1 Pointer in your game then this will accurately be either the first finger touched, or the mouse.
|
|
|
|
*
|
|
|
|
* If your game doesn't need to support multi-touch then you can safely use this property in all of your game
|
|
|
|
* code and it will adapt to be either the mouse or the touch, based on device.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
2018-02-13 01:13:12 +00:00
|
|
|
* @name Phaser.Input.InputManager#activePointer
|
2018-03-19 12:43:19 +00:00
|
|
|
* @type {Phaser.Input.Pointer}
|
2018-01-26 06:55:15 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-05-25 18:28:18 +00:00
|
|
|
this.activePointer = this.pointers[0];
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Reset every frame. Set to `true` if any of the Pointers are dirty this frame.
|
|
|
|
*
|
|
|
|
* @name Phaser.Input.InputManager#dirty
|
|
|
|
* @type {boolean}
|
|
|
|
* @since 3.10.0
|
|
|
|
*/
|
|
|
|
this.dirty = false;
|
2017-07-13 16:21:37 +00:00
|
|
|
|
2018-01-26 06:55:15 +00:00
|
|
|
/**
|
2018-06-04 12:24:47 +00:00
|
|
|
* The Scale factor being applied to input coordinates.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
2018-02-13 01:13:12 +00:00
|
|
|
* @name Phaser.Input.InputManager#scale
|
2018-06-04 12:24:47 +00:00
|
|
|
* @type { { x:number, y:number } }
|
2018-01-26 06:55:15 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-07-17 22:38:43 +00:00
|
|
|
this.scale = { x: 1, y: 1 };
|
|
|
|
|
2018-01-26 06:55:15 +00:00
|
|
|
/**
|
|
|
|
* If the top-most Scene in the Scene List receives an input it will stop input from
|
|
|
|
* propagating any lower down the scene list, i.e. if you have a UI Scene at the top
|
|
|
|
* and click something on it, that click will not then be passed down to any other
|
|
|
|
* Scene below. Disable this to have input events passed through all Scenes, all the time.
|
|
|
|
*
|
2018-02-13 01:13:12 +00:00
|
|
|
* @name Phaser.Input.InputManager#globalTopOnly
|
|
|
|
* @type {boolean}
|
2018-01-26 06:55:15 +00:00
|
|
|
* @default true
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-20 04:44:54 +00:00
|
|
|
this.globalTopOnly = true;
|
|
|
|
|
2018-01-26 06:55:15 +00:00
|
|
|
/**
|
2018-06-04 12:24:47 +00:00
|
|
|
* An internal flag that controls if the Input Manager will ignore or process native DOM events this frame.
|
|
|
|
* Set via the InputPlugin.stopPropagation method.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
2018-02-13 01:13:12 +00:00
|
|
|
* @name Phaser.Input.InputManager#ignoreEvents
|
|
|
|
* @type {boolean}
|
2018-01-26 06:55:15 +00:00
|
|
|
* @default false
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-20 04:44:54 +00:00
|
|
|
this.ignoreEvents = false;
|
|
|
|
|
2018-01-26 06:55:15 +00:00
|
|
|
/**
|
2018-06-04 12:24:47 +00:00
|
|
|
* The bounds of the Input Manager, used for pointer hit test calculations.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
2018-02-13 01:13:12 +00:00
|
|
|
* @name Phaser.Input.InputManager#bounds
|
|
|
|
* @type {Phaser.Geom.Rectangle}
|
2018-01-26 06:55:15 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-22 12:04:14 +00:00
|
|
|
this.bounds = new Rectangle();
|
2017-12-13 22:08:15 +00:00
|
|
|
|
2018-01-26 06:55:15 +00:00
|
|
|
/**
|
2018-06-04 12:24:47 +00:00
|
|
|
* A re-cycled point-like object to store hit test values in.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
2018-02-13 01:13:12 +00:00
|
|
|
* @name Phaser.Input.InputManager#_tempPoint
|
2018-03-19 12:43:19 +00:00
|
|
|
* @type {{x:number,y:number}}
|
2018-01-26 06:55:15 +00:00
|
|
|
* @private
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-06-30 14:47:51 +00:00
|
|
|
this._tempPoint = { x: 0, y: 0 };
|
2018-01-26 06:55:15 +00:00
|
|
|
|
|
|
|
/**
|
2018-06-04 12:24:47 +00:00
|
|
|
* A re-cycled array to store hit results in.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
2018-02-13 01:13:12 +00:00
|
|
|
* @name Phaser.Input.InputManager#_tempHitTest
|
|
|
|
* @type {array}
|
2018-01-26 06:55:15 +00:00
|
|
|
* @private
|
|
|
|
* @default []
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-07-07 19:59:17 +00:00
|
|
|
this._tempHitTest = [];
|
2018-01-18 05:16:52 +00:00
|
|
|
|
2018-04-09 15:42:51 +00:00
|
|
|
/**
|
2018-06-04 12:24:47 +00:00
|
|
|
* A re-cycled matrix used in hit test calculations.
|
2018-04-09 15:42:51 +00:00
|
|
|
*
|
|
|
|
* @name Phaser.Input.InputManager#_tempMatrix
|
|
|
|
* @type {Phaser.GameObjects.Components.TransformMatrix}
|
|
|
|
* @private
|
|
|
|
* @since 3.4.0
|
|
|
|
*/
|
|
|
|
this._tempMatrix = new TransformMatrix();
|
|
|
|
|
2018-08-29 15:08:04 +00:00
|
|
|
/**
|
|
|
|
* A re-cycled matrix used in hit test calculations.
|
|
|
|
*
|
|
|
|
* @name Phaser.Input.InputManager#_tempMatrix2
|
|
|
|
* @type {Phaser.GameObjects.Components.TransformMatrix}
|
|
|
|
* @private
|
|
|
|
* @since 3.12.0
|
|
|
|
*/
|
|
|
|
this._tempMatrix2 = new TransformMatrix();
|
|
|
|
|
2018-01-18 05:16:52 +00:00
|
|
|
game.events.once('boot', this.boot, this);
|
2017-06-30 14:47:51 +00:00
|
|
|
},
|
2017-02-21 01:04:11 +00:00
|
|
|
|
|
|
|
/**
|
2018-01-26 06:55:15 +00:00
|
|
|
* The Boot handler is called by Phaser.Game when it first starts up.
|
|
|
|
* The renderer is available by now.
|
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#boot
|
2018-06-04 12:24:47 +00:00
|
|
|
* @protected
|
2018-01-26 06:55:15 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-02-21 01:04:11 +00:00
|
|
|
boot: function ()
|
|
|
|
{
|
2017-07-17 22:38:43 +00:00
|
|
|
this.canvas = this.game.canvas;
|
|
|
|
|
2017-12-13 22:08:15 +00:00
|
|
|
this.updateBounds();
|
|
|
|
|
2018-05-25 18:28:18 +00:00
|
|
|
this.events.emit('boot');
|
2018-01-31 03:38:10 +00:00
|
|
|
|
2018-05-11 00:50:02 +00:00
|
|
|
this.game.events.on('prestep', this.update, this);
|
2018-06-11 10:36:02 +00:00
|
|
|
this.game.events.on('poststep', this.postUpdate, this);
|
2018-01-31 03:38:10 +00:00
|
|
|
this.game.events.once('destroy', this.destroy, this);
|
2017-02-21 01:04:11 +00:00
|
|
|
},
|
|
|
|
|
2018-01-26 06:55:15 +00:00
|
|
|
/**
|
2018-06-04 12:24:47 +00:00
|
|
|
* Updates the Input Manager bounds rectangle to match the bounding client rectangle of the
|
|
|
|
* canvas element being used to track input events.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#updateBounds
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-12-13 22:08:15 +00:00
|
|
|
updateBounds: function ()
|
|
|
|
{
|
2018-01-22 12:04:14 +00:00
|
|
|
var bounds = this.bounds;
|
2017-12-13 22:08:15 +00:00
|
|
|
|
2018-02-28 14:27:28 +00:00
|
|
|
var clientRect = this.canvas.getBoundingClientRect();
|
|
|
|
|
|
|
|
bounds.x = clientRect.left + window.pageXOffset - document.documentElement.clientLeft;
|
|
|
|
bounds.y = clientRect.top + window.pageYOffset - document.documentElement.clientTop;
|
2018-01-22 12:04:14 +00:00
|
|
|
bounds.width = clientRect.width;
|
|
|
|
bounds.height = clientRect.height;
|
2017-12-13 22:08:15 +00:00
|
|
|
},
|
|
|
|
|
2018-02-28 14:27:28 +00:00
|
|
|
/**
|
2018-06-04 12:24:47 +00:00
|
|
|
* Resizes the Input Manager internal values, including the bounds and scale factor.
|
2018-02-28 14:27:28 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#resize
|
|
|
|
* @since 3.2.0
|
|
|
|
*/
|
|
|
|
resize: function ()
|
|
|
|
{
|
|
|
|
this.updateBounds();
|
|
|
|
|
|
|
|
// Game config size
|
|
|
|
var gw = this.game.config.width;
|
|
|
|
var gh = this.game.config.height;
|
|
|
|
|
|
|
|
// Actual canvas size
|
|
|
|
var bw = this.bounds.width;
|
|
|
|
var bh = this.bounds.height;
|
|
|
|
|
|
|
|
// Scale factor
|
|
|
|
this.scale.x = gw / bw;
|
|
|
|
this.scale.y = gh / bh;
|
|
|
|
},
|
|
|
|
|
2018-11-28 13:10:25 +00:00
|
|
|
/**
|
|
|
|
* Internal canvas state change, called automatically by the Mouse Manager.
|
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#setCanvasOver
|
|
|
|
* @private
|
|
|
|
* @since 3.16.0
|
|
|
|
*
|
|
|
|
* @param {number} event - The DOM Event.
|
|
|
|
*/
|
|
|
|
setCanvasOver: function (event)
|
|
|
|
{
|
|
|
|
this.isOver = true;
|
|
|
|
|
|
|
|
this._emitIsOverEvent = event;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Internal canvas state change, called automatically by the Mouse Manager.
|
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#setCanvasOut
|
|
|
|
* @private
|
|
|
|
* @since 3.16.0
|
|
|
|
*
|
|
|
|
* @param {number} event - The DOM Event.
|
|
|
|
*/
|
|
|
|
setCanvasOut: function (event)
|
|
|
|
{
|
|
|
|
this.isOver = false;
|
|
|
|
|
|
|
|
this._emitIsOverEvent = event;
|
|
|
|
},
|
|
|
|
|
2018-01-26 06:55:15 +00:00
|
|
|
/**
|
2018-06-04 12:24:47 +00:00
|
|
|
* Internal update loop, called automatically by the Game Step.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#update
|
2018-05-29 23:33:51 +00:00
|
|
|
* @private
|
2018-01-26 06:55:15 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-04 12:24:47 +00:00
|
|
|
* @param {number} time - The time stamp value of this game step.
|
2018-01-26 06:55:15 +00:00
|
|
|
*/
|
2018-11-23 16:25:31 +00:00
|
|
|
update: function (time)
|
2017-02-21 01:04:11 +00:00
|
|
|
{
|
2018-05-31 14:19:35 +00:00
|
|
|
var i;
|
|
|
|
|
2018-06-11 10:36:02 +00:00
|
|
|
this._setCursor = 0;
|
2018-06-08 18:04:12 +00:00
|
|
|
|
2018-05-25 18:28:18 +00:00
|
|
|
this.events.emit('update');
|
2017-06-14 00:20:01 +00:00
|
|
|
|
2018-01-20 04:44:54 +00:00
|
|
|
this.ignoreEvents = false;
|
|
|
|
|
2018-05-25 18:28:18 +00:00
|
|
|
this.dirty = false;
|
|
|
|
|
2017-06-14 00:20:01 +00:00
|
|
|
var len = this.queue.length;
|
|
|
|
|
2018-05-25 18:28:18 +00:00
|
|
|
var pointers = this.pointers;
|
2017-07-13 23:37:54 +00:00
|
|
|
|
2018-11-22 17:18:31 +00:00
|
|
|
for (i = 0; i < this.pointersTotal; i++)
|
2017-06-14 00:20:01 +00:00
|
|
|
{
|
2018-11-26 13:10:54 +00:00
|
|
|
pointers[i].reset(time);
|
2018-11-23 16:25:31 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!this.enabled || len === 0)
|
|
|
|
{
|
2018-11-23 18:58:13 +00:00
|
|
|
for (i = 0; i < this.pointersTotal; i++)
|
|
|
|
{
|
|
|
|
pointers[i].updateMotion();
|
|
|
|
}
|
|
|
|
|
2018-11-23 16:25:31 +00:00
|
|
|
return;
|
2017-06-14 00:20:01 +00:00
|
|
|
}
|
|
|
|
|
2018-11-23 16:25:31 +00:00
|
|
|
this.dirty = true;
|
|
|
|
|
|
|
|
this.updateBounds();
|
2017-12-13 22:08:15 +00:00
|
|
|
|
2018-11-23 16:25:31 +00:00
|
|
|
this.scale.x = this.game.config.width / this.bounds.width;
|
|
|
|
this.scale.y = this.game.config.height / this.bounds.height;
|
|
|
|
|
|
|
|
// 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);
|
|
|
|
var mouse = this.mousePointer;
|
|
|
|
|
|
|
|
// Process the event queue, dispatching all of the events that have stored up
|
|
|
|
for (i = 0; i < len; i += 2)
|
2017-06-14 00:20:01 +00:00
|
|
|
{
|
2018-11-23 16:25:31 +00:00
|
|
|
var type = queue[i];
|
|
|
|
var event = queue[i + 1];
|
2017-06-14 00:20:01 +00:00
|
|
|
|
2018-11-23 16:25:31 +00:00
|
|
|
switch (type)
|
2018-05-29 23:33:51 +00:00
|
|
|
{
|
2018-11-23 16:25:31 +00:00
|
|
|
case CONST.MOUSE_DOWN:
|
|
|
|
mouse.down(event, time);
|
|
|
|
break;
|
2018-11-22 17:18:31 +00:00
|
|
|
|
2018-11-23 16:25:31 +00:00
|
|
|
case CONST.MOUSE_MOVE:
|
|
|
|
mouse.move(event, time);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case CONST.MOUSE_UP:
|
|
|
|
mouse.up(event, time);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case CONST.TOUCH_START:
|
|
|
|
this.startPointer(event, time);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case CONST.TOUCH_MOVE:
|
|
|
|
this.updatePointer(event, time);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case CONST.TOUCH_END:
|
|
|
|
this.stopPointer(event, time);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case CONST.TOUCH_CANCEL:
|
|
|
|
this.cancelPointer(event, time);
|
|
|
|
break;
|
|
|
|
|
|
|
|
case CONST.POINTER_LOCK_CHANGE:
|
|
|
|
this.events.emit('pointerlockchange', event, this.mouse.locked);
|
|
|
|
break;
|
|
|
|
}
|
2018-11-22 17:18:31 +00:00
|
|
|
}
|
2018-11-23 18:58:13 +00:00
|
|
|
|
|
|
|
for (i = 0; i < this.pointersTotal; i++)
|
|
|
|
{
|
|
|
|
pointers[i].updateMotion();
|
|
|
|
}
|
2017-06-14 01:20:55 +00:00
|
|
|
},
|
|
|
|
|
2018-06-11 10:36:02 +00:00
|
|
|
/**
|
|
|
|
* Internal post-update, called automatically by the Game step.
|
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#postUpdate
|
|
|
|
* @private
|
|
|
|
* @since 3.10.0
|
|
|
|
*/
|
|
|
|
postUpdate: function ()
|
|
|
|
{
|
|
|
|
if (this._setCursor === 1)
|
|
|
|
{
|
|
|
|
this.canvas.style.cursor = this._customCursor;
|
|
|
|
}
|
|
|
|
else if (this._setCursor === 2)
|
|
|
|
{
|
|
|
|
this.canvas.style.cursor = this.defaultCursor;
|
|
|
|
}
|
2018-11-28 13:10:25 +00:00
|
|
|
|
|
|
|
// Reset the isOver event
|
|
|
|
this._emitIsOverEvent = null;
|
2018-06-11 10:36:02 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Tells the Input system to set a custom cursor.
|
|
|
|
*
|
|
|
|
* This cursor will be the default cursor used when interacting with the game canvas.
|
|
|
|
*
|
|
|
|
* If an Interactive Object also sets a custom cursor, this is the cursor that is reset after its use.
|
|
|
|
*
|
2018-06-11 10:50:37 +00:00
|
|
|
* Any valid CSS cursor value is allowed, including paths to image files, i.e.:
|
|
|
|
*
|
|
|
|
* ```javascript
|
|
|
|
* this.input.setDefaultCursor('url(assets/cursors/sword.cur), pointer');
|
|
|
|
* ```
|
|
|
|
*
|
|
|
|
* Please read about the differences between browsers when it comes to the file formats and sizes they support:
|
2018-06-11 10:36:02 +00:00
|
|
|
*
|
|
|
|
* https://developer.mozilla.org/en-US/docs/Web/CSS/cursor
|
|
|
|
* https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_User_Interface/Using_URL_values_for_the_cursor_property
|
|
|
|
*
|
|
|
|
* It's up to you to pick a suitable cursor format that works across the range of browsers you need to support.
|
|
|
|
*
|
2018-06-11 10:50:37 +00:00
|
|
|
* @method Phaser.Input.InputManager#setDefaultCursor
|
2018-06-11 10:36:02 +00:00
|
|
|
* @since 3.10.0
|
|
|
|
*
|
|
|
|
* @param {string} cursor - The CSS to be used when setting the default cursor.
|
|
|
|
*/
|
|
|
|
setDefaultCursor: function (cursor)
|
|
|
|
{
|
|
|
|
this.defaultCursor = cursor;
|
|
|
|
|
|
|
|
if (this.canvas.style.cursor !== cursor)
|
|
|
|
{
|
|
|
|
this.canvas.style.cursor = cursor;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Called by the InputPlugin when processing over and out events.
|
|
|
|
*
|
|
|
|
* Tells the Input Manager to set a custom cursor during its postUpdate step.
|
|
|
|
*
|
|
|
|
* https://developer.mozilla.org/en-US/docs/Web/CSS/cursor
|
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#setCursor
|
|
|
|
* @private
|
|
|
|
* @since 3.10.0
|
|
|
|
*
|
|
|
|
* @param {Phaser.Input.InteractiveObject} interactiveObject - The Interactive Object that called this method.
|
|
|
|
*/
|
|
|
|
setCursor: function (interactiveObject)
|
|
|
|
{
|
|
|
|
if (interactiveObject.cursor)
|
|
|
|
{
|
|
|
|
this._setCursor = 1;
|
|
|
|
this._customCursor = interactiveObject.cursor;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Called by the InputPlugin when processing over and out events.
|
|
|
|
*
|
|
|
|
* Tells the Input Manager to clear the hand cursor, if set, during its postUpdate step.
|
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#resetCursor
|
|
|
|
* @private
|
|
|
|
* @since 3.10.0
|
|
|
|
*
|
|
|
|
* @param {Phaser.Input.InteractiveObject} interactiveObject - The Interactive Object that called this method.
|
|
|
|
*/
|
|
|
|
resetCursor: function (interactiveObject)
|
|
|
|
{
|
|
|
|
if (interactiveObject.cursor)
|
|
|
|
{
|
|
|
|
this._setCursor = 2;
|
|
|
|
}
|
|
|
|
},
|
2018-06-08 18:04:12 +00:00
|
|
|
|
2018-05-25 18:28:18 +00:00
|
|
|
// event.targetTouches = list of all touches on the TARGET ELEMENT (i.e. game dom element)
|
|
|
|
// event.touches = list of all touches on the ENTIRE DOCUMENT, not just the target element
|
|
|
|
// event.changedTouches = the touches that CHANGED in this event, not the total number of them
|
2018-06-04 12:24:47 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Called by the main update loop when a Touch Start Event is received.
|
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#startPointer
|
|
|
|
* @private
|
|
|
|
* @since 3.10.0
|
|
|
|
*
|
|
|
|
* @param {TouchEvent} event - The native DOM event to be processed.
|
|
|
|
* @param {number} time - The time stamp value of this game step.
|
|
|
|
*/
|
2018-05-29 15:55:52 +00:00
|
|
|
startPointer: function (event, time)
|
2018-05-25 18:28:18 +00:00
|
|
|
{
|
|
|
|
var pointers = this.pointers;
|
|
|
|
|
2018-05-29 15:55:52 +00:00
|
|
|
for (var c = 0; c < event.changedTouches.length; c++)
|
2018-05-25 18:28:18 +00:00
|
|
|
{
|
2018-05-29 15:55:52 +00:00
|
|
|
var changedTouch = event.changedTouches[c];
|
2018-05-25 18:28:18 +00:00
|
|
|
|
2018-05-29 15:55:52 +00:00
|
|
|
for (var i = 1; i < this.pointersTotal; i++)
|
2018-05-25 18:28:18 +00:00
|
|
|
{
|
2018-05-29 15:55:52 +00:00
|
|
|
var pointer = pointers[i];
|
|
|
|
|
|
|
|
if (!pointer.active)
|
|
|
|
{
|
|
|
|
pointer.touchstart(changedTouch, time);
|
|
|
|
this.activePointer = pointer;
|
|
|
|
break;
|
|
|
|
}
|
2018-05-25 18:28:18 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2018-06-04 12:24:47 +00:00
|
|
|
/**
|
|
|
|
* Called by the main update loop when a Touch Move Event is received.
|
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#updatePointer
|
|
|
|
* @private
|
|
|
|
* @since 3.10.0
|
|
|
|
*
|
|
|
|
* @param {TouchEvent} event - The native DOM event to be processed.
|
|
|
|
* @param {number} time - The time stamp value of this game step.
|
|
|
|
*/
|
2018-05-29 15:55:52 +00:00
|
|
|
updatePointer: function (event, time)
|
2018-05-25 18:28:18 +00:00
|
|
|
{
|
|
|
|
var pointers = this.pointers;
|
|
|
|
|
2018-05-29 15:55:52 +00:00
|
|
|
for (var c = 0; c < event.changedTouches.length; c++)
|
2018-05-25 18:28:18 +00:00
|
|
|
{
|
2018-05-29 15:55:52 +00:00
|
|
|
var changedTouch = event.changedTouches[c];
|
2018-05-25 18:28:18 +00:00
|
|
|
|
2018-05-29 15:55:52 +00:00
|
|
|
for (var i = 1; i < this.pointersTotal; i++)
|
2018-05-25 18:28:18 +00:00
|
|
|
{
|
2018-05-29 15:55:52 +00:00
|
|
|
var pointer = pointers[i];
|
|
|
|
|
|
|
|
if (pointer.active && pointer.identifier === changedTouch.identifier)
|
|
|
|
{
|
|
|
|
pointer.touchmove(changedTouch, time);
|
|
|
|
this.activePointer = pointer;
|
|
|
|
break;
|
|
|
|
}
|
2018-05-25 18:28:18 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
// For touch end its a list of the touch points that have been removed from the surface
|
|
|
|
// https://developer.mozilla.org/en-US/docs/DOM/TouchList
|
|
|
|
// event.changedTouches = the touches that CHANGED in this event, not the total number of them
|
2018-06-04 12:24:47 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Called by the main update loop when a Touch End Event is received.
|
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#stopPointer
|
|
|
|
* @private
|
|
|
|
* @since 3.10.0
|
|
|
|
*
|
|
|
|
* @param {TouchEvent} event - The native DOM event to be processed.
|
|
|
|
* @param {number} time - The time stamp value of this game step.
|
|
|
|
*/
|
2018-05-29 15:55:52 +00:00
|
|
|
stopPointer: function (event, time)
|
2018-05-25 18:28:18 +00:00
|
|
|
{
|
|
|
|
var pointers = this.pointers;
|
|
|
|
|
2018-05-29 15:55:52 +00:00
|
|
|
for (var c = 0; c < event.changedTouches.length; c++)
|
2018-05-25 18:28:18 +00:00
|
|
|
{
|
2018-05-29 15:55:52 +00:00
|
|
|
var changedTouch = event.changedTouches[c];
|
2018-05-25 18:28:18 +00:00
|
|
|
|
2018-05-29 15:55:52 +00:00
|
|
|
for (var i = 1; i < this.pointersTotal; i++)
|
2018-05-25 18:28:18 +00:00
|
|
|
{
|
2018-05-29 15:55:52 +00:00
|
|
|
var pointer = pointers[i];
|
|
|
|
|
|
|
|
if (pointer.active && pointer.identifier === changedTouch.identifier)
|
|
|
|
{
|
|
|
|
pointer.touchend(changedTouch, time);
|
|
|
|
break;
|
|
|
|
}
|
2018-05-25 18:28:18 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2018-10-16 10:44:36 +00:00
|
|
|
/**
|
|
|
|
* Called by the main update loop when a Touch Cancel Event is received.
|
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#cancelPointer
|
|
|
|
* @private
|
|
|
|
* @since 3.15.0
|
|
|
|
*
|
|
|
|
* @param {TouchEvent} event - The native DOM event to be processed.
|
|
|
|
* @param {number} time - The time stamp value of this game step.
|
|
|
|
*/
|
|
|
|
cancelPointer: function (event, time)
|
|
|
|
{
|
|
|
|
var pointers = this.pointers;
|
|
|
|
|
|
|
|
for (var c = 0; c < event.changedTouches.length; c++)
|
|
|
|
{
|
|
|
|
var changedTouch = event.changedTouches[c];
|
|
|
|
|
|
|
|
for (var i = 1; i < this.pointersTotal; i++)
|
|
|
|
{
|
|
|
|
var pointer = pointers[i];
|
|
|
|
|
|
|
|
if (pointer.active && pointer.identifier === changedTouch.identifier)
|
|
|
|
{
|
|
|
|
pointer.touchend(changedTouch, time);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2018-05-25 18:28:18 +00:00
|
|
|
/**
|
2018-05-29 23:33:51 +00:00
|
|
|
* Adds new Pointer objects to the Input Manager.
|
2018-05-31 14:19:35 +00:00
|
|
|
*
|
2018-05-29 23:33:51 +00:00
|
|
|
* By default Phaser creates 2 pointer objects: `mousePointer` and `pointer1`.
|
2018-05-31 14:19:35 +00:00
|
|
|
*
|
2018-05-29 23:33:51 +00:00
|
|
|
* You can create more either by calling this method, or by setting the `input.activePointers` property
|
2018-06-11 12:39:28 +00:00
|
|
|
* in the Game Config, up to a maximum of 10 pointers.
|
2018-05-31 14:19:35 +00:00
|
|
|
*
|
2018-06-04 12:24:47 +00:00
|
|
|
* The first 10 pointers are available via the `InputPlugin.pointerX` properties, once they have been added
|
|
|
|
* via this method.
|
2018-05-29 23:33:51 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#addPointer
|
|
|
|
* @since 3.10.0
|
2018-05-25 18:28:18 +00:00
|
|
|
*
|
2018-06-11 12:39:28 +00:00
|
|
|
* @param {integer} [quantity=1] The number of new Pointers to create. A maximum of 10 is allowed in total.
|
2018-05-31 14:19:35 +00:00
|
|
|
*
|
2018-05-29 23:33:51 +00:00
|
|
|
* @return {Phaser.Input.Pointer[]} An array containing all of the new Pointer objects that were created.
|
2018-05-25 18:28:18 +00:00
|
|
|
*/
|
2018-05-29 23:33:51 +00:00
|
|
|
addPointer: function (quantity)
|
2018-05-25 18:28:18 +00:00
|
|
|
{
|
2018-05-29 23:33:51 +00:00
|
|
|
if (quantity === undefined) { quantity = 1; }
|
2018-05-25 18:28:18 +00:00
|
|
|
|
2018-05-29 23:33:51 +00:00
|
|
|
var output = [];
|
|
|
|
|
2018-06-11 12:39:28 +00:00
|
|
|
if (this.pointersTotal + quantity > 10)
|
|
|
|
{
|
|
|
|
quantity = 10 - this.pointersTotal;
|
|
|
|
}
|
|
|
|
|
2018-05-29 23:33:51 +00:00
|
|
|
for (var i = 0; i < quantity; i++)
|
2018-05-29 15:55:52 +00:00
|
|
|
{
|
2018-05-29 23:33:51 +00:00
|
|
|
var id = this.pointers.length;
|
|
|
|
|
|
|
|
var pointer = new Pointer(this, id);
|
|
|
|
|
2018-11-19 15:31:06 +00:00
|
|
|
pointer.smoothFactor = this.config.inputSmoothFactor;
|
|
|
|
|
2018-05-29 23:33:51 +00:00
|
|
|
this.pointers.push(pointer);
|
|
|
|
|
2018-05-29 15:55:52 +00:00
|
|
|
this.pointersTotal++;
|
2018-05-25 18:28:18 +00:00
|
|
|
|
2018-05-29 23:33:51 +00:00
|
|
|
output.push(pointer);
|
|
|
|
}
|
|
|
|
|
|
|
|
return output;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Process any pending DOM callbacks.
|
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#processDomCallbacks
|
|
|
|
* @private
|
|
|
|
* @since 3.10.0
|
|
|
|
*
|
|
|
|
* @param {array} once - The isOnce callbacks to invoke.
|
|
|
|
* @param {array} every - The every frame callbacks to invoke.
|
|
|
|
* @param {any} event - The native DOM event that is passed to the callbacks.
|
|
|
|
*
|
|
|
|
* @return {boolean} `true` if there are callbacks still in the list, otherwise `false`.
|
|
|
|
*/
|
|
|
|
processDomCallbacks: function (once, every, event)
|
|
|
|
{
|
|
|
|
var i = 0;
|
|
|
|
|
|
|
|
for (i = 0; i < once.length; i++)
|
|
|
|
{
|
|
|
|
once[i](event);
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i = 0; i < every.length; i++)
|
|
|
|
{
|
|
|
|
every[i](event);
|
|
|
|
}
|
|
|
|
|
|
|
|
return (every.length > 0);
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Queues a touch start event, as passed in by the TouchManager.
|
|
|
|
* Also dispatches any DOM callbacks for this event.
|
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#queueTouchStart
|
|
|
|
* @private
|
|
|
|
* @since 3.10.0
|
|
|
|
*
|
2018-06-04 12:24:47 +00:00
|
|
|
* @param {TouchEvent} event - The native DOM Touch event.
|
2018-05-29 23:33:51 +00:00
|
|
|
*/
|
|
|
|
queueTouchStart: function (event)
|
|
|
|
{
|
|
|
|
this.queue.push(CONST.TOUCH_START, event);
|
|
|
|
|
|
|
|
if (this._hasDownCallback)
|
|
|
|
{
|
|
|
|
var callbacks = this.domCallbacks;
|
|
|
|
|
|
|
|
this._hasDownCallback = this.processDomCallbacks(callbacks.downOnce, callbacks.down, event);
|
2019-01-04 14:03:21 +00:00
|
|
|
|
|
|
|
callbacks.downOnce = [];
|
2018-05-29 23:33:51 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Queues a touch move event, as passed in by the TouchManager.
|
|
|
|
* Also dispatches any DOM callbacks for this event.
|
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#queueTouchMove
|
|
|
|
* @private
|
|
|
|
* @since 3.10.0
|
|
|
|
*
|
2018-06-04 12:24:47 +00:00
|
|
|
* @param {TouchEvent} event - The native DOM Touch event.
|
2018-05-29 23:33:51 +00:00
|
|
|
*/
|
|
|
|
queueTouchMove: function (event)
|
|
|
|
{
|
|
|
|
this.queue.push(CONST.TOUCH_MOVE, event);
|
|
|
|
|
|
|
|
if (this._hasMoveCallback)
|
|
|
|
{
|
|
|
|
var callbacks = this.domCallbacks;
|
|
|
|
|
|
|
|
this._hasMoveCallback = this.processDomCallbacks(callbacks.moveOnce, callbacks.move, event);
|
2019-01-04 14:03:21 +00:00
|
|
|
|
|
|
|
callbacks.moveOnce = [];
|
2018-05-29 23:33:51 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Queues a touch end event, as passed in by the TouchManager.
|
|
|
|
* Also dispatches any DOM callbacks for this event.
|
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#queueTouchEnd
|
|
|
|
* @private
|
|
|
|
* @since 3.10.0
|
|
|
|
*
|
2018-06-04 12:24:47 +00:00
|
|
|
* @param {TouchEvent} event - The native DOM Touch event.
|
2018-05-29 23:33:51 +00:00
|
|
|
*/
|
|
|
|
queueTouchEnd: function (event)
|
|
|
|
{
|
|
|
|
this.queue.push(CONST.TOUCH_END, event);
|
|
|
|
|
|
|
|
if (this._hasUpCallback)
|
|
|
|
{
|
|
|
|
var callbacks = this.domCallbacks;
|
|
|
|
|
|
|
|
this._hasUpCallback = this.processDomCallbacks(callbacks.upOnce, callbacks.up, event);
|
2019-01-04 14:03:21 +00:00
|
|
|
|
|
|
|
callbacks.upOnce = [];
|
2018-05-29 23:33:51 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2018-10-16 10:44:36 +00:00
|
|
|
/**
|
|
|
|
* Queues a touch cancel event, as passed in by the TouchManager.
|
|
|
|
* Also dispatches any DOM callbacks for this event.
|
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#queueTouchCancel
|
|
|
|
* @private
|
|
|
|
* @since 3.15.0
|
|
|
|
*
|
|
|
|
* @param {TouchEvent} event - The native DOM Touch event.
|
|
|
|
*/
|
|
|
|
queueTouchCancel: function (event)
|
|
|
|
{
|
|
|
|
this.queue.push(CONST.TOUCH_CANCEL, event);
|
|
|
|
},
|
|
|
|
|
2018-05-29 23:33:51 +00:00
|
|
|
/**
|
|
|
|
* Queues a mouse down event, as passed in by the MouseManager.
|
|
|
|
* Also dispatches any DOM callbacks for this event.
|
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#queueMouseDown
|
|
|
|
* @private
|
|
|
|
* @since 3.10.0
|
|
|
|
*
|
2018-06-04 12:24:47 +00:00
|
|
|
* @param {MouseEvent} event - The native DOM Mouse event.
|
2018-05-29 23:33:51 +00:00
|
|
|
*/
|
|
|
|
queueMouseDown: function (event)
|
|
|
|
{
|
|
|
|
this.queue.push(CONST.MOUSE_DOWN, event);
|
|
|
|
|
|
|
|
if (this._hasDownCallback)
|
|
|
|
{
|
|
|
|
var callbacks = this.domCallbacks;
|
|
|
|
|
|
|
|
this._hasDownCallback = this.processDomCallbacks(callbacks.downOnce, callbacks.down, event);
|
2019-01-04 14:03:21 +00:00
|
|
|
|
|
|
|
callbacks.downOnce = [];
|
2018-05-29 23:33:51 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Queues a mouse move event, as passed in by the MouseManager.
|
|
|
|
* Also dispatches any DOM callbacks for this event.
|
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#queueMouseMove
|
|
|
|
* @private
|
|
|
|
* @since 3.10.0
|
|
|
|
*
|
2018-06-04 12:24:47 +00:00
|
|
|
* @param {MouseEvent} event - The native DOM Mouse event.
|
2018-05-29 23:33:51 +00:00
|
|
|
*/
|
|
|
|
queueMouseMove: function (event)
|
|
|
|
{
|
|
|
|
this.queue.push(CONST.MOUSE_MOVE, event);
|
|
|
|
|
|
|
|
if (this._hasMoveCallback)
|
|
|
|
{
|
|
|
|
var callbacks = this.domCallbacks;
|
|
|
|
|
|
|
|
this._hasMoveCallback = this.processDomCallbacks(callbacks.moveOnce, callbacks.move, event);
|
2019-01-04 14:03:21 +00:00
|
|
|
|
|
|
|
callbacks.moveOnce = [];
|
2018-05-29 23:33:51 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Queues a mouse up event, as passed in by the MouseManager.
|
|
|
|
* Also dispatches any DOM callbacks for this event.
|
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#queueMouseUp
|
|
|
|
* @private
|
|
|
|
* @since 3.10.0
|
|
|
|
*
|
2018-06-04 12:24:47 +00:00
|
|
|
* @param {MouseEvent} event - The native DOM Mouse event.
|
2018-05-29 23:33:51 +00:00
|
|
|
*/
|
|
|
|
queueMouseUp: function (event)
|
|
|
|
{
|
|
|
|
this.queue.push(CONST.MOUSE_UP, event);
|
|
|
|
|
|
|
|
if (this._hasUpCallback)
|
|
|
|
{
|
|
|
|
var callbacks = this.domCallbacks;
|
|
|
|
|
|
|
|
this._hasUpCallback = this.processDomCallbacks(callbacks.upOnce, callbacks.up, event);
|
2019-01-04 14:03:21 +00:00
|
|
|
|
|
|
|
callbacks.upOnce = [];
|
2018-05-29 23:33:51 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Adds a callback to be invoked whenever the native DOM `mouseup` or `touchend` events are received.
|
|
|
|
* By setting the `isOnce` argument you can control if the callback is called once,
|
|
|
|
* or every time the DOM event occurs.
|
|
|
|
*
|
|
|
|
* Callbacks passed to this method are invoked _immediately_ when the DOM event happens,
|
|
|
|
* within the scope of the DOM event handler. Therefore, they are considered as 'native'
|
|
|
|
* from the perspective of the browser. This means they can be used for tasks such as
|
|
|
|
* opening new browser windows, or anything which explicitly requires user input to activate.
|
|
|
|
* However, as a result of this, they come with their own risks, and as such should not be used
|
|
|
|
* for general game input, but instead be reserved for special circumstances.
|
|
|
|
*
|
|
|
|
* If all you're trying to do is execute a callback when a pointer is released, then
|
|
|
|
* please use the internal Input event system instead.
|
|
|
|
*
|
|
|
|
* Please understand that these callbacks are invoked when the browser feels like doing so,
|
|
|
|
* which may be entirely out of the normal flow of the Phaser Game Loop. Therefore, you should absolutely keep
|
|
|
|
* Phaser related operations to a minimum in these callbacks. For example, don't destroy Game Objects,
|
|
|
|
* change Scenes or manipulate internal systems, otherwise you run a very real risk of creating
|
|
|
|
* heisenbugs (https://en.wikipedia.org/wiki/Heisenbug) that prove a challenge to reproduce, never mind
|
|
|
|
* solve.
|
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#addUpCallback
|
|
|
|
* @since 3.10.0
|
|
|
|
*
|
|
|
|
* @param {function} callback - The callback to be invoked on this dom event.
|
|
|
|
* @param {boolean} [isOnce=true] - `true` if the callback will only be invoked once, `false` to call every time this event happens.
|
|
|
|
*
|
|
|
|
* @return {this} The Input Manager.
|
|
|
|
*/
|
|
|
|
addUpCallback: function (callback, isOnce)
|
|
|
|
{
|
|
|
|
if (isOnce === undefined) { isOnce = true; }
|
|
|
|
|
|
|
|
if (isOnce)
|
|
|
|
{
|
|
|
|
this.domCallbacks.upOnce.push(callback);
|
2018-05-29 15:55:52 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2018-05-29 23:33:51 +00:00
|
|
|
this.domCallbacks.up.push(callback);
|
|
|
|
}
|
2018-05-29 15:55:52 +00:00
|
|
|
|
2018-05-29 23:33:51 +00:00
|
|
|
this._hasUpCallback = true;
|
2018-05-25 18:28:18 +00:00
|
|
|
|
2018-05-29 23:33:51 +00:00
|
|
|
return this;
|
|
|
|
},
|
2018-05-29 15:55:52 +00:00
|
|
|
|
2018-05-29 23:33:51 +00:00
|
|
|
/**
|
|
|
|
* Adds a callback to be invoked whenever the native DOM `mousedown` or `touchstart` events are received.
|
|
|
|
* By setting the `isOnce` argument you can control if the callback is called once,
|
|
|
|
* or every time the DOM event occurs.
|
|
|
|
*
|
|
|
|
* Callbacks passed to this method are invoked _immediately_ when the DOM event happens,
|
|
|
|
* within the scope of the DOM event handler. Therefore, they are considered as 'native'
|
|
|
|
* from the perspective of the browser. This means they can be used for tasks such as
|
|
|
|
* opening new browser windows, or anything which explicitly requires user input to activate.
|
|
|
|
* However, as a result of this, they come with their own risks, and as such should not be used
|
|
|
|
* for general game input, but instead be reserved for special circumstances.
|
|
|
|
*
|
|
|
|
* If all you're trying to do is execute a callback when a pointer is down, then
|
|
|
|
* please use the internal Input event system instead.
|
|
|
|
*
|
|
|
|
* Please understand that these callbacks are invoked when the browser feels like doing so,
|
|
|
|
* which may be entirely out of the normal flow of the Phaser Game Loop. Therefore, you should absolutely keep
|
|
|
|
* Phaser related operations to a minimum in these callbacks. For example, don't destroy Game Objects,
|
|
|
|
* change Scenes or manipulate internal systems, otherwise you run a very real risk of creating
|
|
|
|
* heisenbugs (https://en.wikipedia.org/wiki/Heisenbug) that prove a challenge to reproduce, never mind
|
|
|
|
* solve.
|
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#addDownCallback
|
|
|
|
* @since 3.10.0
|
|
|
|
*
|
|
|
|
* @param {function} callback - The callback to be invoked on this dom event.
|
|
|
|
* @param {boolean} [isOnce=true] - `true` if the callback will only be invoked once, `false` to call every time this event happens.
|
|
|
|
*
|
|
|
|
* @return {this} The Input Manager.
|
|
|
|
*/
|
|
|
|
addDownCallback: function (callback, isOnce)
|
|
|
|
{
|
|
|
|
if (isOnce === undefined) { isOnce = true; }
|
|
|
|
|
|
|
|
if (isOnce)
|
|
|
|
{
|
|
|
|
this.domCallbacks.downOnce.push(callback);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
this.domCallbacks.down.push(callback);
|
|
|
|
}
|
|
|
|
|
|
|
|
this._hasDownCallback = true;
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Adds a callback to be invoked whenever the native DOM `mousemove` or `touchmove` events are received.
|
|
|
|
* By setting the `isOnce` argument you can control if the callback is called once,
|
|
|
|
* or every time the DOM event occurs.
|
|
|
|
*
|
|
|
|
* Callbacks passed to this method are invoked _immediately_ when the DOM event happens,
|
|
|
|
* within the scope of the DOM event handler. Therefore, they are considered as 'native'
|
|
|
|
* from the perspective of the browser. This means they can be used for tasks such as
|
|
|
|
* opening new browser windows, or anything which explicitly requires user input to activate.
|
|
|
|
* However, as a result of this, they come with their own risks, and as such should not be used
|
|
|
|
* for general game input, but instead be reserved for special circumstances.
|
|
|
|
*
|
|
|
|
* If all you're trying to do is execute a callback when a pointer is moved, then
|
|
|
|
* please use the internal Input event system instead.
|
|
|
|
*
|
|
|
|
* Please understand that these callbacks are invoked when the browser feels like doing so,
|
|
|
|
* which may be entirely out of the normal flow of the Phaser Game Loop. Therefore, you should absolutely keep
|
|
|
|
* Phaser related operations to a minimum in these callbacks. For example, don't destroy Game Objects,
|
|
|
|
* change Scenes or manipulate internal systems, otherwise you run a very real risk of creating
|
|
|
|
* heisenbugs (https://en.wikipedia.org/wiki/Heisenbug) that prove a challenge to reproduce, never mind
|
|
|
|
* solve.
|
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#addMoveCallback
|
|
|
|
* @since 3.10.0
|
|
|
|
*
|
|
|
|
* @param {function} callback - The callback to be invoked on this dom event.
|
|
|
|
* @param {boolean} [isOnce=false] - `true` if the callback will only be invoked once, `false` to call every time this event happens.
|
|
|
|
*
|
|
|
|
* @return {this} The Input Manager.
|
|
|
|
*/
|
|
|
|
addMoveCallback: function (callback, isOnce)
|
|
|
|
{
|
|
|
|
if (isOnce === undefined) { isOnce = false; }
|
|
|
|
|
|
|
|
if (isOnce)
|
|
|
|
{
|
|
|
|
this.domCallbacks.moveOnce.push(callback);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
this.domCallbacks.move.push(callback);
|
2018-05-29 15:55:52 +00:00
|
|
|
}
|
2018-05-29 23:33:51 +00:00
|
|
|
|
|
|
|
this._hasMoveCallback = true;
|
|
|
|
|
|
|
|
return this;
|
2018-05-25 18:28:18 +00:00
|
|
|
},
|
|
|
|
|
2018-06-04 20:04:27 +00:00
|
|
|
/**
|
|
|
|
* Checks if the given Game Object should be considered as a candidate for input or not.
|
|
|
|
*
|
|
|
|
* Checks if the Game Object has an input component that is enabled, that it will render,
|
|
|
|
* and finally, if it has a parent, that the parent parent, or any ancestor, is visible or not.
|
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#inputCandidate
|
|
|
|
* @private
|
|
|
|
* @since 3.10.0
|
|
|
|
*
|
|
|
|
* @param {Phaser.GameObjects.GameObject} gameObject - The Game Object to test.
|
2018-08-29 10:57:30 +00:00
|
|
|
* @param {Phaser.Cameras.Scene2D.Camera} camera - The Camera which is being tested against.
|
2018-06-04 20:04:27 +00:00
|
|
|
*
|
|
|
|
* @return {boolean} `true` if the Game Object should be considered for input, otherwise `false`.
|
|
|
|
*/
|
2018-08-29 10:57:30 +00:00
|
|
|
inputCandidate: function (gameObject, camera)
|
2018-06-04 20:04:27 +00:00
|
|
|
{
|
|
|
|
var input = gameObject.input;
|
|
|
|
|
2018-08-29 10:57:30 +00:00
|
|
|
if (!input || !input.enabled || !gameObject.willRender(camera))
|
2018-06-04 20:04:27 +00:00
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
var visible = true;
|
|
|
|
var parent = gameObject.parentContainer;
|
|
|
|
|
|
|
|
if (parent)
|
|
|
|
{
|
2018-06-05 00:08:32 +00:00
|
|
|
do
|
|
|
|
{
|
2018-08-29 10:57:30 +00:00
|
|
|
if (!parent.willRender(camera))
|
2018-06-04 20:04:27 +00:00
|
|
|
{
|
|
|
|
visible = false;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
parent = parent.parentContainer;
|
|
|
|
|
|
|
|
} while (parent);
|
|
|
|
}
|
|
|
|
|
|
|
|
return visible;
|
|
|
|
},
|
|
|
|
|
2018-01-26 06:55:15 +00:00
|
|
|
/**
|
2018-06-04 12:24:47 +00:00
|
|
|
* Performs a hit test using the given Pointer and camera, against an array of interactive Game Objects.
|
|
|
|
*
|
|
|
|
* The Game Objects are culled against the camera, and then the coordinates are translated into the local camera space
|
|
|
|
* and used to determine if they fall within the remaining Game Objects hit areas or not.
|
|
|
|
*
|
|
|
|
* If nothing is matched an empty array is returned.
|
|
|
|
*
|
|
|
|
* This method is called automatically by InputPlugin.hitTestPointer and doesn't usually need to be invoked directly.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#hitTest
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-04 12:24:47 +00:00
|
|
|
* @param {Phaser.Input.Pointer} pointer - The Pointer to test against.
|
|
|
|
* @param {array} gameObjects - An array of interactive Game Objects to check.
|
|
|
|
* @param {Phaser.Cameras.Scene2D.Camera} camera - The Camera which is being tested against.
|
|
|
|
* @param {array} [output] - An array to store the results in. If not given, a new empty array is created.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
2018-06-04 12:24:47 +00:00
|
|
|
* @return {array} An array of the Game Objects that were hit during this hit test.
|
2018-01-26 06:55:15 +00:00
|
|
|
*/
|
2018-06-04 12:24:47 +00:00
|
|
|
hitTest: function (pointer, gameObjects, camera, output)
|
2018-01-16 15:46:49 +00:00
|
|
|
{
|
|
|
|
if (output === undefined) { output = this._tempHitTest; }
|
|
|
|
|
|
|
|
var tempPoint = this._tempPoint;
|
2018-07-18 13:31:45 +00:00
|
|
|
|
|
|
|
var csx = camera.scrollX;
|
|
|
|
var csy = camera.scrollY;
|
2018-01-16 15:46:49 +00:00
|
|
|
|
|
|
|
output.length = 0;
|
|
|
|
|
2018-06-04 12:24:47 +00:00
|
|
|
var x = pointer.x;
|
|
|
|
var y = pointer.y;
|
|
|
|
|
2018-09-04 14:13:48 +00:00
|
|
|
if (camera.resolution !== 1)
|
2018-01-16 15:46:49 +00:00
|
|
|
{
|
2018-09-04 14:13:48 +00:00
|
|
|
x += camera._x;
|
|
|
|
y += camera._y;
|
2018-01-16 15:46:49 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// Stores the world point inside of tempPoint
|
|
|
|
camera.getWorldPoint(x, y, tempPoint);
|
|
|
|
|
2018-06-04 12:24:47 +00:00
|
|
|
pointer.worldX = tempPoint.x;
|
|
|
|
pointer.worldY = tempPoint.y;
|
|
|
|
|
2018-01-16 15:46:49 +00:00
|
|
|
var point = { x: 0, y: 0 };
|
|
|
|
|
2018-04-09 15:42:51 +00:00
|
|
|
var matrix = this._tempMatrix;
|
2018-08-29 15:08:04 +00:00
|
|
|
var parentMatrix = this._tempMatrix2;
|
2018-04-09 15:42:51 +00:00
|
|
|
|
2018-06-11 13:04:15 +00:00
|
|
|
for (var i = 0; i < gameObjects.length; i++)
|
2018-01-16 15:46:49 +00:00
|
|
|
{
|
2018-06-11 13:04:15 +00:00
|
|
|
var gameObject = gameObjects[i];
|
2018-01-16 15:46:49 +00:00
|
|
|
|
2018-08-29 10:57:30 +00:00
|
|
|
// Checks if the Game Object can receive input (isn't being ignored by the camera, invisible, etc)
|
|
|
|
// and also checks all of its parents, if any
|
|
|
|
if (!this.inputCandidate(gameObject, camera))
|
2018-01-16 15:46:49 +00:00
|
|
|
{
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2018-07-18 13:31:45 +00:00
|
|
|
var px = tempPoint.x + (csx * gameObject.scrollFactorX) - csx;
|
|
|
|
var py = tempPoint.y + (csy * gameObject.scrollFactorY) - csy;
|
2018-01-16 15:46:49 +00:00
|
|
|
|
2018-04-09 15:42:51 +00:00
|
|
|
if (gameObject.parentContainer)
|
|
|
|
{
|
2018-08-29 15:08:04 +00:00
|
|
|
gameObject.getWorldTransformMatrix(matrix, parentMatrix);
|
2018-04-09 15:42:51 +00:00
|
|
|
|
2018-08-29 15:08:04 +00:00
|
|
|
matrix.applyInverse(px, py, point);
|
2018-04-09 15:42:51 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
TransformXY(px, py, gameObject.x, gameObject.y, gameObject.rotation, gameObject.scaleX, gameObject.scaleY, point);
|
|
|
|
}
|
2018-09-04 13:04:48 +00:00
|
|
|
|
2018-01-16 15:46:49 +00:00
|
|
|
if (this.pointWithinHitArea(gameObject, point.x, point.y))
|
|
|
|
{
|
|
|
|
output.push(gameObject);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return output;
|
|
|
|
},
|
|
|
|
|
2018-01-26 06:55:15 +00:00
|
|
|
/**
|
2018-06-04 12:24:47 +00:00
|
|
|
* Checks if the given x and y coordinate are within the hit area of the Game Object.
|
|
|
|
*
|
|
|
|
* This method assumes that the coordinate values have already been translated into the space of the Game Object.
|
|
|
|
*
|
|
|
|
* If the coordinates are within the hit area they are set into the Game Objects Input `localX` and `localY` properties.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#pointWithinHitArea
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-04 12:24:47 +00:00
|
|
|
* @param {Phaser.GameObjects.GameObject} gameObject - The interactive Game Object to check against.
|
|
|
|
* @param {number} x - The translated x coordinate for the hit test.
|
|
|
|
* @param {number} y - The translated y coordinate for the hit test.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
2018-06-04 12:24:47 +00:00
|
|
|
* @return {boolean} `true` if the coordinates were inside the Game Objects hit area, otherwise `false`.
|
2018-01-26 06:55:15 +00:00
|
|
|
*/
|
2018-01-16 15:46:49 +00:00
|
|
|
pointWithinHitArea: function (gameObject, x, y)
|
2017-07-07 19:59:17 +00:00
|
|
|
{
|
2018-01-16 15:46:49 +00:00
|
|
|
// Normalize the origin
|
|
|
|
x += gameObject.displayOriginX;
|
|
|
|
y += gameObject.displayOriginY;
|
|
|
|
|
2018-06-04 12:24:47 +00:00
|
|
|
var input = gameObject.input;
|
|
|
|
|
|
|
|
if (input && input.hitAreaCallback(input.hitArea, x, y, gameObject))
|
2018-01-16 15:46:49 +00:00
|
|
|
{
|
|
|
|
input.localX = x;
|
|
|
|
input.localY = y;
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2018-01-26 06:55:15 +00:00
|
|
|
/**
|
2018-06-04 12:24:47 +00:00
|
|
|
* Checks if the given x and y coordinate are within the hit area of the Interactive Object.
|
|
|
|
*
|
|
|
|
* This method assumes that the coordinate values have already been translated into the space of the Interactive Object.
|
|
|
|
*
|
|
|
|
* If the coordinates are within the hit area they are set into the Interactive Objects Input `localX` and `localY` properties.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#pointWithinInteractiveObject
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-04 12:24:47 +00:00
|
|
|
* @param {Phaser.Input.InteractiveObject} object - The Interactive Object to check against.
|
|
|
|
* @param {number} x - The translated x coordinate for the hit test.
|
|
|
|
* @param {number} y - The translated y coordinate for the hit test.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
2018-06-04 12:24:47 +00:00
|
|
|
* @return {boolean} `true` if the coordinates were inside the Game Objects hit area, otherwise `false`.
|
2018-01-26 06:55:15 +00:00
|
|
|
*/
|
2018-01-16 15:46:49 +00:00
|
|
|
pointWithinInteractiveObject: function (object, x, y)
|
|
|
|
{
|
|
|
|
if (!object.hitArea)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Normalize the origin
|
|
|
|
x += object.gameObject.displayOriginX;
|
|
|
|
y += object.gameObject.displayOriginY;
|
|
|
|
|
|
|
|
object.localX = x;
|
|
|
|
object.localY = y;
|
|
|
|
|
|
|
|
return object.hitAreaCallback(object.hitArea, x, y, object);
|
2017-07-17 22:38:43 +00:00
|
|
|
},
|
|
|
|
|
2018-06-04 14:19:11 +00:00
|
|
|
/**
|
|
|
|
* Transforms the pageX and pageY values of a Pointer into the scaled coordinate space of the Input Manager.
|
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#transformPointer
|
|
|
|
* @since 3.10.0
|
|
|
|
*
|
|
|
|
* @param {Phaser.Input.Pointer} pointer - The Pointer to transform the values for.
|
2018-07-18 13:31:45 +00:00
|
|
|
* @param {number} pageX - The Page X value.
|
|
|
|
* @param {number} pageY - The Page Y value.
|
2018-11-19 15:31:06 +00:00
|
|
|
* @param {boolean} wasMove - Are we transforming the Pointer from a move event, or an up / down event?
|
2018-06-04 14:19:11 +00:00
|
|
|
*/
|
2018-11-19 15:31:06 +00:00
|
|
|
transformPointer: function (pointer, pageX, pageY, wasMove)
|
2018-06-04 14:19:11 +00:00
|
|
|
{
|
2018-11-19 15:31:06 +00:00
|
|
|
var p0 = pointer.position;
|
|
|
|
var p1 = pointer.prevPosition;
|
|
|
|
|
2018-11-23 16:25:31 +00:00
|
|
|
// Store previous position
|
|
|
|
p1.x = p0.x;
|
|
|
|
p1.y = p0.y;
|
|
|
|
|
2018-11-19 15:31:06 +00:00
|
|
|
// Translate coordinates
|
|
|
|
var x = (pageX - this.bounds.left) * this.scale.x;
|
|
|
|
var y = (pageY - this.bounds.top) * this.scale.y;
|
2018-07-11 11:34:00 +00:00
|
|
|
|
2018-11-19 15:31:06 +00:00
|
|
|
var a = pointer.smoothFactor;
|
|
|
|
|
|
|
|
if (!wasMove || a === 0)
|
|
|
|
{
|
|
|
|
// Set immediately
|
|
|
|
p0.x = x;
|
|
|
|
p0.y = y;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// Apply smoothing
|
|
|
|
p0.x = x * a + p1.x * (1 - a);
|
|
|
|
p0.y = y * a + p1.y * (1 - a);
|
|
|
|
}
|
2018-06-04 14:19:11 +00:00
|
|
|
},
|
|
|
|
|
2018-01-26 06:55:15 +00:00
|
|
|
/**
|
2018-06-04 12:24:47 +00:00
|
|
|
* Transforms the pageX value into the scaled coordinate space of the Input Manager.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#transformX
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-04 12:24:47 +00:00
|
|
|
* @param {number} pageX - The DOM pageX value.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
2018-06-04 12:24:47 +00:00
|
|
|
* @return {number} The translated value.
|
2018-01-26 06:55:15 +00:00
|
|
|
*/
|
2017-07-17 22:38:43 +00:00
|
|
|
transformX: function (pageX)
|
|
|
|
{
|
2017-12-13 22:08:15 +00:00
|
|
|
return (pageX - this.bounds.left) * this.scale.x;
|
2017-07-17 22:38:43 +00:00
|
|
|
},
|
|
|
|
|
2018-01-26 06:55:15 +00:00
|
|
|
/**
|
2018-06-04 12:24:47 +00:00
|
|
|
* Transforms the pageY value into the scaled coordinate space of the Input Manager.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#transformY
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-04 12:24:47 +00:00
|
|
|
* @param {number} pageY - The DOM pageY value.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
2018-06-04 12:24:47 +00:00
|
|
|
* @return {number} The translated value.
|
2018-01-26 06:55:15 +00:00
|
|
|
*/
|
2017-07-17 22:38:43 +00:00
|
|
|
transformY: function (pageY)
|
|
|
|
{
|
2017-12-13 22:08:15 +00:00
|
|
|
return (pageY - this.bounds.top) * this.scale.y;
|
2017-07-17 22:38:43 +00:00
|
|
|
},
|
|
|
|
|
2018-01-26 06:55:15 +00:00
|
|
|
/**
|
2018-06-04 12:24:47 +00:00
|
|
|
* Returns the left offset of the Input bounds.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#getOffsetX
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-04 12:24:47 +00:00
|
|
|
* @return {number} The left bounds value.
|
2018-01-26 06:55:15 +00:00
|
|
|
*/
|
2017-07-17 22:38:43 +00:00
|
|
|
getOffsetX: function ()
|
|
|
|
{
|
2017-12-13 22:08:15 +00:00
|
|
|
return this.bounds.left;
|
2017-07-17 22:38:43 +00:00
|
|
|
},
|
|
|
|
|
2018-01-26 06:55:15 +00:00
|
|
|
/**
|
2018-06-04 12:24:47 +00:00
|
|
|
* Returns the top offset of the Input bounds.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#getOffsetY
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-04 12:24:47 +00:00
|
|
|
* @return {number} The top bounds value.
|
2018-01-26 06:55:15 +00:00
|
|
|
*/
|
2017-07-17 22:38:43 +00:00
|
|
|
getOffsetY: function ()
|
|
|
|
{
|
2017-12-13 22:08:15 +00:00
|
|
|
return this.bounds.top;
|
2017-07-17 22:38:43 +00:00
|
|
|
},
|
|
|
|
|
2018-01-26 06:55:15 +00:00
|
|
|
/**
|
2018-06-04 12:24:47 +00:00
|
|
|
* Returns the horizontal Input Scale value.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#getScaleX
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-04 12:24:47 +00:00
|
|
|
* @return {number} The horizontal scale factor of the input.
|
2018-01-26 06:55:15 +00:00
|
|
|
*/
|
2017-07-17 22:38:43 +00:00
|
|
|
getScaleX: function ()
|
|
|
|
{
|
2017-12-13 22:08:15 +00:00
|
|
|
return this.game.config.width / this.bounds.width;
|
2017-07-17 22:38:43 +00:00
|
|
|
},
|
|
|
|
|
2018-01-26 06:55:15 +00:00
|
|
|
/**
|
2018-06-04 12:24:47 +00:00
|
|
|
* Returns the vertical Input Scale value.
|
2018-01-26 06:55:15 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#getScaleY
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-04 12:24:47 +00:00
|
|
|
* @return {number} The vertical scale factor of the input.
|
2018-01-26 06:55:15 +00:00
|
|
|
*/
|
2017-07-17 22:38:43 +00:00
|
|
|
getScaleY: function ()
|
|
|
|
{
|
2017-12-13 22:08:15 +00:00
|
|
|
return this.game.config.height / this.bounds.height;
|
2018-01-31 03:38:10 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
2018-06-04 12:24:47 +00:00
|
|
|
* Destroys the Input Manager and all of its systems.
|
|
|
|
*
|
|
|
|
* There is no way to recover from doing this.
|
2018-01-31 03:38:10 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Input.InputManager#destroy
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
|
|
|
destroy: function ()
|
|
|
|
{
|
|
|
|
this.events.removeAllListeners();
|
|
|
|
|
2018-12-05 11:16:45 +00:00
|
|
|
if (this.keyboard)
|
|
|
|
{
|
|
|
|
this.keyboard.destroy();
|
|
|
|
}
|
|
|
|
|
2018-06-04 12:24:47 +00:00
|
|
|
if (this.mouse)
|
|
|
|
{
|
|
|
|
this.mouse.destroy();
|
|
|
|
}
|
2018-01-31 03:38:10 +00:00
|
|
|
|
2018-06-04 12:24:47 +00:00
|
|
|
if (this.touch)
|
|
|
|
{
|
|
|
|
this.touch.destroy();
|
|
|
|
}
|
2018-01-31 03:38:10 +00:00
|
|
|
|
2018-06-04 12:24:47 +00:00
|
|
|
for (var i = 0; i < this.pointers.length; i++)
|
|
|
|
{
|
|
|
|
this.pointers[i].destroy();
|
|
|
|
}
|
|
|
|
|
|
|
|
this.domCallbacks = {};
|
|
|
|
this.pointers = [];
|
|
|
|
this.queue = [];
|
|
|
|
this._tempHitTest = [];
|
|
|
|
this._tempMatrix.destroy();
|
|
|
|
this.canvas = null;
|
2018-01-31 03:38:10 +00:00
|
|
|
this.game = null;
|
2017-02-21 01:04:11 +00:00
|
|
|
}
|
|
|
|
|
2017-06-30 14:47:51 +00:00
|
|
|
});
|
2017-02-21 01:04:11 +00:00
|
|
|
|
2018-01-16 16:14:21 +00:00
|
|
|
module.exports = InputManager;
|