phaser/src/gameobjects/container/ContainerCanvasRenderer.js

73 lines
2.6 KiB
JavaScript
Raw Normal View History

/**
* @author Richard Davey <rich@photonstorm.com>
* @author Felipe Alfonso <@bitnenfer>
* @copyright 2018 Photon Storm Ltd.
* @license {@link https://github.com/photonstorm/phaser/blob/master/license.txt|MIT License}
*/
/**
* Renders this Game Object with the Canvas Renderer to the given Camera.
* The object will not render if any of its renderFlags are set or it is being actively filtered out by the Camera.
* This method should not be called directly. It is a utility function of the Render module.
*
* @method Phaser.GameObjects.Container#renderCanvas
* @since 3.4.0
* @private
*
* @param {Phaser.Renderer.Canvas.CanvasRenderer} renderer - A reference to the current active Canvas renderer.
* @param {Phaser.GameObjects.Container} container - The Game Object being rendered in this call.
* @param {number} interpolationPercentage - Reserved for future use and custom pipelines.
* @param {Phaser.Cameras.Scene2D.Camera} camera - The Camera that is rendering the Game Object.
* @param {Phaser.GameObjects.Components.TransformMatrix} parentMatrix - This transform matrix is defined if the game object is nested
*/
2018-04-04 15:22:10 +00:00
var ContainerCanvasRenderer = function (renderer, container, interpolationPercentage, camera, parentMatrix)
{
var children = container.list;
if (children.length === 0)
{
return;
}
2018-04-04 15:22:10 +00:00
var transformMatrix = container.localTransform;
2018-08-02 15:19:14 +00:00
if (parentMatrix)
2018-04-04 15:22:10 +00:00
{
transformMatrix.loadIdentity();
transformMatrix.multiply(parentMatrix);
transformMatrix.translate(container.x, container.y);
transformMatrix.rotate(container.rotation);
2018-04-04 15:22:10 +00:00
transformMatrix.scale(container.scaleX, container.scaleY);
}
2018-08-02 15:19:14 +00:00
else
{
transformMatrix.applyITRS(container.x, container.y, container.rotation, container.scaleX, container.scaleY);
}
2018-04-04 15:22:10 +00:00
2018-04-09 15:32:08 +00:00
var alpha = container._alpha;
var scrollFactorX = container.scrollFactorX;
var scrollFactorY = container.scrollFactorY;
2018-04-09 15:32:08 +00:00
for (var i = 0; i < children.length; i++)
2018-04-04 15:22:10 +00:00
{
var child = children[i];
if (!child.willRender(camera))
{
continue;
}
2018-04-09 15:32:08 +00:00
var childAlpha = child._alpha;
var childScrollFactorX = child.scrollFactorX;
var childScrollFactorY = child.scrollFactorY;
child.setScrollFactor(childScrollFactorX * scrollFactorX, childScrollFactorY * scrollFactorY);
2018-04-09 15:32:08 +00:00
child.setAlpha(childAlpha * alpha);
child.renderCanvas(renderer, child, interpolationPercentage, camera, transformMatrix);
child.setAlpha(childAlpha);
child.setScrollFactor(childScrollFactorX, childScrollFactorY);
2018-04-04 15:22:10 +00:00
}
};
2018-04-05 08:02:36 +00:00
module.exports = ContainerCanvasRenderer;