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 Class = require('../../utils/Class');
|
|
|
|
var DegToRad = require('../../math/DegToRad');
|
2018-04-14 11:35:14 +00:00
|
|
|
var EventEmitter = require('eventemitter3');
|
2018-04-14 16:39:43 +00:00
|
|
|
var Effects = require('./effects');
|
2018-01-16 15:06:47 +00:00
|
|
|
var Rectangle = require('../../geom/rectangle/Rectangle');
|
|
|
|
var TransformMatrix = require('../../gameobjects/components/TransformMatrix');
|
|
|
|
var ValueToColor = require('../../display/color/ValueToColor');
|
|
|
|
var Vector2 = require('../../math/Vector2');
|
|
|
|
|
2018-03-19 16:21:25 +00:00
|
|
|
/**
|
|
|
|
* @typedef {object} JSONCamera
|
|
|
|
*
|
|
|
|
* @property {string} name - The name of the camera
|
|
|
|
* @property {number} x - The horizontal position of camera
|
|
|
|
* @property {number} y - The vertical position of camera
|
|
|
|
* @property {number} width - The width size of camera
|
|
|
|
* @property {number} height - The height size of camera
|
|
|
|
* @property {number} zoom - The zoom of camera
|
|
|
|
* @property {number} rotation - The rotation of camera
|
|
|
|
* @property {boolean} roundPixels - The round pixels st status of camera
|
|
|
|
* @property {number} scrollX - The horizontal scroll of camera
|
|
|
|
* @property {number} scrollY - The vertical scroll of camera
|
|
|
|
* @property {string} backgroundColor - The background color of camera
|
2018-03-20 22:28:26 +00:00
|
|
|
* @property {object} [bounds] - The bounds of camera
|
|
|
|
* @property {number} [bounds.x] - The horizontal position of bounds of camera
|
|
|
|
* @property {number} [bounds.y] - The vertical position of bounds of camera
|
|
|
|
* @property {number} [bounds.width] - The width of the bounds of camera
|
|
|
|
* @property {number} [bounds.height] - The height of the bounds of camera
|
2018-03-19 16:21:25 +00:00
|
|
|
*/
|
|
|
|
|
2018-03-27 11:51:45 +00:00
|
|
|
/**
|
|
|
|
* @callback Camera2DCallback
|
|
|
|
*
|
|
|
|
* @param {Phaser.Cameras.Scene2D.Camera} camera - [description]
|
|
|
|
*/
|
|
|
|
|
2018-02-07 15:27:21 +00:00
|
|
|
/**
|
|
|
|
* @classdesc
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @class Camera
|
2018-04-14 11:35:14 +00:00
|
|
|
* @extends Phaser.Events.EventEmitter
|
2018-02-07 15:27:21 +00:00
|
|
|
* @memberOf Phaser.Cameras.Scene2D
|
|
|
|
* @constructor
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
|
|
|
* @param {number} x - The x position of the Camera, relative to the top-left of the game canvas.
|
|
|
|
* @param {number} y - The y position of the Camera, relative to the top-left of the game canvas.
|
|
|
|
* @param {number} width - The width of the Camera, in pixels.
|
|
|
|
* @param {number} height - The height of the Camera, in pixels.
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
var Camera = new Class({
|
|
|
|
|
2018-04-14 11:35:14 +00:00
|
|
|
Extends: EventEmitter,
|
|
|
|
|
2018-01-16 15:06:47 +00:00
|
|
|
initialize:
|
|
|
|
|
|
|
|
function Camera (x, y, width, height)
|
|
|
|
{
|
2018-04-14 11:35:14 +00:00
|
|
|
EventEmitter.call(this);
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* A reference to the Scene this camera belongs to.
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.Camera#scene
|
|
|
|
* @type {Phaser.Scene}
|
2018-01-25 03:38:23 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
this.scene;
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* The name of the Camera. This is left empty for your own use.
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.Camera#name
|
|
|
|
* @type {string}
|
2018-01-25 03:38:23 +00:00
|
|
|
* @default ''
|
2018-02-12 13:14:50 +00:00
|
|
|
* @since 3.0.0
|
2018-01-25 03:38:23 +00:00
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
this.name = '';
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* The x position of the Camera, relative to the top-left of the game canvas.
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.Camera#x
|
|
|
|
* @type {number}
|
2018-01-25 03:38:23 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
this.x = x;
|
2018-01-25 03:38:23 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The y position of the Camera, relative to the top-left of the game canvas.
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.Camera#y
|
|
|
|
* @type {number}
|
2018-01-25 03:38:23 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
this.y = y;
|
2018-01-25 03:38:23 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The width of the Camera, in pixels.
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.Camera#width
|
|
|
|
* @type {number}
|
2018-01-25 03:38:23 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
this.width = width;
|
2018-01-25 03:38:23 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The height of the Camera, in pixels.
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.Camera#height
|
|
|
|
* @type {number}
|
2018-01-25 03:38:23 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
this.height = height;
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* Should this camera round its pixel values to integers?
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.Camera#roundPixels
|
|
|
|
* @type {boolean}
|
2018-01-25 03:38:23 +00:00
|
|
|
* @default false
|
2018-02-12 13:14:50 +00:00
|
|
|
* @since 3.0.0
|
2018-01-25 03:38:23 +00:00
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
this.roundPixels = false;
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* Is this Camera using a bounds to restrict scrolling movement?
|
|
|
|
* Set this property along with the bounds via `Camera.setBounds`.
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.Camera#useBounds
|
|
|
|
* @type {boolean}
|
2018-01-25 03:38:23 +00:00
|
|
|
* @default false
|
2018-02-12 13:14:50 +00:00
|
|
|
* @since 3.0.0
|
2018-01-25 03:38:23 +00:00
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
this.useBounds = false;
|
2018-01-25 03:38:23 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The bounds the camera is restrained to during scrolling.
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.Camera#_bounds
|
|
|
|
* @type {Phaser.Geom.Rectangle}
|
2018-01-25 03:38:23 +00:00
|
|
|
* @private
|
2018-02-12 13:14:50 +00:00
|
|
|
* @since 3.0.0
|
2018-01-25 03:38:23 +00:00
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
this._bounds = new Rectangle();
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* Does this Camera allow the Game Objects it renders to receive input events?
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.Camera#inputEnabled
|
|
|
|
* @type {boolean}
|
2018-01-25 03:38:23 +00:00
|
|
|
* @default true
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
this.inputEnabled = true;
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* The horizontal scroll position of this camera.
|
|
|
|
* Optionally restricted via the Camera bounds.
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.Camera#scrollX
|
|
|
|
* @type {number}
|
2018-01-25 03:38:23 +00:00
|
|
|
* @default 0
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
|
|
|
this.scrollX = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The vertical scroll position of this camera.
|
|
|
|
* Optionally restricted via the Camera bounds.
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.Camera#scrollY
|
|
|
|
* @type {number}
|
2018-01-25 03:38:23 +00:00
|
|
|
* @default 0
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
|
|
|
this.scrollY = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The Camera zoom value. Change this value to zoom in, or out of, a Scene.
|
|
|
|
* Set to 1 to return to the default zoom level.
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.Camera#zoom
|
|
|
|
* @type {float}
|
2018-01-25 03:38:23 +00:00
|
|
|
* @default 1
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
|
|
|
this.zoom = 1;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The rotation of the Camera. This influences the rendering of all Game Objects visible by this camera.
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.Camera#rotation
|
|
|
|
* @type {number}
|
2018-01-25 03:38:23 +00:00
|
|
|
* @default 0
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
|
|
|
this.rotation = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A local transform matrix used for internal calculations.
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.Camera#matrix
|
2018-03-27 11:51:45 +00:00
|
|
|
* @type {Phaser.GameObjects.Components.TransformMatrix}
|
2018-01-25 03:38:23 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
this.matrix = new TransformMatrix(1, 0, 0, 1, 0, 0);
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* Does this Camera have a transparent background?
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.Camera#transparent
|
|
|
|
* @type {boolean}
|
2018-01-25 03:38:23 +00:00
|
|
|
* @default true
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
this.transparent = true;
|
2018-01-25 03:38:23 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The background color of this Camera. Only used if `transparent` is `false`.
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.Camera#backgroundColor
|
|
|
|
* @type {Phaser.Display.Color}
|
2018-01-25 03:38:23 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
this.backgroundColor = ValueToColor('rgba(0,0,0,0)');
|
|
|
|
|
2018-04-14 16:39:43 +00:00
|
|
|
// Allow to be modified
|
|
|
|
this.effects = {
|
|
|
|
fade: new Effects.Fade(this),
|
|
|
|
flash: new Effects.Flash(this),
|
|
|
|
shake: new Effects.Shake(this)
|
|
|
|
};
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
2018-04-14 11:35:14 +00:00
|
|
|
* Should the camera cull Game Objects before checking them for input hit tests?
|
2018-01-25 03:38:23 +00:00
|
|
|
* In some special cases it may be beneficial to disable this.
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.Camera#disableCull
|
|
|
|
* @type {boolean}
|
2018-01-25 03:38:23 +00:00
|
|
|
* @default false
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
this.disableCull = false;
|
2018-01-25 03:38:23 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* A temporary array of culled objects.
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.Camera#culledObjects
|
2018-03-27 11:51:45 +00:00
|
|
|
* @type {Phaser.GameObjects.GameObject[]}
|
2018-01-25 03:38:23 +00:00
|
|
|
* @default []
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
this.culledObjects = [];
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.Camera#_follow
|
|
|
|
* @type {?any}
|
2018-01-25 03:38:23 +00:00
|
|
|
* @private
|
|
|
|
* @default null
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
this._follow = null;
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @name Phaser.Cameras.Scene2D.Camera#_id
|
|
|
|
* @type {integer}
|
2018-01-25 03:38:23 +00:00
|
|
|
* @private
|
|
|
|
* @default 0
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
this._id = 0;
|
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#centerToBounds
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
centerToBounds: function ()
|
|
|
|
{
|
|
|
|
this.scrollX = (this._bounds.width * 0.5) - (this.width * 0.5);
|
|
|
|
this.scrollY = (this._bounds.height * 0.5) - (this.height * 0.5);
|
2018-01-28 17:06:37 +00:00
|
|
|
|
2018-01-16 15:06:47 +00:00
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#centerToSize
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
centerToSize: function ()
|
|
|
|
{
|
|
|
|
this.scrollX = this.width * 0.5;
|
|
|
|
this.scrollY = this.height * 0.5;
|
2018-01-28 17:06:37 +00:00
|
|
|
|
2018-01-16 15:06:47 +00:00
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#cull
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-03-27 11:51:45 +00:00
|
|
|
* @generic {Phaser.GameObjects.GameObject[]} G - [renderableObjects,$return]
|
|
|
|
*
|
|
|
|
* @param {Phaser.GameObjects.GameObject[]} renderableObjects - [description]
|
2018-01-25 03:38:23 +00:00
|
|
|
*
|
2018-03-27 11:51:45 +00:00
|
|
|
* @return {Phaser.GameObjects.GameObject[]} [description]
|
2018-01-25 03:38:23 +00:00
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
cull: function (renderableObjects)
|
|
|
|
{
|
|
|
|
if (this.disableCull)
|
|
|
|
{
|
|
|
|
return renderableObjects;
|
|
|
|
}
|
|
|
|
|
|
|
|
var cameraMatrix = this.matrix.matrix;
|
|
|
|
|
|
|
|
var mva = cameraMatrix[0];
|
|
|
|
var mvb = cameraMatrix[1];
|
|
|
|
var mvc = cameraMatrix[2];
|
|
|
|
var mvd = cameraMatrix[3];
|
2018-01-28 17:06:37 +00:00
|
|
|
|
2018-01-16 15:06:47 +00:00
|
|
|
/* First Invert Matrix */
|
|
|
|
var determinant = (mva * mvd) - (mvb * mvc);
|
|
|
|
|
|
|
|
if (!determinant)
|
|
|
|
{
|
|
|
|
return renderableObjects;
|
|
|
|
}
|
|
|
|
|
|
|
|
var mve = cameraMatrix[4];
|
|
|
|
var mvf = cameraMatrix[5];
|
|
|
|
|
|
|
|
var scrollX = this.scrollX;
|
|
|
|
var scrollY = this.scrollY;
|
|
|
|
var cameraW = this.width;
|
|
|
|
var cameraH = this.height;
|
|
|
|
var culledObjects = this.culledObjects;
|
|
|
|
var length = renderableObjects.length;
|
|
|
|
|
|
|
|
determinant = 1 / determinant;
|
|
|
|
|
|
|
|
culledObjects.length = 0;
|
|
|
|
|
|
|
|
for (var index = 0; index < length; ++index)
|
|
|
|
{
|
|
|
|
var object = renderableObjects[index];
|
|
|
|
|
2018-04-09 15:00:33 +00:00
|
|
|
if (!object.hasOwnProperty('width') || object.parentContainer)
|
2018-01-16 15:06:47 +00:00
|
|
|
{
|
|
|
|
culledObjects.push(object);
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
var objectW = object.width;
|
|
|
|
var objectH = object.height;
|
|
|
|
var objectX = (object.x - (scrollX * object.scrollFactorX)) - (objectW * object.originX);
|
|
|
|
var objectY = (object.y - (scrollY * object.scrollFactorY)) - (objectH * object.originY);
|
|
|
|
var tx = (objectX * mva + objectY * mvc + mve);
|
|
|
|
var ty = (objectX * mvb + objectY * mvd + mvf);
|
|
|
|
var tw = ((objectX + objectW) * mva + (objectY + objectH) * mvc + mve);
|
|
|
|
var th = ((objectX + objectW) * mvb + (objectY + objectH) * mvd + mvf);
|
|
|
|
var cullW = cameraW + objectW;
|
|
|
|
var cullH = cameraH + objectH;
|
|
|
|
|
|
|
|
if (tx > -objectW || ty > -objectH || tx < cullW || ty < cullH ||
|
|
|
|
tw > -objectW || th > -objectH || tw < cullW || th < cullH)
|
|
|
|
{
|
|
|
|
culledObjects.push(object);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return culledObjects;
|
|
|
|
},
|
|
|
|
|
2018-03-20 00:10:55 +00:00
|
|
|
/**
|
|
|
|
* Fades the Camera in from the given color over the duration specified.
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#fadeIn
|
|
|
|
* @since 3.3.0
|
|
|
|
*
|
2018-04-14 16:39:43 +00:00
|
|
|
* @param {integer} [duration=1000] - The duration of the effect in milliseconds.
|
|
|
|
* @param {integer} [red=0] - The amount to fade the red channel towards. A value between 0 and 255.
|
|
|
|
* @param {integer} [green=0] - The amount to fade the green channel towards. A value between 0 and 255.
|
|
|
|
* @param {integer} [blue=0] - The amount to fade the blue channel towards. A value between 0 and 255.
|
|
|
|
* @param {function} [callback] - This callback will be invoked every frame for the duration of the effect.
|
|
|
|
* It is sent two arguments: A reference to the camera and a progress amount between 0 and 1 indicating how complete the effect is.
|
|
|
|
* @param {any} [context] - The context in which the callback is invoked. Defaults to the Scene to which the Camera belongs.
|
2018-03-20 00:10:55 +00:00
|
|
|
*
|
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
2018-04-14 16:39:43 +00:00
|
|
|
fadeIn: function (duration, red, green, blue, callback, context)
|
2018-03-20 00:10:55 +00:00
|
|
|
{
|
2018-04-14 16:39:43 +00:00
|
|
|
return this.effects.fade.start(false, duration, red, green, blue, true, callback, context);
|
2018-03-20 00:10:55 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fades the Camera out to the given color over the duration specified.
|
|
|
|
* This is an alias for Camera.fade that forces the fade to start, regardless of existing fades.
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#fadeOut
|
|
|
|
* @since 3.3.0
|
|
|
|
*
|
2018-04-14 16:39:43 +00:00
|
|
|
* @param {integer} [duration=1000] - The duration of the effect in milliseconds.
|
|
|
|
* @param {integer} [red=0] - The amount to fade the red channel towards. A value between 0 and 255.
|
|
|
|
* @param {integer} [green=0] - The amount to fade the green channel towards. A value between 0 and 255.
|
|
|
|
* @param {integer} [blue=0] - The amount to fade the blue channel towards. A value between 0 and 255.
|
|
|
|
* @param {function} [callback] - This callback will be invoked every frame for the duration of the effect.
|
|
|
|
* It is sent two arguments: A reference to the camera and a progress amount between 0 and 1 indicating how complete the effect is.
|
|
|
|
* @param {any} [context] - The context in which the callback is invoked. Defaults to the Scene to which the Camera belongs.
|
2018-03-20 00:10:55 +00:00
|
|
|
*
|
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
2018-04-14 16:39:43 +00:00
|
|
|
fadeOut: function (duration, red, green, blue, callback, context)
|
2018-03-20 00:10:55 +00:00
|
|
|
{
|
2018-04-14 16:39:43 +00:00
|
|
|
return this.effects.fade.start(true, duration, red, green, blue, true, callback, context);
|
|
|
|
},
|
2018-03-20 00:10:55 +00:00
|
|
|
|
2018-04-14 16:39:43 +00:00
|
|
|
/**
|
|
|
|
* Fades the Camera from the given color to transparent over the duration specified.
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#fadeFrom
|
|
|
|
* @since 3.5.0
|
|
|
|
*
|
|
|
|
* @param {integer} [duration=1000] - The duration of the effect in milliseconds.
|
|
|
|
* @param {integer} [red=0] - The amount to fade the red channel towards. A value between 0 and 255.
|
|
|
|
* @param {integer} [green=0] - The amount to fade the green channel towards. A value between 0 and 255.
|
|
|
|
* @param {integer} [blue=0] - The amount to fade the blue channel towards. A value between 0 and 255.
|
|
|
|
* @param {boolean} [force=false] - Force the effect to start immediately, even if already running.
|
|
|
|
* @param {function} [callback] - This callback will be invoked every frame for the duration of the effect.
|
|
|
|
* It is sent two arguments: A reference to the camera and a progress amount between 0 and 1 indicating how complete the effect is.
|
|
|
|
* @param {any} [context] - The context in which the callback is invoked. Defaults to the Scene to which the Camera belongs.
|
|
|
|
*
|
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
|
|
|
fadeFrom: function (duration, red, green, blue, force, callback, context)
|
|
|
|
{
|
|
|
|
return this.effects.fade.start(false, duration, red, green, blue, force, callback, context);
|
2018-03-20 00:10:55 +00:00
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
2018-04-14 16:39:43 +00:00
|
|
|
* Fades the Camera from transparent to the given color over the duration specified.
|
2018-01-25 03:38:23 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#fade
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-04-14 16:39:43 +00:00
|
|
|
* @param {integer} [duration=1000] - The duration of the effect in milliseconds.
|
|
|
|
* @param {integer} [red=0] - The amount to fade the red channel towards. A value between 0 and 255.
|
|
|
|
* @param {integer} [green=0] - The amount to fade the green channel towards. A value between 0 and 255.
|
|
|
|
* @param {integer} [blue=0] - The amount to fade the blue channel towards. A value between 0 and 255.
|
|
|
|
* @param {boolean} [force=false] - Force the effect to start immediately, even if already running.
|
|
|
|
* @param {function} [callback] - This callback will be invoked every frame for the duration of the effect.
|
|
|
|
* It is sent two arguments: A reference to the camera and a progress amount between 0 and 1 indicating how complete the effect is.
|
|
|
|
* @param {any} [context] - The context in which the callback is invoked. Defaults to the Scene to which the Camera belongs.
|
2018-01-25 03:38:23 +00:00
|
|
|
*
|
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
2018-04-14 16:39:43 +00:00
|
|
|
fade: function (duration, red, green, blue, force, callback, context)
|
2018-01-16 15:06:47 +00:00
|
|
|
{
|
2018-04-14 16:39:43 +00:00
|
|
|
return this.effects.fade.start(true, duration, red, green, blue, force, callback, context);
|
2018-01-16 15:06:47 +00:00
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
2018-04-14 16:39:43 +00:00
|
|
|
* Flashes the Camera by setting it to the given color immediately and then fading it away again quickly over the duration specified.
|
2018-01-25 03:38:23 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#flash
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-04-15 03:00:21 +00:00
|
|
|
* @param {integer} [duration=250] - The duration of the effect in milliseconds.
|
2018-04-14 16:39:43 +00:00
|
|
|
* @param {integer} [red=255] - The amount to fade the red channel towards. A value between 0 and 255.
|
|
|
|
* @param {integer} [green=255] - The amount to fade the green channel towards. A value between 0 and 255.
|
|
|
|
* @param {integer} [blue=255] - The amount to fade the blue channel towards. A value between 0 and 255.
|
|
|
|
* @param {boolean} [force=false] - Force the effect to start immediately, even if already running.
|
|
|
|
* @param {function} [callback] - This callback will be invoked every frame for the duration of the effect.
|
|
|
|
* It is sent two arguments: A reference to the camera and a progress amount between 0 and 1 indicating how complete the effect is.
|
|
|
|
* @param {any} [context] - The context in which the callback is invoked. Defaults to the Scene to which the Camera belongs.
|
2018-01-25 03:38:23 +00:00
|
|
|
*
|
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
2018-04-14 16:39:43 +00:00
|
|
|
flash: function (duration, red, green, blue, force, callback, context)
|
2018-01-16 15:06:47 +00:00
|
|
|
{
|
2018-04-14 16:39:43 +00:00
|
|
|
return this.effects.flash.start(duration, red, green, blue, force, callback, context);
|
2018-01-16 15:06:47 +00:00
|
|
|
},
|
|
|
|
|
2018-03-19 15:21:48 +00:00
|
|
|
/**
|
2018-03-19 23:29:15 +00:00
|
|
|
* Shakes the Camera by the given intensity over the duration specified.
|
2018-03-19 15:21:48 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#shake
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-04-14 16:39:43 +00:00
|
|
|
* @param {integer} [duration=100] - The duration of the effect in milliseconds.
|
2018-03-19 23:29:15 +00:00
|
|
|
* @param {number} [intensity=0.05] - The intensity of the shake.
|
|
|
|
* @param {boolean} [force=false] - Force the shake effect to start immediately, even if already running.
|
2018-04-14 16:39:43 +00:00
|
|
|
* @param {function} [callback] - This callback will be invoked every frame for the duration of the effect.
|
|
|
|
* It is sent two arguments: A reference to the camera and a progress amount between 0 and 1 indicating how complete the effect is.
|
2018-04-14 11:35:14 +00:00
|
|
|
* @param {any} [context] - The context in which the callback is invoked. Defaults to the Scene to which the Camera belongs.
|
2018-03-19 15:21:48 +00:00
|
|
|
*
|
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
2018-04-14 11:35:14 +00:00
|
|
|
shake: function (duration, intensity, force, callback, context)
|
2018-03-19 15:21:48 +00:00
|
|
|
{
|
2018-04-14 16:39:43 +00:00
|
|
|
return this.effects.shake.start(duration, intensity, force, callback, context);
|
2018-03-19 15:21:48 +00:00
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#getWorldPoint
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-03-27 11:51:45 +00:00
|
|
|
* @generic {Phaser.Math.Vector2} O - [output,$return]
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @param {number} x - [description]
|
|
|
|
* @param {number} y - [description]
|
2018-03-27 11:51:45 +00:00
|
|
|
* @param {(object|Phaser.Math.Vector2)} [output] - [description]
|
2018-01-25 03:38:23 +00:00
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @return {Phaser.Math.Vector2} [description]
|
2018-01-25 03:38:23 +00:00
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
getWorldPoint: function (x, y, output)
|
|
|
|
{
|
|
|
|
if (output === undefined) { output = new Vector2(); }
|
|
|
|
|
|
|
|
var cameraMatrix = this.matrix.matrix;
|
|
|
|
|
|
|
|
var mva = cameraMatrix[0];
|
|
|
|
var mvb = cameraMatrix[1];
|
|
|
|
var mvc = cameraMatrix[2];
|
|
|
|
var mvd = cameraMatrix[3];
|
|
|
|
var mve = cameraMatrix[4];
|
|
|
|
var mvf = cameraMatrix[5];
|
2018-01-28 17:06:37 +00:00
|
|
|
|
2018-01-16 15:06:47 +00:00
|
|
|
/* First Invert Matrix */
|
|
|
|
var determinant = (mva * mvd) - (mvb * mvc);
|
|
|
|
|
|
|
|
if (!determinant)
|
|
|
|
{
|
|
|
|
output.x = x;
|
|
|
|
output.y = y;
|
|
|
|
|
|
|
|
return output;
|
|
|
|
}
|
|
|
|
|
|
|
|
determinant = 1 / determinant;
|
|
|
|
|
|
|
|
var ima = mvd * determinant;
|
|
|
|
var imb = -mvb * determinant;
|
|
|
|
var imc = -mvc * determinant;
|
|
|
|
var imd = mva * determinant;
|
|
|
|
var ime = (mvc * mvf - mvd * mve) * determinant;
|
|
|
|
var imf = (mvb * mve - mva * mvf) * determinant;
|
|
|
|
|
|
|
|
var c = Math.cos(this.rotation);
|
|
|
|
var s = Math.sin(this.rotation);
|
|
|
|
|
|
|
|
var zoom = this.zoom;
|
|
|
|
|
|
|
|
var scrollX = this.scrollX;
|
|
|
|
var scrollY = this.scrollY;
|
|
|
|
|
|
|
|
var sx = x + ((scrollX * c - scrollY * s) * zoom);
|
|
|
|
var sy = y + ((scrollX * s + scrollY * c) * zoom);
|
|
|
|
|
|
|
|
/* Apply transform to point */
|
|
|
|
output.x = (sx * ima + sy * imc + ime);
|
|
|
|
output.y = (sx * imb + sy * imd + imf);
|
2018-01-28 17:06:37 +00:00
|
|
|
|
2018-01-16 15:06:47 +00:00
|
|
|
return output;
|
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#ignore
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-03-20 14:58:02 +00:00
|
|
|
* @param {(Phaser.GameObjects.GameObject|Phaser.GameObjects.GameObject[])} gameObjectOrArray - [description]
|
2018-01-28 17:06:37 +00:00
|
|
|
*
|
2018-01-25 03:38:23 +00:00
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
ignore: function (gameObjectOrArray)
|
|
|
|
{
|
2018-04-05 08:23:52 +00:00
|
|
|
if (Array.isArray(gameObjectOrArray))
|
2018-01-16 15:06:47 +00:00
|
|
|
{
|
|
|
|
for (var index = 0; index < gameObjectOrArray.length; ++index)
|
|
|
|
{
|
|
|
|
gameObjectOrArray[index].cameraFilter |= this._id;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
gameObjectOrArray.cameraFilter |= this._id;
|
|
|
|
}
|
2018-01-25 03:38:23 +00:00
|
|
|
|
|
|
|
return this;
|
2018-01-16 15:06:47 +00:00
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#preRender
|
|
|
|
* @since 3.0.0
|
2018-02-01 00:01:27 +00:00
|
|
|
*
|
|
|
|
* @param {number} baseScale - [description]
|
2018-02-12 21:39:26 +00:00
|
|
|
* @param {number} resolution - [description]
|
2018-02-01 00:01:27 +00:00
|
|
|
*
|
2018-01-25 03:38:23 +00:00
|
|
|
*/
|
2018-02-12 19:03:13 +00:00
|
|
|
preRender: function (baseScale, resolution)
|
2018-01-16 15:06:47 +00:00
|
|
|
{
|
|
|
|
var width = this.width;
|
|
|
|
var height = this.height;
|
2018-02-01 00:52:48 +00:00
|
|
|
var zoom = this.zoom * baseScale;
|
2018-01-16 15:06:47 +00:00
|
|
|
var matrix = this.matrix;
|
|
|
|
var originX = width / 2;
|
|
|
|
var originY = height / 2;
|
|
|
|
var follow = this._follow;
|
|
|
|
|
|
|
|
if (follow !== null)
|
|
|
|
{
|
|
|
|
originX = follow.x;
|
|
|
|
originY = follow.y;
|
2018-01-28 17:06:37 +00:00
|
|
|
|
2018-03-09 06:26:09 +00:00
|
|
|
this.scrollX = (originX - width * 0.5) / zoom;
|
|
|
|
this.scrollY = (originY - height * 0.5) / zoom;
|
2018-01-16 15:06:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (this.useBounds)
|
|
|
|
{
|
|
|
|
var bounds = this._bounds;
|
|
|
|
|
|
|
|
var bw = Math.max(0, bounds.right - width);
|
|
|
|
var bh = Math.max(0, bounds.bottom - height);
|
|
|
|
|
|
|
|
if (this.scrollX < bounds.x)
|
|
|
|
{
|
|
|
|
this.scrollX = bounds.x;
|
|
|
|
}
|
|
|
|
else if (this.scrollX > bw)
|
|
|
|
{
|
|
|
|
this.scrollX = bw;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (this.scrollY < bounds.y)
|
|
|
|
{
|
|
|
|
this.scrollY = bounds.y;
|
|
|
|
}
|
|
|
|
else if (this.scrollY > bh)
|
|
|
|
{
|
|
|
|
this.scrollY = bh;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (this.roundPixels)
|
|
|
|
{
|
|
|
|
this.scrollX = Math.round(this.scrollX);
|
|
|
|
this.scrollY = Math.round(this.scrollY);
|
|
|
|
}
|
|
|
|
|
|
|
|
matrix.loadIdentity();
|
2018-02-12 19:03:13 +00:00
|
|
|
matrix.scale(resolution, resolution);
|
2018-01-16 15:06:47 +00:00
|
|
|
matrix.translate(this.x + originX, this.y + originY);
|
|
|
|
matrix.rotate(this.rotation);
|
|
|
|
matrix.scale(zoom, zoom);
|
|
|
|
matrix.translate(-originX, -originY);
|
2018-04-14 11:35:14 +00:00
|
|
|
|
2018-04-14 16:39:43 +00:00
|
|
|
this.effects.shake.preRender();
|
2018-01-16 15:06:47 +00:00
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#removeBounds
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
removeBounds: function ()
|
|
|
|
{
|
|
|
|
this.useBounds = false;
|
|
|
|
|
|
|
|
this._bounds.setEmpty();
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#setAngle
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-03-27 11:51:45 +00:00
|
|
|
* @param {number} [value=0] - [description]
|
2018-01-25 03:38:23 +00:00
|
|
|
*
|
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
setAngle: function (value)
|
|
|
|
{
|
|
|
|
if (value === undefined) { value = 0; }
|
|
|
|
|
|
|
|
this.rotation = DegToRad(value);
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#setBackgroundColor
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-03-27 11:51:45 +00:00
|
|
|
* @param {(string|number|InputColorObject)} [color='rgba(0,0,0,0)'] - [description]
|
2018-01-25 03:38:23 +00:00
|
|
|
*
|
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
setBackgroundColor: function (color)
|
|
|
|
{
|
|
|
|
if (color === undefined) { color = 'rgba(0,0,0,0)'; }
|
|
|
|
|
|
|
|
this.backgroundColor = ValueToColor(color);
|
|
|
|
|
|
|
|
this.transparent = (this.backgroundColor.alpha === 0);
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#setBounds
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @param {number} x - [description]
|
|
|
|
* @param {number} y - [description]
|
|
|
|
* @param {number} width - [description]
|
|
|
|
* @param {number} height - [description]
|
2018-01-25 03:38:23 +00:00
|
|
|
*
|
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
setBounds: function (x, y, width, height)
|
|
|
|
{
|
|
|
|
this._bounds.setTo(x, y, width, height);
|
|
|
|
|
|
|
|
this.useBounds = true;
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#setName
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-03-27 11:51:45 +00:00
|
|
|
* @param {string} [value=''] - [description]
|
2018-01-25 03:38:23 +00:00
|
|
|
*
|
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
setName: function (value)
|
|
|
|
{
|
|
|
|
if (value === undefined) { value = ''; }
|
|
|
|
|
|
|
|
this.name = value;
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#setPosition
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @param {number} x - [description]
|
2018-03-19 23:29:15 +00:00
|
|
|
* @param {number} [y=x] - [description]
|
2018-01-25 03:38:23 +00:00
|
|
|
*
|
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
setPosition: function (x, y)
|
|
|
|
{
|
|
|
|
if (y === undefined) { y = x; }
|
|
|
|
|
|
|
|
this.x = x;
|
|
|
|
this.y = y;
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#setRotation
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-03-19 23:29:15 +00:00
|
|
|
* @param {number} [value=0] - [description]
|
2018-01-25 03:38:23 +00:00
|
|
|
*
|
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
setRotation: function (value)
|
|
|
|
{
|
|
|
|
if (value === undefined) { value = 0; }
|
|
|
|
|
|
|
|
this.rotation = value;
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#setRoundPixels
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @param {boolean} value - [description]
|
2018-01-25 03:38:23 +00:00
|
|
|
*
|
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
setRoundPixels: function (value)
|
|
|
|
{
|
|
|
|
this.roundPixels = value;
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#setScene
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @param {Phaser.Scene} scene - [description]
|
2018-01-25 03:38:23 +00:00
|
|
|
*
|
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
setScene: function (scene)
|
|
|
|
{
|
|
|
|
this.scene = scene;
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#setScroll
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @param {number} x - [description]
|
2018-03-19 23:29:15 +00:00
|
|
|
* @param {number} [y=x] - [description]
|
2018-01-25 03:38:23 +00:00
|
|
|
*
|
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
setScroll: function (x, y)
|
|
|
|
{
|
|
|
|
if (y === undefined) { y = x; }
|
|
|
|
|
|
|
|
this.scrollX = x;
|
|
|
|
this.scrollY = y;
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#setSize
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @param {number} width - [description]
|
2018-03-19 23:29:15 +00:00
|
|
|
* @param {number} [height=width] - [description]
|
2018-01-25 03:38:23 +00:00
|
|
|
*
|
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
setSize: function (width, height)
|
|
|
|
{
|
|
|
|
if (height === undefined) { height = width; }
|
|
|
|
|
|
|
|
this.width = width;
|
|
|
|
this.height = height;
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#setViewport
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-02-12 13:14:50 +00:00
|
|
|
* @param {number} x - [description]
|
|
|
|
* @param {number} y - [description]
|
|
|
|
* @param {number} width - [description]
|
|
|
|
* @param {number} height - [description]
|
2018-01-25 03:38:23 +00:00
|
|
|
*
|
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
setViewport: function (x, y, width, height)
|
|
|
|
{
|
|
|
|
this.x = x;
|
|
|
|
this.y = y;
|
|
|
|
this.width = width;
|
|
|
|
this.height = height;
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#setZoom
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-03-19 23:29:15 +00:00
|
|
|
* @param {float} [value=1] - [description]
|
2018-01-25 03:38:23 +00:00
|
|
|
*
|
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
setZoom: function (value)
|
|
|
|
{
|
|
|
|
if (value === undefined) { value = 1; }
|
|
|
|
|
|
|
|
this.zoom = value;
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#startFollow
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-03-20 14:58:02 +00:00
|
|
|
* @param {(Phaser.GameObjects.GameObject|object)} target - [description]
|
2018-03-27 11:51:45 +00:00
|
|
|
* @param {boolean} [roundPx=false] - [description]
|
2018-01-25 03:38:23 +00:00
|
|
|
*
|
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
2018-03-19 23:29:15 +00:00
|
|
|
startFollow: function (target, roundPx)
|
2018-01-16 15:06:47 +00:00
|
|
|
{
|
2018-03-19 23:29:15 +00:00
|
|
|
if (roundPx === undefined) { roundPx = false; }
|
2018-01-16 15:06:47 +00:00
|
|
|
|
2018-03-19 23:29:15 +00:00
|
|
|
this._follow = target;
|
|
|
|
|
|
|
|
this.roundPixels = roundPx;
|
2018-01-16 15:06:47 +00:00
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#stopFollow
|
|
|
|
* @since 3.0.0
|
2018-01-28 17:06:37 +00:00
|
|
|
*
|
2018-01-25 03:38:23 +00:00
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
stopFollow: function ()
|
|
|
|
{
|
|
|
|
this._follow = null;
|
2018-01-25 03:38:23 +00:00
|
|
|
|
|
|
|
return this;
|
2018-01-16 15:06:47 +00:00
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#toJSON
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-03-19 16:21:25 +00:00
|
|
|
* @return {JSONCamera} [description]
|
2018-01-25 03:38:23 +00:00
|
|
|
*/
|
2018-01-16 15:06:47 +00:00
|
|
|
toJSON: function ()
|
|
|
|
{
|
|
|
|
var output = {
|
|
|
|
name: this.name,
|
|
|
|
x: this.x,
|
|
|
|
y: this.y,
|
|
|
|
width: this.width,
|
|
|
|
height: this.height,
|
|
|
|
zoom: this.zoom,
|
|
|
|
rotation: this.rotation,
|
|
|
|
roundPixels: this.roundPixels,
|
|
|
|
scrollX: this.scrollX,
|
|
|
|
scrollY: this.scrollY,
|
|
|
|
backgroundColor: this.backgroundColor.rgba
|
|
|
|
};
|
|
|
|
|
|
|
|
if (this.useBounds)
|
|
|
|
{
|
|
|
|
output['bounds'] = {
|
|
|
|
x: this._bounds.x,
|
|
|
|
y: this._bounds.y,
|
|
|
|
width: this._bounds.width,
|
|
|
|
height: this._bounds.height
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
return output;
|
|
|
|
},
|
|
|
|
|
2018-01-28 17:06:37 +00:00
|
|
|
/**
|
|
|
|
* Resets any active FX, such as a fade, flash or shake. Useful to call after a fade in order to
|
|
|
|
* remove the fade.
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#resetFX
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
|
|
|
* @return {Phaser.Cameras.Scene2D.Camera} This Camera instance.
|
|
|
|
*/
|
|
|
|
resetFX: function ()
|
|
|
|
{
|
2018-04-14 16:39:43 +00:00
|
|
|
this.effects.shake.reset();
|
2018-04-15 03:00:21 +00:00
|
|
|
this.effects.flash.reset();
|
2018-04-14 16:39:43 +00:00
|
|
|
this.effects.fade.reset();
|
2018-01-28 17:06:37 +00:00
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#update
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-03-18 13:43:37 +00:00
|
|
|
* @param {integer} time - The current timestamp as generated by the Request Animation Frame or SetTimeout.
|
|
|
|
* @param {number} delta - The delta time, in ms, elapsed since the last frame.
|
2018-01-25 03:38:23 +00:00
|
|
|
*/
|
2018-03-18 13:43:37 +00:00
|
|
|
update: function (time, delta)
|
2018-01-16 15:06:47 +00:00
|
|
|
{
|
2018-04-14 16:39:43 +00:00
|
|
|
this.effects.shake.update(time, delta);
|
2018-04-15 03:00:21 +00:00
|
|
|
this.effects.flash.update(time, delta);
|
2018-04-14 16:39:43 +00:00
|
|
|
this.effects.fade.update(time, delta);
|
2018-01-25 03:38:23 +00:00
|
|
|
},
|
|
|
|
|
2018-04-14 11:35:14 +00:00
|
|
|
/**
|
|
|
|
* This event is fired when a camera is destroyed by the Camera Manager.
|
|
|
|
*
|
|
|
|
* @event CameraDestroyEvent
|
|
|
|
* @param {Phaser.Cameras.Scene2D.Camera} camera - The camera that was destroyed.
|
|
|
|
*/
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
/**
|
|
|
|
* [description]
|
|
|
|
*
|
|
|
|
* @method Phaser.Cameras.Scene2D.Camera#destroy
|
2018-04-14 11:35:14 +00:00
|
|
|
* @fires CameraDestroyEvent
|
2018-01-25 03:38:23 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
|
|
|
destroy: function ()
|
|
|
|
{
|
2018-04-14 11:35:14 +00:00
|
|
|
this.emit('cameradestroy', this);
|
|
|
|
|
|
|
|
this.removeAllListeners();
|
|
|
|
|
2018-04-15 03:00:21 +00:00
|
|
|
this.resetFX();
|
|
|
|
|
2018-04-14 11:35:14 +00:00
|
|
|
this.matrix.destroy();
|
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
this._bounds = undefined;
|
2018-04-14 11:35:14 +00:00
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
this.culledObjects = [];
|
2018-04-14 11:35:14 +00:00
|
|
|
|
2018-01-25 03:38:23 +00:00
|
|
|
this.scene = undefined;
|
2018-02-12 13:14:50 +00:00
|
|
|
}
|
2018-01-16 15:06:47 +00:00
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
module.exports = Camera;
|