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 19:49:13 +00:00
|
|
|
var CONST = require('./const');
|
|
|
|
var GetValue = require('../utils/object/GetValue');
|
2018-04-09 19:16:45 +00:00
|
|
|
var Merge = require('../utils/object/Merge');
|
2017-06-29 23:32:18 +00:00
|
|
|
var InjectionMap = require('./InjectionMap');
|
2016-11-29 13:01:16 +00:00
|
|
|
|
2018-04-16 14:11:51 +00:00
|
|
|
/**
|
|
|
|
* @namespace Phaser.Scenes.Settings
|
|
|
|
*/
|
2018-03-22 12:51:30 +00:00
|
|
|
|
2018-02-12 15:18:31 +00:00
|
|
|
/**
|
2018-04-16 14:11:51 +00:00
|
|
|
* @typedef {object} Phaser.Scenes.Settings.Config
|
2018-02-12 15:18:31 +00:00
|
|
|
*
|
2018-10-19 14:53:04 +00:00
|
|
|
* @property {string} [key] - The unique key of this Scene. Must be unique within the entire Game instance.
|
|
|
|
* @property {boolean} [active=false] - Does the Scene start as active or not? An active Scene updates each step.
|
|
|
|
* @property {boolean} [visible=true] - Does the Scene start as visible or not? A visible Scene renders each step.
|
|
|
|
* @property {(false|Phaser.Loader.FileTypes.PackFileConfig)} [pack=false] - An optional Loader Packfile to be loaded before the Scene begins.
|
|
|
|
* @property {?(InputJSONCameraObject|InputJSONCameraObject[])} [cameras=null] - An optional Camera configuration object.
|
2018-04-09 19:32:19 +00:00
|
|
|
* @property {Object.<string, string>} [map] - Overwrites the default injection map for a scene.
|
|
|
|
* @property {Object.<string, string>} [mapAdd] - Extends the injection map for a scene.
|
2018-10-19 14:53:04 +00:00
|
|
|
* @property {object} [physics={}] - The physics configuration object for the Scene.
|
|
|
|
* @property {object} [loader={}] - The loader configuration object for the Scene.
|
|
|
|
* @property {(false|*)} [plugins=false] - The plugin configuration object for the Scene.
|
2018-03-21 13:41:17 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2018-04-16 14:11:51 +00:00
|
|
|
* @typedef {object} Phaser.Scenes.Settings.Object
|
2018-02-12 15:18:31 +00:00
|
|
|
*
|
2018-10-19 14:53:04 +00:00
|
|
|
* @property {number} status - The current status of the Scene. Maps to the Scene constants.
|
|
|
|
* @property {string} key - The unique key of this Scene. Unique within the entire Game instance.
|
|
|
|
* @property {boolean} active - The active state of this Scene. An active Scene updates each step.
|
|
|
|
* @property {boolean} visible - The visible state of this Scene. A visible Scene renders each step.
|
|
|
|
* @property {boolean} isBooted - Has the Scene finished booting?
|
|
|
|
* @property {boolean} isTransition - Is the Scene in a state of transition?
|
|
|
|
* @property {?Phaser.Scene} transitionFrom - The Scene this Scene is transitioning from, if set.
|
|
|
|
* @property {integer} transitionDuration - The duration of the transition, if set.
|
|
|
|
* @property {boolean} transitionAllowInput - Is this Scene allowed to receive input during transitions?
|
|
|
|
* @property {object} data - a data bundle passed to this Scene from the Scene Manager.
|
|
|
|
* @property {(false|Phaser.Loader.FileTypes.PackFileConfig)} pack - The Loader Packfile to be loaded before the Scene begins.
|
|
|
|
* @property {?(InputJSONCameraObject|InputJSONCameraObject[])} cameras - The Camera configuration object.
|
|
|
|
* @property {Object.<string, string>} map - The Scene's Injection Map.
|
|
|
|
* @property {object} physics - The physics configuration object for the Scene.
|
|
|
|
* @property {object} loader - The loader configuration object for the Scene.
|
|
|
|
* @property {(false|*)} plugins - The plugin configuration object for the Scene.
|
2018-02-12 15:18:31 +00:00
|
|
|
*/
|
2018-03-21 13:41:17 +00:00
|
|
|
|
2017-02-06 23:59:15 +00:00
|
|
|
var Settings = {
|
|
|
|
|
2018-03-21 13:41:17 +00:00
|
|
|
/**
|
2018-10-19 14:53:04 +00:00
|
|
|
* Takes a Scene configuration object and returns a fully formed System Settings object.
|
2018-03-21 13:41:17 +00:00
|
|
|
*
|
|
|
|
* @function Phaser.Scenes.Settings.create
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-10-19 14:53:04 +00:00
|
|
|
* @param {(string|Phaser.Scenes.Settings.Config)} config - The Scene configuration object used to create this Scene Settings.
|
2018-03-21 13:41:17 +00:00
|
|
|
*
|
2018-10-19 14:53:04 +00:00
|
|
|
* @return {Phaser.Scenes.Settings.Object} The Scene Settings object created as a result of the config and default settings.
|
2018-03-21 13:41:17 +00:00
|
|
|
*/
|
2017-02-06 23:59:15 +00:00
|
|
|
create: function (config)
|
2016-11-29 13:01:16 +00:00
|
|
|
{
|
2017-02-06 23:59:15 +00:00
|
|
|
if (typeof config === 'string')
|
|
|
|
{
|
|
|
|
config = { key: config };
|
|
|
|
}
|
|
|
|
else if (config === undefined)
|
|
|
|
{
|
|
|
|
// Pass the 'hasOwnProperty' checks
|
|
|
|
config = {};
|
|
|
|
}
|
2016-11-29 13:01:16 +00:00
|
|
|
|
2017-02-06 23:59:15 +00:00
|
|
|
return {
|
2016-11-29 13:01:16 +00:00
|
|
|
|
2017-02-06 23:59:15 +00:00
|
|
|
status: CONST.PENDING,
|
2016-11-29 13:01:16 +00:00
|
|
|
|
2017-07-03 11:24:18 +00:00
|
|
|
key: GetValue(config, 'key', ''),
|
2017-04-26 15:03:14 +00:00
|
|
|
active: GetValue(config, 'active', false),
|
|
|
|
visible: GetValue(config, 'visible', true),
|
2017-02-07 18:44:26 +00:00
|
|
|
|
2018-01-18 13:59:32 +00:00
|
|
|
isBooted: false,
|
|
|
|
|
2018-04-13 19:12:29 +00:00
|
|
|
isTransition: false,
|
|
|
|
transitionFrom: null,
|
2018-04-14 03:24:05 +00:00
|
|
|
transitionDuration: 0,
|
|
|
|
transitionAllowInput: true,
|
2018-04-13 19:12:29 +00:00
|
|
|
|
2017-02-07 18:44:26 +00:00
|
|
|
// Loader payload array
|
|
|
|
|
2017-02-17 02:07:56 +00:00
|
|
|
data: {},
|
|
|
|
|
2018-05-04 13:33:28 +00:00
|
|
|
pack: GetValue(config, 'pack', false),
|
2016-11-29 13:01:16 +00:00
|
|
|
|
2017-06-29 15:49:05 +00:00
|
|
|
// Cameras
|
2017-01-26 04:06:10 +00:00
|
|
|
|
2017-06-29 15:49:05 +00:00
|
|
|
cameras: GetValue(config, 'cameras', null),
|
|
|
|
|
2017-07-14 13:30:20 +00:00
|
|
|
// Scene Property Injection Map
|
2017-06-29 23:32:18 +00:00
|
|
|
|
2018-04-09 19:16:45 +00:00
|
|
|
map: GetValue(config, 'map', Merge(InjectionMap, GetValue(config, 'mapAdd', {}))),
|
2017-06-29 23:32:18 +00:00
|
|
|
|
2017-08-18 00:42:14 +00:00
|
|
|
// Physics
|
2018-01-18 05:18:45 +00:00
|
|
|
|
2017-08-18 00:42:14 +00:00
|
|
|
physics: GetValue(config, 'physics', {}),
|
|
|
|
|
2018-01-19 16:56:41 +00:00
|
|
|
// Loader
|
|
|
|
|
|
|
|
loader: GetValue(config, 'loader', {}),
|
|
|
|
|
2018-01-18 05:18:45 +00:00
|
|
|
// Plugins
|
|
|
|
|
2018-06-08 14:16:09 +00:00
|
|
|
plugins: GetValue(config, 'plugins', false),
|
|
|
|
|
|
|
|
// Input
|
|
|
|
|
|
|
|
input: GetValue(config, 'input', {})
|
2017-02-06 23:59:15 +00:00
|
|
|
|
|
|
|
};
|
2017-06-29 15:49:05 +00:00
|
|
|
}
|
2017-02-06 23:59:15 +00:00
|
|
|
|
2016-11-29 13:01:16 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
module.exports = Settings;
|