phaser/src/renderer/snapshot/WebGLSnapshot.js

93 lines
3 KiB
JavaScript
Raw Normal View History

2018-02-12 16:01:20 +00:00
/**
* @author Richard Davey <rich@photonstorm.com>
2019-01-15 16:20:22 +00:00
* @copyright 2019 Photon Storm Ltd.
2018-02-12 16:01:20 +00:00
* @license {@link https://github.com/photonstorm/phaser/blob/master/license.txt|MIT License}
*/
var CanvasPool = require('../../display/canvas/CanvasPool');
var Color = require('../../display/color/Color');
2019-01-25 10:01:53 +00:00
var GetFastValue = require('../../utils/object/GetFastValue');
2018-02-09 13:46:04 +00:00
/**
* Takes a snapshot of an area from the current frame displayed by a WebGL canvas.
2018-02-09 13:46:04 +00:00
*
* @function Phaser.Renderer.Snapshot.WebGL
* @since 3.0.0
*
* @param {HTMLCanvasElement} sourceCanvas - The canvas to take a snapshot of.
* @param {SnapshotState} config - The snapshot configuration object.
2018-02-09 13:46:04 +00:00
*
* @return {(Phaser.Display.Color|HTMLImageElement)} Either a Color object if a single pixel is being grabbed, or a new Image which contains a snapshot of the canvas contents.
2018-02-09 13:46:04 +00:00
*/
var WebGLSnapshot = function (sourceCanvas, config)
2017-05-16 19:15:01 +00:00
{
var gl = sourceCanvas.getContext('experimental-webgl');
2017-05-16 19:15:01 +00:00
var callback = GetFastValue(config, 'callback');
var type = GetFastValue(config, 'type', 'image/png');
var encoderOptions = GetFastValue(config, 'encoder', 0.92);
var x = GetFastValue(config, 'x', 0);
var y = GetFastValue(config, 'y', 0);
var width = GetFastValue(config, 'width', gl.drawingBufferWidth);
var height = GetFastValue(config, 'height', gl.drawingBufferHeight);
var getPixel = GetFastValue(config, 'getPixel', false);
2019-01-25 10:01:53 +00:00
if (getPixel)
{
var pixel = new Uint8Array(4);
2019-01-25 10:01:53 +00:00
gl.readPixels(x, gl.drawingBufferHeight - y, 1, 1, gl.RGBA, gl.UNSIGNED_BYTE, pixel);
callback.call(null, new Color(pixel[0], pixel[1], pixel[2], pixel[3] / 255));
2019-01-25 10:01:53 +00:00
}
else
2017-05-16 19:15:01 +00:00
{
var pixels = new Uint8Array(width * height * 4);
2019-01-25 10:01:53 +00:00
gl.readPixels(x, gl.drawingBufferHeight - y - height, width, height, gl.RGBA, gl.UNSIGNED_BYTE, pixels);
2019-01-25 10:01:53 +00:00
var canvas = CanvasPool.createWebGL(this, width, height);
2019-01-25 10:01:53 +00:00
var ctx = canvas.getContext('2d');
var imageData = ctx.getImageData(0, 0, width, height);
2019-01-25 10:01:53 +00:00
var data = imageData.data;
for (var py = 0; py < height; py++)
2017-05-16 19:15:01 +00:00
{
for (var px = 0; px < width; px++)
2019-01-25 10:01:53 +00:00
{
var sourceIndex = ((height - py) * width + px) * 4;
var destIndex = (py * width + px) * 4;
data[destIndex + 0] = pixels[sourceIndex + 0];
data[destIndex + 1] = pixels[sourceIndex + 1];
data[destIndex + 2] = pixels[sourceIndex + 2];
data[destIndex + 3] = pixels[sourceIndex + 3];
2019-01-25 10:01:53 +00:00
}
2017-05-16 19:15:01 +00:00
}
2019-01-25 10:01:53 +00:00
ctx.putImageData(imageData, 0, 0);
var image = new Image();
image.onerror = function ()
{
callback.call(null);
CanvasPool.remove(canvas);
};
image.onload = function ()
{
callback.call(null, image);
CanvasPool.remove(canvas);
};
image.src = canvas.toDataURL(type, encoderOptions);
2017-05-16 19:15:01 +00:00
}
};
module.exports = WebGLSnapshot;