phaser/src/gameobjects/components/Pipeline.js

125 lines
3.3 KiB
JavaScript
Raw Normal View History

2018-02-12 16:01:20 +00:00
/**
* @author Richard Davey <rich@photonstorm.com>
2020-01-15 12:07:09 +00:00
* @copyright 2020 Photon Storm Ltd.
2019-05-10 15:15:04 +00:00
* @license {@link https://opensource.org/licenses/MIT|MIT License}
2018-02-12 16:01:20 +00:00
*/
2018-02-01 00:25:33 +00:00
/**
* Provides methods used for setting the WebGL rendering pipeline of a Game Object.
*
2019-02-12 12:48:41 +00:00
* @namespace Phaser.GameObjects.Components.Pipeline
2018-02-01 00:25:33 +00:00
* @webglOnly
* @since 3.0.0
*/
2018-01-29 21:46:48 +00:00
var Pipeline = {
2018-02-01 00:25:33 +00:00
/**
* The initial WebGL pipeline of this Game Object.
*
2018-02-01 00:25:33 +00:00
* @name Phaser.GameObjects.Components.Pipeline#defaultPipeline
* @type {Phaser.Renderer.WebGL.WebGLPipeline}
* @default null
* @webglOnly
* @since 3.0.0
*/
2018-01-29 21:46:48 +00:00
defaultPipeline: null,
2018-02-01 00:25:33 +00:00
/**
* The current WebGL pipeline of this Game Object.
*
2018-02-01 00:25:33 +00:00
* @name Phaser.GameObjects.Components.Pipeline#pipeline
* @type {Phaser.Renderer.WebGL.WebGLPipeline}
* @default null
* @webglOnly
* @since 3.0.0
*/
2018-01-29 21:46:48 +00:00
pipeline: null,
2018-02-01 00:25:33 +00:00
/**
* Sets the initial WebGL Pipeline of this Game Object.
2020-08-21 15:14:59 +00:00
*
2018-02-01 00:25:33 +00:00
* This should only be called during the instantiation of the Game Object.
*
2018-02-01 01:36:52 +00:00
* @method Phaser.GameObjects.Components.Pipeline#initPipeline
2018-02-01 00:25:33 +00:00
* @webglOnly
* @since 3.0.0
*
2020-08-21 15:14:59 +00:00
* @param {string} [pipelineName=MultiPipeline] - The name of the pipeline to set on this Game Object. Defaults to the Multi Pipeline.
*
2018-02-01 00:25:33 +00:00
* @return {boolean} `true` if the pipeline was set successfully, otherwise `false`.
*/
2018-01-29 21:46:48 +00:00
initPipeline: function (pipelineName)
{
2020-08-21 15:14:59 +00:00
if (pipelineName === undefined) { pipelineName = 'MultiPipeline'; }
2018-01-29 21:46:48 +00:00
var renderer = this.scene.sys.game.renderer;
if (renderer && renderer.gl && renderer.hasPipeline(pipelineName))
2018-01-29 21:46:48 +00:00
{
this.defaultPipeline = renderer.getPipeline(pipelineName);
this.pipeline = this.defaultPipeline;
2018-01-30 03:38:31 +00:00
return true;
2018-01-29 21:46:48 +00:00
}
2018-01-30 03:38:31 +00:00
return false;
2018-01-29 21:46:48 +00:00
},
2018-02-01 00:25:33 +00:00
/**
* Sets the active WebGL Pipeline of this Game Object.
*
2018-02-01 01:36:52 +00:00
* @method Phaser.GameObjects.Components.Pipeline#setPipeline
2018-02-01 00:25:33 +00:00
* @webglOnly
* @since 3.0.0
*
* @param {string} pipelineName - The name of the pipeline to set on this Game Object.
*
* @return {this} This Game Object instance.
2018-02-01 00:25:33 +00:00
*/
2018-01-29 21:46:48 +00:00
setPipeline: function (pipelineName)
{
var renderer = this.scene.sys.game.renderer;
if (renderer && renderer.gl && renderer.hasPipeline(pipelineName))
2018-01-29 21:46:48 +00:00
{
this.pipeline = renderer.getPipeline(pipelineName);
}
return this;
2018-01-29 21:46:48 +00:00
},
2018-02-01 00:25:33 +00:00
/**
* Resets the WebGL Pipeline of this Game Object back to the default it was created with.
*
2018-02-01 01:36:52 +00:00
* @method Phaser.GameObjects.Components.Pipeline#resetPipeline
2018-02-01 00:25:33 +00:00
* @webglOnly
* @since 3.0.0
*
* @return {boolean} `true` if the pipeline was set successfully, otherwise `false`.
*/
2018-01-29 21:46:48 +00:00
resetPipeline: function ()
{
this.pipeline = this.defaultPipeline;
2018-01-30 03:38:31 +00:00
return (this.pipeline !== null);
2018-01-30 22:46:43 +00:00
},
2018-02-01 00:25:33 +00:00
/**
* Gets the name of the WebGL Pipeline this Game Object is currently using.
*
2018-02-01 01:36:52 +00:00
* @method Phaser.GameObjects.Components.Pipeline#getPipelineName
2018-02-01 00:25:33 +00:00
* @webglOnly
* @since 3.0.0
*
* @return {string} The string-based name of the pipeline being used by this Game Object.
*/
2018-01-30 22:46:43 +00:00
getPipelineName: function ()
{
return this.pipeline.name;
2018-01-29 21:46:48 +00:00
}
};
module.exports = Pipeline;