2018-02-12 22:16:27 +00:00
|
|
|
/**
|
|
|
|
* @author Richard Davey <rich@photonstorm.com>
|
2022-02-28 14:29:51 +00:00
|
|
|
* @copyright 2022 Photon Storm Ltd.
|
2019-05-10 15:15:04 +00:00
|
|
|
* @license {@link https://opensource.org/licenses/MIT|MIT License}
|
2018-02-12 22:16:27 +00:00
|
|
|
*/
|
|
|
|
|
2020-12-02 17:56:53 +00:00
|
|
|
var Circle = require('../../geom/circle/Circle');
|
2018-02-12 22:16:27 +00:00
|
|
|
var Class = require('../../utils/Class');
|
2020-12-02 17:56:53 +00:00
|
|
|
var Components = require('../components');
|
|
|
|
var RGB = require('../../display/RGB');
|
2018-02-12 22:16:27 +00:00
|
|
|
var Utils = require('../../renderer/webgl/Utils');
|
|
|
|
|
2018-02-12 23:03:48 +00:00
|
|
|
/**
|
|
|
|
* @classdesc
|
2018-06-08 14:40:28 +00:00
|
|
|
* A 2D point light.
|
|
|
|
*
|
2018-06-13 17:44:17 +00:00
|
|
|
* These are typically created by a {@link Phaser.GameObjects.LightsManager}, available from within a scene via `this.lights`.
|
|
|
|
*
|
2020-07-16 02:26:32 +00:00
|
|
|
* Any Game Objects using the Light2D pipeline will then be affected by these Lights as long as they have a normal map.
|
2018-06-13 17:44:17 +00:00
|
|
|
*
|
|
|
|
* They can also simply be used to represent a point light for your own purposes.
|
2018-02-12 23:03:48 +00:00
|
|
|
*
|
2022-05-31 17:10:25 +00:00
|
|
|
* As of Phaser 3.60 this Game Object now has the Transform and Origin components. However, changing the scale,
|
|
|
|
* rotation or origin properties will not make any difference to the Light. They are simply present to allow you
|
|
|
|
* to add this Light to a Container, or enable it for Physics.
|
|
|
|
*
|
2018-02-12 23:03:48 +00:00
|
|
|
* @class Light
|
2020-12-02 17:56:53 +00:00
|
|
|
* @extends Phaser.Geom.Circle
|
2018-10-10 09:49:13 +00:00
|
|
|
* @memberof Phaser.GameObjects
|
2018-02-12 23:03:48 +00:00
|
|
|
* @constructor
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2022-05-31 17:10:25 +00:00
|
|
|
* @extends Phaser.GameObjects.Components.Origin
|
2020-12-02 17:56:53 +00:00
|
|
|
* @extends Phaser.GameObjects.Components.ScrollFactor
|
2022-05-31 17:10:25 +00:00
|
|
|
* @extends Phaser.GameObjects.Components.Transform
|
2020-12-02 17:56:53 +00:00
|
|
|
* @extends Phaser.GameObjects.Components.Visible
|
|
|
|
*
|
2018-02-12 23:03:48 +00:00
|
|
|
* @param {number} x - The horizontal position of the light.
|
|
|
|
* @param {number} y - The vertical position of the light.
|
|
|
|
* @param {number} radius - The radius of the light.
|
2018-06-08 14:40:28 +00:00
|
|
|
* @param {number} r - The red color of the light. A value between 0 and 1.
|
|
|
|
* @param {number} g - The green color of the light. A value between 0 and 1.
|
|
|
|
* @param {number} b - The blue color of the light. A value between 0 and 1.
|
2018-02-12 23:03:48 +00:00
|
|
|
* @param {number} intensity - The intensity of the light.
|
|
|
|
*/
|
2018-02-12 22:16:27 +00:00
|
|
|
var Light = new Class({
|
|
|
|
|
2020-12-02 17:56:53 +00:00
|
|
|
Extends: Circle,
|
|
|
|
|
|
|
|
Mixins: [
|
2022-05-31 17:10:25 +00:00
|
|
|
Components.Origin,
|
2020-12-02 17:56:53 +00:00
|
|
|
Components.ScrollFactor,
|
2022-05-31 17:10:25 +00:00
|
|
|
Components.Transform,
|
2020-12-02 17:56:53 +00:00
|
|
|
Components.Visible
|
|
|
|
],
|
|
|
|
|
2018-02-12 22:16:27 +00:00
|
|
|
initialize:
|
|
|
|
|
|
|
|
function Light (x, y, radius, r, g, b, intensity)
|
|
|
|
{
|
2020-12-02 17:56:53 +00:00
|
|
|
Circle.call(this, x, y, radius);
|
2018-02-12 23:03:48 +00:00
|
|
|
|
|
|
|
/**
|
2020-12-02 17:56:53 +00:00
|
|
|
* The color of the light.
|
2018-02-12 23:03:48 +00:00
|
|
|
*
|
2020-12-02 17:56:53 +00:00
|
|
|
* @name Phaser.GameObjects.Light#color
|
|
|
|
* @type {Phaser.Display.RGB}
|
|
|
|
* @since 3.50.0
|
2018-02-12 23:03:48 +00:00
|
|
|
*/
|
2020-12-02 17:56:53 +00:00
|
|
|
this.color = new RGB(r, g, b);
|
2018-02-12 23:03:48 +00:00
|
|
|
|
|
|
|
/**
|
2018-06-08 14:40:28 +00:00
|
|
|
* The intensity of the light.
|
2018-02-12 23:03:48 +00:00
|
|
|
*
|
2020-12-02 17:56:53 +00:00
|
|
|
* @name Phaser.GameObjects.Light#intensity
|
2018-02-12 23:03:48 +00:00
|
|
|
* @type {number}
|
2020-12-02 17:56:53 +00:00
|
|
|
* @since 3.50.0
|
2018-02-12 23:03:48 +00:00
|
|
|
*/
|
2020-12-02 17:56:53 +00:00
|
|
|
this.intensity = intensity;
|
2018-02-12 23:03:48 +00:00
|
|
|
|
|
|
|
/**
|
2020-12-02 17:56:53 +00:00
|
|
|
* The flags that are compared against `RENDER_MASK` to determine if this Game Object will render or not.
|
|
|
|
* The bits are 0001 | 0010 | 0100 | 1000 set by the components Visible, Alpha, Transform and Texture respectively.
|
|
|
|
* If those components are not used by your custom class then you can use this bitmask as you wish.
|
2018-02-12 23:03:48 +00:00
|
|
|
*
|
2021-07-08 21:54:10 +00:00
|
|
|
* @name Phaser.GameObjects.Light#renderFlags
|
2018-02-12 23:03:48 +00:00
|
|
|
* @type {number}
|
2020-12-02 17:56:53 +00:00
|
|
|
* @default 15
|
2018-02-12 23:03:48 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2020-12-02 17:56:53 +00:00
|
|
|
this.renderFlags = 15;
|
2018-02-12 23:03:48 +00:00
|
|
|
|
|
|
|
/**
|
2020-12-02 17:56:53 +00:00
|
|
|
* A bitmask that controls if this Game Object is drawn by a Camera or not.
|
|
|
|
* Not usually set directly, instead call `Camera.ignore`, however you can
|
|
|
|
* set this property directly using the Camera.id property:
|
|
|
|
*
|
|
|
|
* @example
|
|
|
|
* this.cameraFilter |= camera.id
|
2018-02-12 23:03:48 +00:00
|
|
|
*
|
2021-07-08 21:54:10 +00:00
|
|
|
* @name Phaser.GameObjects.Light#cameraFilter
|
2018-02-12 23:03:48 +00:00
|
|
|
* @type {number}
|
2020-12-02 17:56:53 +00:00
|
|
|
* @default 0
|
2018-02-12 23:03:48 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2020-12-02 17:56:53 +00:00
|
|
|
this.cameraFilter = 0;
|
2020-07-16 02:26:32 +00:00
|
|
|
|
2020-12-02 17:56:53 +00:00
|
|
|
this.setScrollFactor(1, 1);
|
2022-05-31 17:10:25 +00:00
|
|
|
this.setOrigin();
|
|
|
|
this.setDisplayOrigin(radius);
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The width of this Light Game Object. This is the same as `Light.diameter`.
|
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.Light#displayWidth
|
|
|
|
* @type {number}
|
|
|
|
* @since 3.60.0
|
|
|
|
*/
|
|
|
|
displayWidth: {
|
|
|
|
|
|
|
|
get: function ()
|
|
|
|
{
|
|
|
|
return this.diameter;
|
|
|
|
},
|
|
|
|
|
|
|
|
set: function (value)
|
|
|
|
{
|
|
|
|
this.diameter = value;
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The height of this Light Game Object. This is the same as `Light.diameter`.
|
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.Light#displayHeight
|
|
|
|
* @type {number}
|
|
|
|
* @since 3.60.0
|
|
|
|
*/
|
|
|
|
displayHeight: {
|
|
|
|
|
|
|
|
get: function ()
|
|
|
|
{
|
|
|
|
return this.diameter;
|
|
|
|
},
|
|
|
|
|
|
|
|
set: function (value)
|
|
|
|
{
|
|
|
|
this.diameter = value;
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The width of this Light Game Object. This is the same as `Light.diameter`.
|
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.Light#width
|
|
|
|
* @type {number}
|
|
|
|
* @since 3.60.0
|
|
|
|
*/
|
|
|
|
width: {
|
|
|
|
|
|
|
|
get: function ()
|
|
|
|
{
|
|
|
|
return this.diameter;
|
|
|
|
},
|
|
|
|
|
|
|
|
set: function (value)
|
|
|
|
{
|
|
|
|
this.diameter = value;
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The height of this Light Game Object. This is the same as `Light.diameter`.
|
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.Light#height
|
|
|
|
* @type {number}
|
|
|
|
* @since 3.60.0
|
|
|
|
*/
|
|
|
|
height: {
|
|
|
|
|
|
|
|
get: function ()
|
|
|
|
{
|
|
|
|
return this.diameter;
|
|
|
|
},
|
|
|
|
|
|
|
|
set: function (value)
|
|
|
|
{
|
|
|
|
this.diameter = value;
|
|
|
|
}
|
|
|
|
|
2018-02-12 22:16:27 +00:00
|
|
|
},
|
|
|
|
|
2018-02-12 23:03:48 +00:00
|
|
|
/**
|
2020-12-02 17:56:53 +00:00
|
|
|
* Compares the renderMask with the renderFlags to see if this Game Object will render or not.
|
|
|
|
* Also checks the Game Object against the given Cameras exclusion list.
|
2018-02-12 23:03:48 +00:00
|
|
|
*
|
2020-12-02 17:56:53 +00:00
|
|
|
* @method Phaser.GameObjects.Light#willRender
|
|
|
|
* @since 3.50.0
|
2018-02-12 23:03:48 +00:00
|
|
|
*
|
2020-12-02 17:56:53 +00:00
|
|
|
* @param {Phaser.Cameras.Scene2D.Camera} camera - The Camera to check against this Game Object.
|
2018-02-12 23:03:48 +00:00
|
|
|
*
|
2020-12-02 17:56:53 +00:00
|
|
|
* @return {boolean} True if the Game Object should be rendered, otherwise false.
|
2018-02-12 23:03:48 +00:00
|
|
|
*/
|
2020-12-02 17:56:53 +00:00
|
|
|
willRender: function (camera)
|
2018-02-12 22:16:27 +00:00
|
|
|
{
|
2020-12-02 17:56:53 +00:00
|
|
|
return !(Light.RENDER_MASK !== this.renderFlags || (this.cameraFilter !== 0 && (this.cameraFilter & camera.id)));
|
2018-02-12 22:16:27 +00:00
|
|
|
},
|
|
|
|
|
2018-02-12 23:03:48 +00:00
|
|
|
/**
|
2018-06-08 14:40:28 +00:00
|
|
|
* Set the color of the light from a single integer RGB value.
|
2018-02-12 23:03:48 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Light#setColor
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-13 17:44:17 +00:00
|
|
|
* @param {number} rgb - The integer RGB color of the light.
|
2018-02-12 23:03:48 +00:00
|
|
|
*
|
2020-01-26 13:06:58 +00:00
|
|
|
* @return {this} This Light object.
|
2018-02-12 23:03:48 +00:00
|
|
|
*/
|
2018-02-12 22:16:27 +00:00
|
|
|
setColor: function (rgb)
|
|
|
|
{
|
|
|
|
var color = Utils.getFloatsFromUintRGB(rgb);
|
2018-06-08 14:40:28 +00:00
|
|
|
|
2020-12-02 17:56:53 +00:00
|
|
|
this.color.set(color[0], color[1], color[2]);
|
2020-07-16 02:26:32 +00:00
|
|
|
|
2018-02-12 22:16:27 +00:00
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-02-12 23:03:48 +00:00
|
|
|
/**
|
2018-06-08 14:40:28 +00:00
|
|
|
* Set the intensity of the light.
|
2018-02-12 23:03:48 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Light#setIntensity
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-08 14:40:28 +00:00
|
|
|
* @param {number} intensity - The intensity of the light.
|
2018-02-12 23:03:48 +00:00
|
|
|
*
|
2020-01-26 13:06:58 +00:00
|
|
|
* @return {this} This Light object.
|
2018-02-12 23:03:48 +00:00
|
|
|
*/
|
2018-02-12 22:16:27 +00:00
|
|
|
setIntensity: function (intensity)
|
|
|
|
{
|
2020-12-02 17:56:53 +00:00
|
|
|
this.intensity = intensity;
|
2020-07-16 02:26:32 +00:00
|
|
|
|
2018-02-12 22:16:27 +00:00
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-02-12 23:03:48 +00:00
|
|
|
/**
|
2018-06-08 14:40:28 +00:00
|
|
|
* Set the radius of the light.
|
2018-02-12 23:03:48 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Light#setRadius
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-08 14:40:28 +00:00
|
|
|
* @param {number} radius - The radius of the light.
|
2018-02-12 23:03:48 +00:00
|
|
|
*
|
2020-01-26 13:06:58 +00:00
|
|
|
* @return {this} This Light object.
|
2018-02-12 23:03:48 +00:00
|
|
|
*/
|
2018-02-12 22:16:27 +00:00
|
|
|
setRadius: function (radius)
|
|
|
|
{
|
2020-12-02 17:56:53 +00:00
|
|
|
this.radius = radius;
|
2020-07-16 02:26:32 +00:00
|
|
|
|
2018-02-12 22:16:27 +00:00
|
|
|
return this;
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
2020-12-02 17:56:53 +00:00
|
|
|
/**
|
|
|
|
* The bitmask that `GameObject.renderFlags` is compared against to determine if the Game Object will render or not.
|
|
|
|
*
|
|
|
|
* @constant {number} RENDER_MASK
|
|
|
|
* @memberof Phaser.GameObjects.Light
|
|
|
|
* @default
|
|
|
|
*/
|
|
|
|
Light.RENDER_MASK = 15;
|
|
|
|
|
2018-02-12 22:16:27 +00:00
|
|
|
module.exports = Light;
|