2020-10-13 17:17:30 +00:00
|
|
|
/**
|
|
|
|
* @author Richard Davey <rich@photonstorm.com>
|
2022-02-28 14:29:51 +00:00
|
|
|
* @copyright 2022 Photon Storm Ltd.
|
2020-10-13 17:17:30 +00:00
|
|
|
* @license {@link https://opensource.org/licenses/MIT|MIT License}
|
|
|
|
*/
|
|
|
|
|
|
|
|
var Class = require('../../utils/Class');
|
|
|
|
var Components = require('../components');
|
|
|
|
var GameObject = require('../GameObject');
|
2020-12-11 15:56:21 +00:00
|
|
|
var IntegerToColor = require('../../display/color/IntegerToColor');
|
2020-12-02 13:48:38 +00:00
|
|
|
var PIPELINES_CONST = require('../../renderer/webgl/pipelines/const');
|
|
|
|
var Render = require('./PointLightRender');
|
2020-10-13 17:17:30 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @classdesc
|
2020-12-14 14:07:57 +00:00
|
|
|
* The Point Light Game Object provides a way to add a point light effect into your game,
|
|
|
|
* without the expensive shader processing requirements of the traditional Light Game Object.
|
|
|
|
*
|
|
|
|
* The difference is that the Point Light renders using a custom shader, designed to give the
|
|
|
|
* impression of a point light source, of variable radius, intensity and color, in your game.
|
|
|
|
* However, unlike the Light Game Object, it does not impact any other Game Objects, or use their
|
|
|
|
* normal maps for calcuations. This makes them extremely fast to render compared to Lights
|
|
|
|
* and perfect for special effects, such as flickering torches or muzzle flashes.
|
|
|
|
*
|
|
|
|
* For maximum performance you should batch Point Light Game Objects together. This means
|
|
|
|
* ensuring they follow each other consecutively on the display list. Ideally, use a Layer
|
|
|
|
* Game Object and then add just Point Lights to it, so that it can batch together the rendering
|
|
|
|
* of the lights. You don't _have_ to do this, and if you've only a handful of Point Lights in
|
|
|
|
* your game then it's perfectly safe to mix them into the dislay list as normal. However, if
|
|
|
|
* you're using a large number of them, please consider how they are mixed into the display list.
|
|
|
|
*
|
|
|
|
* The renderer will automatically cull Point Lights. Those with a radius that does not intersect
|
|
|
|
* with the Camera will be skipped in the rendering list. This happens automatically and the
|
|
|
|
* culled state is refreshed every frame, for every camera.
|
|
|
|
*
|
|
|
|
* The origin of a Point Light is always 0.5 and it cannot be changed.
|
|
|
|
*
|
|
|
|
* Point Lights are a WebGL only feature and do not have a Canvas counterpart.
|
2020-10-13 17:17:30 +00:00
|
|
|
*
|
|
|
|
* @class PointLight
|
|
|
|
* @extends Phaser.GameObjects.GameObject
|
|
|
|
* @memberof Phaser.GameObjects
|
|
|
|
* @constructor
|
|
|
|
* @since 3.50.0
|
|
|
|
*
|
|
|
|
* @extends Phaser.GameObjects.Components.AlphaSingle
|
|
|
|
* @extends Phaser.GameObjects.Components.BlendMode
|
|
|
|
* @extends Phaser.GameObjects.Components.Depth
|
|
|
|
* @extends Phaser.GameObjects.Components.GetBounds
|
|
|
|
* @extends Phaser.GameObjects.Components.Mask
|
|
|
|
* @extends Phaser.GameObjects.Components.Pipeline
|
|
|
|
* @extends Phaser.GameObjects.Components.ScrollFactor
|
|
|
|
* @extends Phaser.GameObjects.Components.Transform
|
|
|
|
* @extends Phaser.GameObjects.Components.Visible
|
|
|
|
*
|
2020-12-14 14:07:57 +00:00
|
|
|
* @param {Phaser.Scene} scene - The Scene to which this Point Light belongs. A Point Light can only belong to one Scene at a time.
|
|
|
|
* @param {number} x - The horizontal position of this Point Light in the world.
|
|
|
|
* @param {number} y - The vertical position of this Point Light in the world.
|
|
|
|
* @param {number} [color=0xffffff] - The color of the Point Light, given as a hex value.
|
|
|
|
* @param {number} [radius=128] - The radius of the Point Light.
|
2021-09-03 11:35:32 +00:00
|
|
|
* @param {number} [intensity=1] - The intensity, or color blend, of the Point Light.
|
2020-12-14 14:07:57 +00:00
|
|
|
* @param {number} [attenuation=0.1] - The attenuation of the Point Light. This is the reduction of light from the center point.
|
2020-10-13 17:17:30 +00:00
|
|
|
*/
|
|
|
|
var PointLight = new Class({
|
|
|
|
|
|
|
|
Extends: GameObject,
|
|
|
|
|
|
|
|
Mixins: [
|
|
|
|
Components.AlphaSingle,
|
|
|
|
Components.BlendMode,
|
|
|
|
Components.Depth,
|
|
|
|
Components.Mask,
|
|
|
|
Components.Pipeline,
|
|
|
|
Components.ScrollFactor,
|
|
|
|
Components.Transform,
|
2020-12-02 13:48:38 +00:00
|
|
|
Components.Visible,
|
|
|
|
Render
|
2020-10-13 17:17:30 +00:00
|
|
|
],
|
|
|
|
|
|
|
|
initialize:
|
|
|
|
|
2020-12-03 12:52:36 +00:00
|
|
|
function PointLight (scene, x, y, color, radius, intensity, attenuation)
|
2020-10-13 17:17:30 +00:00
|
|
|
{
|
|
|
|
if (color === undefined) { color = 0xffffff; }
|
|
|
|
if (radius === undefined) { radius = 128; }
|
2020-12-01 17:23:42 +00:00
|
|
|
if (intensity === undefined) { intensity = 1; }
|
2020-12-03 12:52:36 +00:00
|
|
|
if (attenuation === undefined) { attenuation = 0.1; }
|
2020-10-13 17:17:30 +00:00
|
|
|
|
|
|
|
GameObject.call(this, scene, 'PointLight');
|
|
|
|
|
2020-12-02 13:48:38 +00:00
|
|
|
this.initPipeline(PIPELINES_CONST.POINTLIGHT_PIPELINE);
|
2020-10-13 17:17:30 +00:00
|
|
|
|
|
|
|
this.setPosition(x, y);
|
|
|
|
|
2020-12-14 14:07:57 +00:00
|
|
|
/**
|
|
|
|
* The color of this Point Light. This property is an instance of a
|
|
|
|
* Color object, so you can use the methods within it, such as `setTo(r, g, b)`
|
|
|
|
* to change the color value.
|
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.PointLight#color
|
|
|
|
* @type {Phaser.Display.Color}
|
|
|
|
* @since 3.50.0
|
|
|
|
*/
|
2020-12-11 15:56:21 +00:00
|
|
|
this.color = IntegerToColor(color);
|
2020-10-13 17:17:30 +00:00
|
|
|
|
2020-12-14 14:07:57 +00:00
|
|
|
/**
|
|
|
|
* The intensity of the Point Light.
|
|
|
|
*
|
|
|
|
* The colors of the light are multiplied by this value during rendering.
|
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.PointLight#intensity
|
|
|
|
* @type {number}
|
|
|
|
* @since 3.50.0
|
|
|
|
*/
|
2020-10-13 17:17:30 +00:00
|
|
|
this.intensity = intensity;
|
2020-12-14 14:07:57 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The attenuation of the Point Light.
|
|
|
|
*
|
|
|
|
* This value controls the force with which the light falls-off from the center of the light.
|
|
|
|
*
|
|
|
|
* Use small float-based values, i.e. 0.1.
|
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.PointLight#attenuation
|
|
|
|
* @type {number}
|
|
|
|
* @since 3.50.0
|
|
|
|
*/
|
2020-12-03 12:52:36 +00:00
|
|
|
this.attenuation = attenuation;
|
2020-10-13 17:17:30 +00:00
|
|
|
|
|
|
|
// read only:
|
2020-12-02 13:48:38 +00:00
|
|
|
this.width = radius * 2;
|
|
|
|
this.height = radius * 2;
|
2020-10-13 17:17:30 +00:00
|
|
|
|
2020-12-02 13:48:38 +00:00
|
|
|
this._radius = radius;
|
2020-10-13 17:17:30 +00:00
|
|
|
},
|
|
|
|
|
2020-12-14 14:07:57 +00:00
|
|
|
/**
|
|
|
|
* The radius of the Point Light.
|
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.PointLight#radius
|
|
|
|
* @type {number}
|
|
|
|
* @since 3.50.0
|
|
|
|
*/
|
2020-12-02 13:48:38 +00:00
|
|
|
radius: {
|
2020-10-13 17:17:30 +00:00
|
|
|
|
|
|
|
get: function ()
|
|
|
|
{
|
2020-12-02 13:48:38 +00:00
|
|
|
return this._radius;
|
2020-10-13 17:17:30 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
set: function (value)
|
|
|
|
{
|
2020-12-02 13:48:38 +00:00
|
|
|
this._radius = value;
|
2020-10-13 17:17:30 +00:00
|
|
|
this.width = value * 2;
|
|
|
|
this.height = value * 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
originX: {
|
|
|
|
|
|
|
|
get: function ()
|
|
|
|
{
|
|
|
|
return 0.5;
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
originY: {
|
|
|
|
|
|
|
|
get: function ()
|
|
|
|
{
|
|
|
|
return 0.5;
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
displayOriginX: {
|
|
|
|
|
|
|
|
get: function ()
|
|
|
|
{
|
|
|
|
return this._radius;
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
displayOriginY: {
|
|
|
|
|
|
|
|
get: function ()
|
|
|
|
{
|
|
|
|
return this._radius;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
|
|
|
module.exports = PointLight;
|