2017-10-11 16:05:59 +00:00
|
|
|
var CanvasPool = require('../display/canvas/CanvasPool');
|
2017-01-18 14:09:26 +00:00
|
|
|
|
|
|
|
var CanvasFeatures = {
|
|
|
|
|
|
|
|
supportNewBlendModes: false,
|
|
|
|
|
|
|
|
supportInverseAlpha: false
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
function checkBlendMode ()
|
|
|
|
{
|
|
|
|
var pngHead = '';
|
|
|
|
var pngEnd = 'AAAACklEQVQI12NgAAAAAgAB4iG8MwAAAABJRU5ErkJggg==';
|
|
|
|
|
|
|
|
var magenta = new Image();
|
|
|
|
|
2017-08-02 16:43:01 +00:00
|
|
|
magenta.onload = function ()
|
|
|
|
{
|
|
|
|
var yellow = new Image();
|
2017-01-18 14:09:26 +00:00
|
|
|
|
2017-08-02 16:43:01 +00:00
|
|
|
yellow.onload = function ()
|
|
|
|
{
|
|
|
|
var canvas = CanvasPool.create(yellow, 6, 1);
|
|
|
|
var context = canvas.getContext('2d');
|
2017-01-18 14:09:26 +00:00
|
|
|
|
2017-08-02 16:43:01 +00:00
|
|
|
context.globalCompositeOperation = 'multiply';
|
2017-01-18 14:09:26 +00:00
|
|
|
|
2017-08-02 16:43:01 +00:00
|
|
|
context.drawImage(magenta, 0, 0);
|
|
|
|
context.drawImage(yellow, 2, 0);
|
2017-01-18 14:09:26 +00:00
|
|
|
|
2017-08-02 16:43:01 +00:00
|
|
|
if (!context.getImageData(2, 0, 1, 1))
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
2017-01-18 14:09:26 +00:00
|
|
|
|
2017-08-02 16:43:01 +00:00
|
|
|
var data = context.getImageData(2, 0, 1, 1).data;
|
|
|
|
|
|
|
|
CanvasPool.remove(yellow);
|
|
|
|
|
|
|
|
CanvasFeatures.supportNewBlendModes = (data[0] === 255 && data[1] === 0 && data[2] === 0);
|
|
|
|
};
|
|
|
|
|
|
|
|
yellow.src = pngHead + '/wCKxvRF' + pngEnd;
|
|
|
|
};
|
|
|
|
|
|
|
|
magenta.src = pngHead + 'AP804Oa6' + pngEnd;
|
2017-01-18 14:09:26 +00:00
|
|
|
|
2017-08-02 16:43:01 +00:00
|
|
|
return false;
|
2017-01-18 14:09:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function checkInverseAlpha ()
|
|
|
|
{
|
|
|
|
var canvas = CanvasPool.create(this, 2, 1);
|
|
|
|
var context = canvas.getContext('2d');
|
|
|
|
|
|
|
|
context.fillStyle = 'rgba(10, 20, 30, 0.5)';
|
|
|
|
|
|
|
|
// Draw a single pixel
|
|
|
|
context.fillRect(0, 0, 1, 1);
|
|
|
|
|
|
|
|
// Get the color values
|
|
|
|
var s1 = context.getImageData(0, 0, 1, 1);
|
|
|
|
|
|
|
|
if (s1 === null)
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Plot them to x2
|
|
|
|
context.putImageData(s1, 1, 0);
|
|
|
|
|
|
|
|
// Get those values
|
|
|
|
var s2 = context.getImageData(1, 0, 1, 1);
|
|
|
|
|
|
|
|
// Compare and return
|
|
|
|
return (s2.data[0] === s1.data[0] && s2.data[1] === s1.data[1] && s2.data[2] === s1.data[2] && s2.data[3] === s1.data[3]);
|
|
|
|
}
|
|
|
|
|
|
|
|
function init ()
|
|
|
|
{
|
|
|
|
if (document !== undefined)
|
|
|
|
{
|
|
|
|
CanvasFeatures.supportNewBlendModes = checkBlendMode();
|
|
|
|
CanvasFeatures.supportInverseAlpha = checkInverseAlpha();
|
|
|
|
}
|
|
|
|
|
|
|
|
return CanvasFeatures;
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = init();
|