phaser/src/core/CreateRenderer.js

139 lines
3.9 KiB
JavaScript
Raw Normal View History

2018-02-12 16:01:20 +00:00
/**
* @author Richard Davey <rich@phaser.io>
* @copyright 2013-2024 Phaser Studio Inc.
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-01-25 00:48:48 +00:00
var CanvasInterpolation = require('../display/canvas/CanvasInterpolation');
2017-10-11 16:05:59 +00:00
var CanvasPool = require('../display/canvas/CanvasPool');
2018-01-25 00:48:48 +00:00
var CONST = require('../const');
2016-11-29 11:26:30 +00:00
var Features = require('../device/Features');
2017-10-04 22:48:16 +00:00
/**
2018-01-25 00:48:48 +00:00
* Called automatically by Phaser.Game and responsible for creating the renderer it will use.
*
* Relies upon two webpack global flags to be defined: `WEBGL_RENDERER` and `CANVAS_RENDERER` during build time, but not at run-time.
2017-10-04 22:48:16 +00:00
*
* @function Phaser.Core.CreateRenderer
2017-10-04 22:48:16 +00:00
* @since 3.0.0
*
2018-01-25 00:48:48 +00:00
* @param {Phaser.Game} game - The Phaser.Game instance on which the renderer will be set.
2017-10-04 22:48:16 +00:00
*/
2016-11-29 11:26:30 +00:00
var CreateRenderer = function (game)
{
var config = game.config;
2018-11-28 15:47:06 +00:00
if ((config.customEnvironment || config.canvas) && config.renderType === CONST.AUTO)
{
throw new Error('Must set explicit renderType in custom environment');
}
2018-11-28 15:47:06 +00:00
// Not a custom environment, didn't provide their own canvas and not headless, so determine the renderer:
if (!config.customEnvironment && !config.canvas && config.renderType !== CONST.HEADLESS)
2016-11-29 11:26:30 +00:00
{
if (config.renderType === CONST.AUTO)
2016-11-29 11:26:30 +00:00
{
config.renderType = Features.webGL ? CONST.WEBGL : CONST.CANVAS;
}
if (config.renderType === CONST.WEBGL)
{
if (!Features.webGL) { throw new Error('Cannot create WebGL context, aborting.'); }
}
else if (config.renderType === CONST.CANVAS)
{
if (!Features.canvas) { throw new Error('Cannot create Canvas context, aborting.'); }
2016-11-29 11:26:30 +00:00
}
else
{
throw new Error('Unknown value for renderer type: ' + config.renderType);
2016-11-29 11:26:30 +00:00
}
}
// Pixel Art mode?
2018-06-27 14:27:16 +00:00
if (!config.antialias)
{
CanvasPool.disableSmoothing();
}
2019-01-10 13:40:41 +00:00
var baseSize = game.scale.baseSize;
2019-01-22 16:28:54 +00:00
var width = baseSize.width;
var height = baseSize.height;
2016-11-29 11:26:30 +00:00
// Does the game config provide its own canvas element to use?
if (config.canvas)
{
game.canvas = config.canvas;
2018-10-11 16:01:38 +00:00
2019-01-22 16:28:54 +00:00
game.canvas.width = width;
game.canvas.height = height;
2016-11-29 11:26:30 +00:00
}
else
{
2019-01-22 16:28:54 +00:00
game.canvas = CanvasPool.create(game, width, height, config.renderType);
2016-11-29 11:26:30 +00:00
}
// Does the game config provide some canvas css styles to use?
if (config.canvasStyle)
{
game.canvas.style = config.canvasStyle;
}
// Pixel Art mode?
2018-06-27 14:27:16 +00:00
if (!config.antialias)
{
CanvasInterpolation.setCrisp(game.canvas);
}
if (config.renderType === CONST.HEADLESS)
{
// Nothing more to do here
return;
}
var CanvasRenderer;
var WebGLRenderer;
if (typeof WEBGL_RENDERER && typeof CANVAS_RENDERER)
{
CanvasRenderer = require('../renderer/canvas/CanvasRenderer');
WebGLRenderer = require('../renderer/webgl/WebGLRenderer');
// Let the config pick the renderer type, as both are included
if (config.renderType === CONST.WEBGL)
{
game.renderer = new WebGLRenderer(game);
}
else
{
game.renderer = new CanvasRenderer(game);
game.context = game.renderer.gameContext;
}
}
if (typeof WEBGL_RENDERER && !typeof CANVAS_RENDERER)
2016-11-29 11:26:30 +00:00
{
WebGLRenderer = require('../renderer/webgl/WebGLRenderer');
// Force the type to WebGL, regardless what was requested
config.renderType = CONST.WEBGL;
2016-12-07 02:28:22 +00:00
game.renderer = new WebGLRenderer(game);
2016-11-29 11:26:30 +00:00
}
if (!typeof WEBGL_RENDERER && typeof CANVAS_RENDERER)
2016-11-29 11:26:30 +00:00
{
CanvasRenderer = require('../renderer/canvas/CanvasRenderer');
// Force the type to Canvas, regardless what was requested
config.renderType = CONST.CANVAS;
2017-01-12 17:11:58 +00:00
game.renderer = new CanvasRenderer(game);
game.context = game.renderer.gameContext;
2016-11-29 11:26:30 +00:00
}
};
module.exports = CreateRenderer;