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 15:06:47 +00:00
|
|
|
var Camera = require('./Camera');
|
|
|
|
var Class = require('../../utils/Class');
|
|
|
|
var GetFastValue = require('../../utils/object/GetFastValue');
|
2018-05-15 11:51:50 +00:00
|
|
|
var PluginCache = require('../../plugins/PluginCache');
|
2018-01-16 15:06:47 +00:00
|
|
|
var RectangleContains = require('../../geom/rectangle/Contains');
|
|
|
|
|
2018-03-22 12:51:30 +00:00
|
|
|
/**
|
|
|
|
* @typedef {object} InputJSONCameraObject
|
|
|
|
*
|
2018-06-26 16:24:51 +00:00
|
|
|
* @property {string} [name=''] - The name of the Camera.
|
|
|
|
* @property {integer} [x=0] - The horizontal position of the Camera viewport.
|
|
|
|
* @property {integer} [y=0] - The vertical position of the Camera viewport.
|
|
|
|
* @property {integer} [width] - The width of the Camera viewport.
|
|
|
|
* @property {integer} [height] - The height of the Camera viewport.
|
2018-06-26 22:19:14 +00:00
|
|
|
* @property {number} [zoom=1] - The default zoom level of the Camera.
|
|
|
|
* @property {number} [rotation=0] - The rotation of the Camera, in radians.
|
2018-06-26 16:24:51 +00:00
|
|
|
* @property {boolean} [roundPixels=false] - Should the Camera round pixels before rendering?
|
2018-06-26 22:19:14 +00:00
|
|
|
* @property {number} [scrollX=0] - The horizontal scroll position of the Camera.
|
|
|
|
* @property {number} [scrollY=0] - The vertical scroll position of the Camera.
|
2018-06-26 16:24:51 +00:00
|
|
|
* @property {(false|string)} [backgroundColor=false] - A CSS color string controlling the Camera background color.
|
|
|
|
* @property {?object} [bounds] - Defines the Camera bounds.
|
|
|
|
* @property {number} [bounds.x=0] - The top-left extent of the Camera bounds.
|
|
|
|
* @property {number} [bounds.y=0] - The top-left extent of the Camera bounds.
|
|
|
|
* @property {number} [bounds.width] - The width of the Camera bounds.
|
|
|
|
* @property {number} [bounds.height] - The height of the Camera bounds.
|
2018-03-22 12:51:30 +00:00
|
|
|
*/
|
|
|
|
|
2018-02-07 15:27:21 +00:00
|
|
|
/**
|
|
|
|
* @classdesc
|
2018-06-26 16:24:51 +00:00
|
|
|
* The Camera Manager is a plugin that belongs to a Scene and is responsible for managing all of the Scene Cameras.
|
|
|
|
*
|
|
|
|
* By default you can access the Camera Manager from within a Scene using `this.cameras`, although this can be changed
|
|
|
|
* in your game config.
|
|
|
|
*
|
|
|
|
* Create new Cameras using the `add` method. Or extend the Camera class with your own addition code and then add
|
|
|
|
* the new Camera in using the `addExisting` method.
|
|
|
|
*
|
|
|
|
* Cameras provide a view into your game world, and can be positioned, rotated, zoomed and scrolled accordingly.
|
|
|
|
*
|
|
|
|
* A Camera consists of two elements: The viewport and the scroll values.
|
|
|
|
*
|
|
|
|
* The viewport is the physical position and size of the Camera within your game. Cameras, by default, are
|
|
|
|
* created the same size as your game, but their position and size can be set to anything. This means if you
|
|
|
|
* wanted to create a camera that was 320x200 in size, positioned in the bottom-right corner of your game,
|
|
|
|
* you'd adjust the viewport to do that (using methods like `setViewport` and `setSize`).
|
|
|
|
*
|
|
|
|
* If you wish to change where the Camera is looking in your game, then you scroll it. You can do this
|
|
|
|
* via the properties `scrollX` and `scrollY` or the method `setScroll`. Scrolling has no impact on the
|
|
|
|
* viewport, and changing the viewport has no impact on the scrolling.
|
|
|
|
*
|
|
|
|
* By default a Camera will render all Game Objects it can see. You can change this using the `ignore` method,
|
2018-06-27 11:13:37 +00:00
|
|
|
* allowing you to filter Game Objects out on a per-Camera basis. The Camera Manager can manage up to 31 unique
|
|
|
|
* 'Game Object ignore capable' Cameras. Any Cameras beyond 31 that you create will all be given a Camera ID of
|
|
|
|
* zero, meaning that they cannot be used for Game Object exclusion. This means if you need your Camera to ignore
|
|
|
|
* Game Objects, make sure it's one of the first 31 created.
|
2018-06-26 16:24:51 +00:00
|
|
|
*
|
2018-06-27 11:13:37 +00:00
|
|
|
* A Camera also has built-in special effects including Fade, Flash, Camera Shake, Pan and Zoom.
|
2018-02-07 15:27:21 +00:00
|
|
|
*
|
|
|
|
* @class CameraManager
|
2018-10-10 09:49:13 +00:00
|
|
|
* @memberof Phaser.Cameras.Scene2D
|
2018-02-07 15:27:21 +00:00
|
|
|
* @constructor
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
|
|
|
* @param {Phaser.Scene} scene - The Scene that owns the Camera Manager plugin.
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
var CameraManager = new Class({
|
|
|
|
|
|
|
|
initialize:
|
|
|
|
|
|
|
|
function CameraManager (scene)
|
|
|
|
{
|
2018-01-25 04:41:36 +00:00
|
|
|
/**
|
|
|
|
* The Scene that owns the Camera Manager plugin.
|
|
|
|
*
|
2018-02-12 23:51:47 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.CameraManager#scene
|
|
|
|
* @type {Phaser.Scene}
|
2018-01-25 04:41:36 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
this.scene = scene;
|
|
|
|
|
2018-01-25 04:41:36 +00:00
|
|
|
/**
|
|
|
|
* A reference to the Scene.Systems handler for the Scene that owns the Camera Manager.
|
|
|
|
*
|
2018-02-12 23:51:47 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.CameraManager#systems
|
|
|
|
* @type {Phaser.Scenes.Systems}
|
2018-01-25 04:41:36 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
this.systems = scene.sys;
|
|
|
|
|
2018-06-27 14:15:00 +00:00
|
|
|
/**
|
|
|
|
* All Cameras created by, or added to, this Camera Manager, will have their `roundPixels`
|
|
|
|
* property set to match this value. By default it is set to match the value set in the
|
|
|
|
* game configuration, but can be changed at any point. Equally, individual cameras can
|
|
|
|
* also be changed as needed.
|
|
|
|
*
|
|
|
|
* @name Phaser.Cameras.Scene2D.CameraManager#roundPixels
|
|
|
|
* @type {boolean}
|
|
|
|
* @since 3.11.0
|
|
|
|
*/
|
|
|
|
this.roundPixels = scene.sys.game.config.roundPixels;
|
|
|
|
|
2018-01-25 04:41:36 +00:00
|
|
|
/**
|
|
|
|
* An Array of the Camera objects being managed by this Camera Manager.
|
2018-06-25 15:10:50 +00:00
|
|
|
* The Cameras are updated and rendered in the same order in which they appear in this array.
|
|
|
|
* Do not directly add or remove entries to this array. However, you can move the contents
|
|
|
|
* around the array should you wish to adjust the display order.
|
2018-01-25 04:41:36 +00:00
|
|
|
*
|
2018-02-12 23:51:47 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.CameraManager#cameras
|
|
|
|
* @type {Phaser.Cameras.Scene2D.Camera[]}
|
2018-01-25 04:41:36 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
this.cameras = [];
|
2018-01-25 04:41:36 +00:00
|
|
|
|
|
|
|
/**
|
2018-06-25 15:10:50 +00:00
|
|
|
* A handy reference to the 'main' camera. By default this is the first Camera the
|
|
|
|
* Camera Manager creates. You can also set it directly, or use the `makeMain` argument
|
|
|
|
* in the `add` and `addExisting` methods. It allows you to access it from your game:
|
|
|
|
*
|
|
|
|
* ```javascript
|
|
|
|
* var cam = this.cameras.main;
|
|
|
|
* ```
|
|
|
|
*
|
|
|
|
* Also see the properties `camera1`, `camera2` and so on.
|
2018-01-25 04:41:36 +00:00
|
|
|
*
|
2018-02-12 23:51:47 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.CameraManager#main
|
|
|
|
* @type {Phaser.Cameras.Scene2D.Camera}
|
2018-01-25 04:41:36 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-04-13 16:12:17 +00:00
|
|
|
this.main;
|
2018-02-01 00:01:27 +00:00
|
|
|
|
|
|
|
/**
|
2018-06-25 15:10:50 +00:00
|
|
|
* This scale affects all cameras. It's used by the Scale Manager.
|
2018-02-01 00:01:27 +00:00
|
|
|
*
|
2018-02-12 23:51:47 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.CameraManager#baseScale
|
|
|
|
* @type {number}
|
2018-02-01 00:01:27 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-04-13 16:12:17 +00:00
|
|
|
this.baseScale = 1;
|
|
|
|
|
2018-04-17 01:34:07 +00:00
|
|
|
scene.sys.events.once('boot', this.boot, this);
|
2018-04-13 16:12:17 +00:00
|
|
|
scene.sys.events.on('start', this.start, this);
|
2018-01-16 15:06:47 +00:00
|
|
|
},
|
|
|
|
|
2018-01-25 04:41:36 +00:00
|
|
|
/**
|
2018-04-17 01:34:07 +00:00
|
|
|
* This method is called automatically, only once, when the Scene is first created.
|
2018-04-13 16:12:17 +00:00
|
|
|
* Do not invoke it directly.
|
2018-01-25 04:41:36 +00:00
|
|
|
*
|
2018-04-17 01:34:07 +00:00
|
|
|
* @method Phaser.Cameras.Scene2D.CameraManager#boot
|
2018-04-13 16:12:17 +00:00
|
|
|
* @private
|
2018-04-17 01:34:07 +00:00
|
|
|
* @since 3.5.1
|
2018-01-25 04:41:36 +00:00
|
|
|
*/
|
2018-04-17 01:34:07 +00:00
|
|
|
boot: function ()
|
2018-01-16 15:06:47 +00:00
|
|
|
{
|
2018-04-13 16:12:17 +00:00
|
|
|
var sys = this.systems;
|
|
|
|
|
|
|
|
if (sys.settings.cameras)
|
|
|
|
{
|
|
|
|
// We have cameras to create
|
|
|
|
this.fromJSON(sys.settings.cameras);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// Make one
|
|
|
|
this.add();
|
|
|
|
}
|
|
|
|
|
|
|
|
this.main = this.cameras[0];
|
2018-04-17 11:25:45 +00:00
|
|
|
|
|
|
|
this.systems.events.once('destroy', this.destroy, this);
|
2018-04-17 01:34:07 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This method is called automatically by the Scene when it is starting up.
|
|
|
|
* It is responsible for creating local systems, properties and listening for Scene events.
|
|
|
|
* Do not invoke it directly.
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.CameraManager#start
|
|
|
|
* @private
|
|
|
|
* @since 3.5.0
|
|
|
|
*/
|
|
|
|
start: function ()
|
|
|
|
{
|
|
|
|
if (!this.main)
|
|
|
|
{
|
2018-07-31 10:34:59 +00:00
|
|
|
var sys = this.systems;
|
|
|
|
|
|
|
|
if (sys.settings.cameras)
|
|
|
|
{
|
|
|
|
// We have cameras to create
|
|
|
|
this.fromJSON(sys.settings.cameras);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// Make one
|
|
|
|
this.add();
|
|
|
|
}
|
|
|
|
|
|
|
|
this.main = this.cameras[0];
|
2018-04-17 01:34:07 +00:00
|
|
|
}
|
2018-04-13 16:12:17 +00:00
|
|
|
|
2018-04-17 01:34:07 +00:00
|
|
|
var eventEmitter = this.systems.events;
|
2018-01-18 14:00:31 +00:00
|
|
|
|
|
|
|
eventEmitter.on('update', this.update, this);
|
2018-04-13 16:12:17 +00:00
|
|
|
eventEmitter.once('shutdown', this.shutdown, this);
|
2018-01-16 15:06:47 +00:00
|
|
|
},
|
|
|
|
|
2018-01-25 04:41:36 +00:00
|
|
|
/**
|
2018-06-26 16:24:51 +00:00
|
|
|
* Adds a new Camera into the Camera Manager. The Camera Manager can support up to 31 different Cameras.
|
|
|
|
*
|
|
|
|
* Each Camera has its own viewport, which controls the size of the Camera and its position within the canvas.
|
|
|
|
*
|
|
|
|
* Use the `Camera.scrollX` and `Camera.scrollY` properties to change where the Camera is looking, or the
|
|
|
|
* Camera methods such as `centerOn`. Cameras also have built in special effects, such as fade, flash, shake,
|
|
|
|
* pan and zoom.
|
|
|
|
*
|
|
|
|
* By default Cameras are transparent and will render anything that they can see based on their `scrollX`
|
|
|
|
* and `scrollY` values. Game Objects can be set to be ignored by a Camera by using the `Camera.ignore` method.
|
|
|
|
*
|
2018-10-26 18:38:13 +00:00
|
|
|
* The Camera will have its `roundPixels` property set to whatever `CameraManager.roundPixels` is. You can change
|
2018-06-27 14:27:16 +00:00
|
|
|
* it after creation if required.
|
2018-06-27 14:15:00 +00:00
|
|
|
*
|
2018-06-26 16:24:51 +00:00
|
|
|
* See the Camera class documentation for more details.
|
2018-01-25 04:41:36 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.CameraManager#add
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-26 16:24:51 +00:00
|
|
|
* @param {integer} [x=0] - The horizontal position of the Camera viewport.
|
|
|
|
* @param {integer} [y=0] - The vertical position of the Camera viewport.
|
|
|
|
* @param {integer} [width] - The width of the Camera viewport. If not given it'll be the game config size.
|
|
|
|
* @param {integer} [height] - The height of the Camera viewport. If not given it'll be the game config size.
|
|
|
|
* @param {boolean} [makeMain=false] - Set this Camera as being the 'main' camera. This just makes the property `main` a reference to it.
|
|
|
|
* @param {string} [name=''] - The name of the Camera.
|
2018-01-25 04:41:36 +00:00
|
|
|
*
|
2018-06-26 16:24:51 +00:00
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} The newly created Camera.
|
2018-01-25 04:41:36 +00:00
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
add: function (x, y, width, height, makeMain, name)
|
|
|
|
{
|
|
|
|
if (x === undefined) { x = 0; }
|
|
|
|
if (y === undefined) { y = 0; }
|
|
|
|
if (width === undefined) { width = this.scene.sys.game.config.width; }
|
|
|
|
if (height === undefined) { height = this.scene.sys.game.config.height; }
|
|
|
|
if (makeMain === undefined) { makeMain = false; }
|
|
|
|
if (name === undefined) { name = ''; }
|
|
|
|
|
2018-06-23 11:33:10 +00:00
|
|
|
var camera = new Camera(x, y, width, height);
|
2018-01-16 15:06:47 +00:00
|
|
|
|
|
|
|
camera.setName(name);
|
|
|
|
camera.setScene(this.scene);
|
2018-06-27 14:15:00 +00:00
|
|
|
camera.setRoundPixels(this.roundPixels);
|
2018-01-16 15:06:47 +00:00
|
|
|
|
2018-06-27 11:13:37 +00:00
|
|
|
camera.id = this.getNextID();
|
|
|
|
|
2018-01-16 15:06:47 +00:00
|
|
|
this.cameras.push(camera);
|
|
|
|
|
|
|
|
if (makeMain)
|
|
|
|
{
|
|
|
|
this.main = camera;
|
|
|
|
}
|
|
|
|
|
2018-06-27 11:13:37 +00:00
|
|
|
return camera;
|
|
|
|
},
|
2018-01-16 15:06:47 +00:00
|
|
|
|
2018-06-27 11:45:54 +00:00
|
|
|
/**
|
|
|
|
* Adds an existing Camera into the Camera Manager.
|
|
|
|
*
|
|
|
|
* The Camera should either be a `Phaser.Cameras.Scene2D.Camera` instance, or a class that extends from it.
|
|
|
|
*
|
2018-10-26 18:38:13 +00:00
|
|
|
* The Camera will have its `roundPixels` property set to whatever `CameraManager.roundPixels` is. You can change
|
2018-06-27 14:27:16 +00:00
|
|
|
* it after addition if required.
|
2018-06-27 14:15:00 +00:00
|
|
|
*
|
2018-06-27 11:45:54 +00:00
|
|
|
* The Camera will be assigned an ID, which is used for Game Object exclusion and then added to the
|
|
|
|
* manager. As long as it doesn't already exist in the manager it will be added then returned.
|
|
|
|
*
|
|
|
|
* If this method returns `null` then the Camera already exists in this Camera Manager.
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.CameraManager#addExisting
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
|
|
|
* @param {Phaser.Cameras.Scene2D.Camera} camera - The Camera to be added to the Camera Manager.
|
|
|
|
* @param {boolean} [makeMain=false] - Set this Camera as being the 'main' camera. This just makes the property `main` a reference to it.
|
|
|
|
*
|
|
|
|
* @return {?Phaser.Cameras.Scene2D.Camera} The Camera that was added to the Camera Manager, or `null` if it couldn't be added.
|
|
|
|
*/
|
|
|
|
addExisting: function (camera, makeMain)
|
|
|
|
{
|
|
|
|
if (makeMain === undefined) { makeMain = false; }
|
|
|
|
|
|
|
|
var index = this.cameras.indexOf(camera);
|
|
|
|
|
|
|
|
if (index === -1)
|
|
|
|
{
|
|
|
|
camera.id = this.getNextID();
|
|
|
|
|
2018-06-27 14:15:00 +00:00
|
|
|
camera.setRoundPixels(this.roundPixels);
|
|
|
|
|
2018-06-27 11:45:54 +00:00
|
|
|
this.cameras.push(camera);
|
|
|
|
|
|
|
|
if (makeMain)
|
|
|
|
{
|
|
|
|
this.main = camera;
|
|
|
|
}
|
|
|
|
|
|
|
|
return camera;
|
|
|
|
}
|
|
|
|
|
|
|
|
return null;
|
|
|
|
},
|
|
|
|
|
2018-06-27 11:13:37 +00:00
|
|
|
/**
|
|
|
|
* Gets the next available Camera ID number.
|
|
|
|
*
|
|
|
|
* The Camera Manager supports up to 31 unique cameras, after which the ID returned will always be zero.
|
|
|
|
* You can create additional cameras beyond 31, but they cannot be used for Game Object exclusion.
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.CameraManager#getNextID
|
|
|
|
* @private
|
|
|
|
* @since 3.11.0
|
|
|
|
*
|
|
|
|
* @return {number} The next available Camera ID, or 0 if they're all already in use.
|
|
|
|
*/
|
|
|
|
getNextID: function ()
|
|
|
|
{
|
|
|
|
var cameras = this.cameras;
|
2018-01-16 15:06:47 +00:00
|
|
|
|
2018-06-27 11:13:37 +00:00
|
|
|
var testID = 1;
|
|
|
|
|
|
|
|
// Find the first free camera ID we can use
|
|
|
|
|
|
|
|
for (var t = 0; t < 32; t++)
|
|
|
|
{
|
|
|
|
var found = false;
|
|
|
|
|
|
|
|
for (var i = 0; i < cameras.length; i++)
|
|
|
|
{
|
|
|
|
var camera = cameras[i];
|
|
|
|
|
|
|
|
if (camera && camera.id === testID)
|
|
|
|
{
|
|
|
|
found = true;
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (found)
|
|
|
|
{
|
|
|
|
testID = testID << 1;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return testID;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
2018-01-16 15:06:47 +00:00
|
|
|
},
|
|
|
|
|
2018-01-25 04:41:36 +00:00
|
|
|
/**
|
2018-06-27 11:45:54 +00:00
|
|
|
* Gets the total number of Cameras in this Camera Manager.
|
2018-06-26 16:24:51 +00:00
|
|
|
*
|
2018-06-27 11:45:54 +00:00
|
|
|
* If the optional `isVisible` argument is set it will only count Cameras that are currently visible.
|
2018-01-25 04:41:36 +00:00
|
|
|
*
|
2018-06-27 11:45:54 +00:00
|
|
|
* @method Phaser.Cameras.Scene2D.CameraManager#getTotal
|
|
|
|
* @since 3.11.0
|
|
|
|
*
|
|
|
|
* @param {boolean} [isVisible=false] - Set the `true` to only include visible Cameras in the total.
|
2018-01-25 04:41:36 +00:00
|
|
|
*
|
2018-06-27 11:45:54 +00:00
|
|
|
* @return {integer} The total number of Cameras in this Camera Manager.
|
2018-01-25 04:41:36 +00:00
|
|
|
*/
|
2018-06-27 11:45:54 +00:00
|
|
|
getTotal: function (isVisible)
|
2018-01-16 15:06:47 +00:00
|
|
|
{
|
2018-06-27 11:45:54 +00:00
|
|
|
if (isVisible === undefined) { isVisible = false; }
|
2018-06-25 15:10:50 +00:00
|
|
|
|
2018-06-27 11:45:54 +00:00
|
|
|
var total = 0;
|
2018-01-16 15:06:47 +00:00
|
|
|
|
2018-06-27 11:45:54 +00:00
|
|
|
var cameras = this.cameras;
|
2018-06-25 15:10:50 +00:00
|
|
|
|
2018-06-27 11:45:54 +00:00
|
|
|
for (var i = 0; i < cameras.length; i++)
|
|
|
|
{
|
|
|
|
var camera = cameras[i];
|
2018-06-25 15:10:50 +00:00
|
|
|
|
2018-06-27 11:45:54 +00:00
|
|
|
if (!isVisible || (isVisible && camera.visible))
|
2018-06-25 15:10:50 +00:00
|
|
|
{
|
2018-06-27 11:45:54 +00:00
|
|
|
total++;
|
2018-06-25 15:10:50 +00:00
|
|
|
}
|
2018-01-16 15:06:47 +00:00
|
|
|
}
|
2018-03-19 00:49:29 +00:00
|
|
|
|
2018-06-27 11:45:54 +00:00
|
|
|
return total;
|
2018-01-16 15:06:47 +00:00
|
|
|
},
|
|
|
|
|
2018-01-25 04:41:36 +00:00
|
|
|
/**
|
2018-06-26 16:24:51 +00:00
|
|
|
* Populates this Camera Manager based on the given configuration object, or an array of config objects.
|
|
|
|
*
|
|
|
|
* See the `InputJSONCameraObject` documentation for details of the object structure.
|
2018-01-25 04:41:36 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.CameraManager#fromJSON
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-26 16:24:51 +00:00
|
|
|
* @param {(InputJSONCameraObject|InputJSONCameraObject[])} config - A Camera configuration object, or an array of them, to be added to this Camera Manager.
|
2018-01-25 04:41:36 +00:00
|
|
|
*
|
2018-06-26 16:24:51 +00:00
|
|
|
* @return {Phaser.Cameras.Scene2D.CameraManager} This Camera Manager instance.
|
2018-01-25 04:41:36 +00:00
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
fromJSON: function (config)
|
|
|
|
{
|
|
|
|
if (!Array.isArray(config))
|
|
|
|
{
|
|
|
|
config = [ config ];
|
|
|
|
}
|
|
|
|
|
|
|
|
var gameWidth = this.scene.sys.game.config.width;
|
|
|
|
var gameHeight = this.scene.sys.game.config.height;
|
|
|
|
|
|
|
|
for (var i = 0; i < config.length; i++)
|
|
|
|
{
|
|
|
|
var cameraConfig = config[i];
|
|
|
|
|
|
|
|
var x = GetFastValue(cameraConfig, 'x', 0);
|
|
|
|
var y = GetFastValue(cameraConfig, 'y', 0);
|
|
|
|
var width = GetFastValue(cameraConfig, 'width', gameWidth);
|
|
|
|
var height = GetFastValue(cameraConfig, 'height', gameHeight);
|
|
|
|
|
|
|
|
var camera = this.add(x, y, width, height);
|
|
|
|
|
|
|
|
// Direct properties
|
|
|
|
camera.name = GetFastValue(cameraConfig, 'name', '');
|
|
|
|
camera.zoom = GetFastValue(cameraConfig, 'zoom', 1);
|
|
|
|
camera.rotation = GetFastValue(cameraConfig, 'rotation', 0);
|
|
|
|
camera.scrollX = GetFastValue(cameraConfig, 'scrollX', 0);
|
|
|
|
camera.scrollY = GetFastValue(cameraConfig, 'scrollY', 0);
|
|
|
|
camera.roundPixels = GetFastValue(cameraConfig, 'roundPixels', false);
|
2018-06-04 21:10:13 +00:00
|
|
|
camera.visible = GetFastValue(cameraConfig, 'visible', true);
|
2018-01-16 15:06:47 +00:00
|
|
|
|
|
|
|
// Background Color
|
|
|
|
|
|
|
|
var backgroundColor = GetFastValue(cameraConfig, 'backgroundColor', false);
|
|
|
|
|
|
|
|
if (backgroundColor)
|
|
|
|
{
|
|
|
|
camera.setBackgroundColor(backgroundColor);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Bounds
|
|
|
|
|
|
|
|
var boundsConfig = GetFastValue(cameraConfig, 'bounds', null);
|
|
|
|
|
|
|
|
if (boundsConfig)
|
|
|
|
{
|
|
|
|
var bx = GetFastValue(boundsConfig, 'x', 0);
|
|
|
|
var by = GetFastValue(boundsConfig, 'y', 0);
|
|
|
|
var bwidth = GetFastValue(boundsConfig, 'width', gameWidth);
|
|
|
|
var bheight = GetFastValue(boundsConfig, 'height', gameHeight);
|
|
|
|
|
|
|
|
camera.setBounds(bx, by, bwidth, bheight);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-01-25 04:41:36 +00:00
|
|
|
/**
|
2018-06-26 16:24:51 +00:00
|
|
|
* Gets a Camera based on its name.
|
|
|
|
*
|
|
|
|
* Camera names are optional and don't have to be set, so this method is only of any use if you
|
|
|
|
* have given your Cameras unique names.
|
2018-01-25 04:41:36 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.CameraManager#getCamera
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-26 16:24:51 +00:00
|
|
|
* @param {string} name - The name of the Camera.
|
2018-01-25 04:41:36 +00:00
|
|
|
*
|
2018-06-26 16:24:51 +00:00
|
|
|
* @return {?Phaser.Cameras.Scene2D.Camera} The first Camera with a name matching the given string, otherwise `null`.
|
2018-01-25 04:41:36 +00:00
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
getCamera: function (name)
|
|
|
|
{
|
2018-06-25 15:10:50 +00:00
|
|
|
var cameras = this.cameras;
|
|
|
|
|
|
|
|
for (var i = 0; i < cameras.length; i++)
|
2018-01-16 15:06:47 +00:00
|
|
|
{
|
2018-06-25 15:10:50 +00:00
|
|
|
if (cameras[i].name === name)
|
2018-01-16 15:06:47 +00:00
|
|
|
{
|
2018-06-25 15:10:50 +00:00
|
|
|
return cameras[i];
|
2018-01-16 15:06:47 +00:00
|
|
|
}
|
2018-03-15 15:58:05 +00:00
|
|
|
}
|
2018-01-16 15:06:47 +00:00
|
|
|
|
|
|
|
return null;
|
|
|
|
},
|
|
|
|
|
2018-01-25 04:41:36 +00:00
|
|
|
/**
|
2018-06-04 21:10:13 +00:00
|
|
|
* Returns an array of all cameras below the given Pointer.
|
|
|
|
*
|
|
|
|
* The first camera in the array is the top-most camera in the camera list.
|
2018-01-25 04:41:36 +00:00
|
|
|
*
|
2018-06-04 21:10:13 +00:00
|
|
|
* @method Phaser.Cameras.Scene2D.CameraManager#getCamerasBelowPointer
|
|
|
|
* @since 3.10.0
|
2018-01-25 04:41:36 +00:00
|
|
|
*
|
2018-06-04 21:10:13 +00:00
|
|
|
* @param {Phaser.Input.Pointer} pointer - The Pointer to check against.
|
2018-01-25 04:41:36 +00:00
|
|
|
*
|
2018-06-04 21:10:13 +00:00
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera[]} An array of cameras below the Pointer.
|
2018-01-25 04:41:36 +00:00
|
|
|
*/
|
2018-06-04 21:10:13 +00:00
|
|
|
getCamerasBelowPointer: function (pointer)
|
2018-01-16 15:06:47 +00:00
|
|
|
{
|
|
|
|
var cameras = this.cameras;
|
|
|
|
|
2018-06-04 21:10:13 +00:00
|
|
|
var x = pointer.x;
|
|
|
|
var y = pointer.y;
|
|
|
|
|
|
|
|
var output = [];
|
|
|
|
|
|
|
|
for (var i = 0; i < cameras.length; i++)
|
2018-01-16 15:06:47 +00:00
|
|
|
{
|
|
|
|
var camera = cameras[i];
|
|
|
|
|
2018-06-04 21:10:13 +00:00
|
|
|
if (camera.visible && camera.inputEnabled && RectangleContains(camera, x, y))
|
2018-01-16 15:06:47 +00:00
|
|
|
{
|
2018-06-04 21:10:13 +00:00
|
|
|
// So the top-most camera is at the top of the search array
|
|
|
|
output.unshift(camera);
|
2018-01-16 15:06:47 +00:00
|
|
|
}
|
|
|
|
}
|
2018-06-04 21:10:13 +00:00
|
|
|
|
|
|
|
return output;
|
2018-01-16 15:06:47 +00:00
|
|
|
},
|
|
|
|
|
2018-01-25 04:41:36 +00:00
|
|
|
/**
|
2018-06-27 12:03:40 +00:00
|
|
|
* Removes the given Camera, or an array of Cameras, from this Camera Manager.
|
2018-06-26 16:24:51 +00:00
|
|
|
*
|
|
|
|
* If found in the Camera Manager it will be immediately removed from the local cameras array.
|
|
|
|
* If also currently the 'main' camera, 'main' will be reset to be camera 0.
|
|
|
|
*
|
2018-10-05 17:30:00 +00:00
|
|
|
* The removed Cameras are automatically destroyed if the `runDestroy` argument is `true`, which is the default.
|
|
|
|
* If you wish to re-use the cameras then set this to `false`, but know that they will retain their references
|
|
|
|
* and internal data until destroyed or re-added to a Camera Manager.
|
2018-01-25 04:41:36 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.CameraManager#remove
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-27 12:03:40 +00:00
|
|
|
* @param {(Phaser.Cameras.Scene2D.Camera|Phaser.Cameras.Scene2D.Camera[])} camera - The Camera, or an array of Cameras, to be removed from this Camera Manager.
|
2018-10-05 17:30:00 +00:00
|
|
|
* @param {boolean} [runDestroy=true] - Automatically call `Camera.destroy` on each Camera removed from this Camera Manager.
|
2018-06-27 12:16:01 +00:00
|
|
|
*
|
|
|
|
* @return {integer} The total number of Cameras removed.
|
2018-01-25 04:41:36 +00:00
|
|
|
*/
|
2018-10-05 17:30:00 +00:00
|
|
|
remove: function (camera, runDestroy)
|
2018-01-16 15:06:47 +00:00
|
|
|
{
|
2018-10-05 17:30:00 +00:00
|
|
|
if (runDestroy === undefined) { runDestroy = true; }
|
|
|
|
|
2018-06-27 12:03:40 +00:00
|
|
|
if (!Array.isArray(camera))
|
|
|
|
{
|
|
|
|
camera = [ camera ];
|
|
|
|
}
|
2018-01-16 15:06:47 +00:00
|
|
|
|
2018-06-27 12:16:01 +00:00
|
|
|
var total = 0;
|
2018-06-27 12:03:40 +00:00
|
|
|
var cameras = this.cameras;
|
|
|
|
|
|
|
|
for (var i = 0; i < camera.length; i++)
|
2018-01-16 15:06:47 +00:00
|
|
|
{
|
2018-06-27 12:05:06 +00:00
|
|
|
var index = cameras.indexOf(camera[i]);
|
2018-01-16 15:06:47 +00:00
|
|
|
|
2018-06-27 12:03:40 +00:00
|
|
|
if (index !== -1)
|
2018-01-16 15:06:47 +00:00
|
|
|
{
|
2018-10-05 17:30:00 +00:00
|
|
|
if (runDestroy)
|
|
|
|
{
|
|
|
|
cameras[index].destroy();
|
|
|
|
}
|
|
|
|
|
2018-06-27 12:03:40 +00:00
|
|
|
cameras.splice(index, 1);
|
2018-10-05 17:30:00 +00:00
|
|
|
|
2018-06-27 12:16:01 +00:00
|
|
|
total++;
|
2018-01-16 15:06:47 +00:00
|
|
|
}
|
|
|
|
}
|
2018-06-27 12:03:40 +00:00
|
|
|
|
2018-10-05 17:30:00 +00:00
|
|
|
if (!this.main && cameras[0])
|
2018-06-27 12:03:40 +00:00
|
|
|
{
|
2018-06-27 12:05:06 +00:00
|
|
|
this.main = cameras[0];
|
2018-06-27 12:03:40 +00:00
|
|
|
}
|
2018-06-27 12:16:01 +00:00
|
|
|
|
|
|
|
return total;
|
2018-01-16 15:06:47 +00:00
|
|
|
},
|
|
|
|
|
2018-01-25 04:41:36 +00:00
|
|
|
/**
|
2018-06-26 16:24:51 +00:00
|
|
|
* The internal render method. This is called automatically by the Scene and should not be invoked directly.
|
|
|
|
*
|
|
|
|
* It will iterate through all local cameras and render them in turn, as long as they're visible and have
|
|
|
|
* an alpha level > 0.
|
2018-01-25 04:41:36 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.CameraManager#render
|
2018-06-26 16:24:51 +00:00
|
|
|
* @protected
|
2018-01-25 04:41:36 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-03-20 14:58:02 +00:00
|
|
|
* @param {(Phaser.Renderer.Canvas.CanvasRenderer|Phaser.Renderer.WebGL.WebGLRenderer)} renderer - The Renderer that will render the children to this camera.
|
2018-03-18 13:43:37 +00:00
|
|
|
* @param {Phaser.GameObjects.GameObject[]} children - An array of renderable Game Objects.
|
|
|
|
* @param {number} interpolation - Interpolation value. Reserved for future use.
|
2018-01-25 04:41:36 +00:00
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
render: function (renderer, children, interpolation)
|
|
|
|
{
|
2018-06-25 15:10:50 +00:00
|
|
|
var scene = this.scene;
|
2018-01-16 15:06:47 +00:00
|
|
|
var cameras = this.cameras;
|
2018-02-01 00:01:27 +00:00
|
|
|
var baseScale = this.baseScale;
|
2018-06-25 15:10:50 +00:00
|
|
|
var resolution = renderer.config.resolution;
|
2018-01-16 15:06:47 +00:00
|
|
|
|
2018-06-25 15:10:50 +00:00
|
|
|
for (var i = 0; i < this.cameras.length; i++)
|
2018-01-16 15:06:47 +00:00
|
|
|
{
|
|
|
|
var camera = cameras[i];
|
|
|
|
|
2018-06-25 15:10:50 +00:00
|
|
|
if (camera.visible && camera.alpha > 0)
|
2018-06-04 21:10:13 +00:00
|
|
|
{
|
2018-06-25 15:10:50 +00:00
|
|
|
camera.preRender(baseScale, resolution);
|
2018-01-16 15:06:47 +00:00
|
|
|
|
2018-06-25 15:10:50 +00:00
|
|
|
renderer.render(scene, children, interpolation, camera);
|
2018-06-04 21:10:13 +00:00
|
|
|
}
|
2018-01-16 15:06:47 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2018-01-25 04:41:36 +00:00
|
|
|
/**
|
2018-06-26 16:24:51 +00:00
|
|
|
* Resets this Camera Manager.
|
|
|
|
*
|
|
|
|
* This will iterate through all current Cameras, destroying them all, then it will reset the
|
|
|
|
* cameras array, reset the ID counter and create 1 new single camera using the default values.
|
2018-01-25 04:41:36 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.CameraManager#resetAll
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-26 16:24:51 +00:00
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} The freshly created main Camera.
|
2018-01-25 04:41:36 +00:00
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
resetAll: function ()
|
|
|
|
{
|
2018-06-23 11:33:10 +00:00
|
|
|
for (var i = 0; i < this.cameras.length; i++)
|
2018-01-16 15:06:47 +00:00
|
|
|
{
|
2018-06-23 11:33:10 +00:00
|
|
|
this.cameras[i].destroy();
|
2018-01-16 15:06:47 +00:00
|
|
|
}
|
|
|
|
|
2018-06-23 11:33:10 +00:00
|
|
|
this.cameras = [];
|
|
|
|
|
2018-01-16 15:06:47 +00:00
|
|
|
this.main = this.add();
|
|
|
|
|
|
|
|
return this.main;
|
|
|
|
},
|
|
|
|
|
2018-01-25 04:41:36 +00:00
|
|
|
/**
|
2018-06-26 16:24:51 +00:00
|
|
|
* The main update loop. Called automatically when the Scene steps.
|
2018-01-25 04:41:36 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.CameraManager#update
|
2018-06-26 16:24:51 +00:00
|
|
|
* @protected
|
2018-01-25 04:41:36 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-26 16:24:51 +00:00
|
|
|
* @param {number} timestep - The timestep value.
|
|
|
|
* @param {number} delta - The delta value since the last frame.
|
2018-01-25 04:41:36 +00:00
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
update: function (timestep, delta)
|
|
|
|
{
|
2018-06-25 15:10:50 +00:00
|
|
|
for (var i = 0; i < this.cameras.length; i++)
|
2018-01-16 15:06:47 +00:00
|
|
|
{
|
|
|
|
this.cameras[i].update(timestep, delta);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2018-02-28 17:19:10 +00:00
|
|
|
/**
|
|
|
|
* Resizes all cameras to the given dimensions.
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.CameraManager#resize
|
|
|
|
* @since 3.2.0
|
2018-03-19 00:49:29 +00:00
|
|
|
*
|
2018-02-28 17:19:10 +00:00
|
|
|
* @param {number} width - The new width of the camera.
|
|
|
|
* @param {number} height - The new height of the camera.
|
|
|
|
*/
|
|
|
|
resize: function (width, height)
|
|
|
|
{
|
2018-06-25 15:10:50 +00:00
|
|
|
for (var i = 0; i < this.cameras.length; i++)
|
2018-02-28 17:19:10 +00:00
|
|
|
{
|
|
|
|
this.cameras[i].setSize(width, height);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2018-01-25 04:41:36 +00:00
|
|
|
/**
|
2018-04-13 16:12:17 +00:00
|
|
|
* The Scene that owns this plugin is shutting down.
|
|
|
|
* We need to kill and reset all internal properties as well as stop listening to Scene events.
|
2018-01-25 04:41:36 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.CameraManager#shutdown
|
2018-04-13 16:12:17 +00:00
|
|
|
* @private
|
2018-01-25 04:41:36 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
shutdown: function ()
|
2018-01-16 19:49:13 +00:00
|
|
|
{
|
|
|
|
this.main = undefined;
|
|
|
|
|
|
|
|
for (var i = 0; i < this.cameras.length; i++)
|
|
|
|
{
|
|
|
|
this.cameras[i].destroy();
|
|
|
|
}
|
|
|
|
|
|
|
|
this.cameras = [];
|
2018-04-13 16:12:17 +00:00
|
|
|
|
|
|
|
var eventEmitter = this.systems.events;
|
|
|
|
|
|
|
|
eventEmitter.off('update', this.update, this);
|
|
|
|
eventEmitter.off('shutdown', this.shutdown, this);
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The Scene that owns this plugin is being destroyed.
|
|
|
|
* We need to shutdown and then kill off all external references.
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.CameraManager#destroy
|
|
|
|
* @private
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
|
|
|
destroy: function ()
|
|
|
|
{
|
|
|
|
this.shutdown();
|
|
|
|
|
|
|
|
this.scene.sys.events.off('start', this.start, this);
|
|
|
|
|
|
|
|
this.scene = null;
|
|
|
|
this.systems = null;
|
2018-01-16 15:06:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
2018-05-15 11:51:50 +00:00
|
|
|
PluginCache.register('CameraManager', CameraManager, 'cameras');
|
2018-01-16 15:06:47 +00:00
|
|
|
|
|
|
|
module.exports = CameraManager;
|