2018-06-08 14:15:36 +00:00
|
|
|
/**
|
|
|
|
* @author Richard Davey <rich@photonstorm.com>
|
2019-01-15 16:20:22 +00:00
|
|
|
* @copyright 2019 Photon Storm Ltd.
|
2019-05-10 15:15:04 +00:00
|
|
|
* @license {@link https://opensource.org/licenses/MIT|MIT License}
|
2018-06-08 14:15:36 +00:00
|
|
|
*/
|
|
|
|
|
2018-06-08 15:18:32 +00:00
|
|
|
var GetValue = require('../utils/object/GetValue');
|
|
|
|
|
2018-06-08 14:15:36 +00:00
|
|
|
// Contains the plugins that Phaser uses globally and locally.
|
|
|
|
// These are the source objects, not instantiated.
|
|
|
|
var inputPlugins = {};
|
|
|
|
|
2019-01-31 14:47:50 +00:00
|
|
|
/**
|
|
|
|
* @namespace Phaser.Input.InputPluginCache
|
|
|
|
*/
|
|
|
|
|
2018-06-08 14:15:36 +00:00
|
|
|
var InputPluginCache = {};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Static method called directly by the Core internal Plugins.
|
|
|
|
* Key is a reference used to get the plugin from the plugins object (i.e. InputPlugin)
|
|
|
|
* Plugin is the object to instantiate to create the plugin
|
|
|
|
* Mapping is what the plugin is injected into the Scene.Systems as (i.e. input)
|
|
|
|
*
|
2019-01-31 14:47:50 +00:00
|
|
|
* @name Phaser.Input.InputPluginCache.register
|
|
|
|
* @type {function}
|
|
|
|
* @static
|
2018-06-08 14:15:36 +00:00
|
|
|
* @since 3.10.0
|
|
|
|
*
|
|
|
|
* @param {string} key - A reference used to get this plugin from the plugin cache.
|
|
|
|
* @param {function} plugin - The plugin to be stored. Should be the core object, not instantiated.
|
|
|
|
* @param {string} mapping - If this plugin is to be injected into the Input Plugin, this is the property key used.
|
2018-06-08 15:18:32 +00:00
|
|
|
* @param {string} settingsKey - The key in the Scene Settings to check to see if this plugin should install or not.
|
|
|
|
* @param {string} configKey - The key in the Game Config to check to see if this plugin should install or not.
|
2018-06-08 14:15:36 +00:00
|
|
|
*/
|
2018-06-08 15:18:32 +00:00
|
|
|
InputPluginCache.register = function (key, plugin, mapping, settingsKey, configKey)
|
2018-06-08 14:15:36 +00:00
|
|
|
{
|
2018-06-08 15:18:32 +00:00
|
|
|
inputPlugins[key] = { plugin: plugin, mapping: mapping, settingsKey: settingsKey, configKey: configKey };
|
2018-06-08 14:15:36 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns the input plugin object from the cache based on the given key.
|
|
|
|
*
|
2019-01-31 14:47:50 +00:00
|
|
|
* @name Phaser.Input.InputPluginCache.getCore
|
|
|
|
* @type {function}
|
|
|
|
* @static
|
2018-06-08 14:15:36 +00:00
|
|
|
* @since 3.10.0
|
|
|
|
*
|
|
|
|
* @param {string} key - The key of the input plugin to get.
|
|
|
|
*
|
2019-05-09 11:02:03 +00:00
|
|
|
* @return {Phaser.Types.Input.InputPluginContainer} The input plugin object.
|
2018-06-08 14:15:36 +00:00
|
|
|
*/
|
|
|
|
InputPluginCache.getPlugin = function (key)
|
|
|
|
{
|
|
|
|
return inputPlugins[key];
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Installs all of the registered Input Plugins into the given target.
|
|
|
|
*
|
2019-01-31 14:47:50 +00:00
|
|
|
* @name Phaser.Input.InputPluginCache.install
|
|
|
|
* @type {function}
|
|
|
|
* @static
|
2018-06-08 14:15:36 +00:00
|
|
|
* @since 3.10.0
|
|
|
|
*
|
|
|
|
* @param {Phaser.Input.InputPlugin} target - The target InputPlugin to install the plugins into.
|
|
|
|
*/
|
|
|
|
InputPluginCache.install = function (target)
|
|
|
|
{
|
2018-06-08 15:18:32 +00:00
|
|
|
var sys = target.scene.sys;
|
|
|
|
var settings = sys.settings.input;
|
|
|
|
var config = sys.game.config;
|
|
|
|
|
2018-06-08 14:15:36 +00:00
|
|
|
for (var key in inputPlugins)
|
|
|
|
{
|
|
|
|
var source = inputPlugins[key].plugin;
|
|
|
|
var mapping = inputPlugins[key].mapping;
|
2018-06-08 15:18:32 +00:00
|
|
|
var settingsKey = inputPlugins[key].settingsKey;
|
|
|
|
var configKey = inputPlugins[key].configKey;
|
|
|
|
|
|
|
|
if (GetValue(settings, settingsKey, config[configKey]))
|
|
|
|
{
|
|
|
|
target[mapping] = new source(target);
|
|
|
|
}
|
2018-06-08 14:15:36 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Removes an input plugin based on the given key.
|
|
|
|
*
|
2019-01-31 14:47:50 +00:00
|
|
|
* @name Phaser.Input.InputPluginCache.remove
|
|
|
|
* @type {function}
|
|
|
|
* @static
|
2018-06-08 14:15:36 +00:00
|
|
|
* @since 3.10.0
|
|
|
|
*
|
|
|
|
* @param {string} key - The key of the input plugin to remove.
|
|
|
|
*/
|
|
|
|
InputPluginCache.remove = function (key)
|
|
|
|
{
|
|
|
|
if (inputPlugins.hasOwnProperty(key))
|
|
|
|
{
|
|
|
|
delete inputPlugins[key];
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
module.exports = InputPluginCache;
|