2013-11-13 20:57:09 +00:00
|
|
|
/**
|
|
|
|
* @author Richard Davey <rich@photonstorm.com>
|
2014-02-05 05:54:25 +00:00
|
|
|
* @copyright 2014 Photon Storm Ltd.
|
2013-11-13 20:57:09 +00:00
|
|
|
* @license {@link https://github.com/photonstorm/phaser/blob/master/license.txt|MIT License}
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
2014-09-16 16:35:08 +00:00
|
|
|
* A BitmapData object contains a Canvas element to which you can draw anything you like via normal Canvas context operations.
|
|
|
|
* A single BitmapData can be used as the texture for one or many Images/Sprites.
|
|
|
|
* So if you need to dynamically create a Sprite texture then they are a good choice.
|
2013-11-13 20:57:09 +00:00
|
|
|
*
|
|
|
|
* @class Phaser.BitmapData
|
|
|
|
* @constructor
|
|
|
|
* @param {Phaser.Game} game - A reference to the currently running game.
|
2014-02-07 06:25:28 +00:00
|
|
|
* @param {string} key - Internal Phaser reference key for the render texture.
|
2014-09-03 11:53:07 +00:00
|
|
|
* @param {number} [width=256] - The width of the BitmapData in pixels.
|
|
|
|
* @param {number} [height=256] - The height of the BitmapData in pixels.
|
2013-11-13 20:57:09 +00:00
|
|
|
*/
|
2014-02-07 06:25:28 +00:00
|
|
|
Phaser.BitmapData = function (game, key, width, height) {
|
2013-11-13 20:57:09 +00:00
|
|
|
|
2014-09-03 11:53:07 +00:00
|
|
|
if (typeof width === 'undefined') { width = 256; }
|
|
|
|
if (typeof height === 'undefined') { height = 256; }
|
2013-11-13 20:57:09 +00:00
|
|
|
|
2013-11-25 03:13:04 +00:00
|
|
|
/**
|
2014-03-23 07:59:28 +00:00
|
|
|
* @property {Phaser.Game} game - A reference to the currently running game.
|
2013-11-25 03:13:04 +00:00
|
|
|
*/
|
|
|
|
this.game = game;
|
2013-11-13 20:57:09 +00:00
|
|
|
|
2013-11-25 03:13:04 +00:00
|
|
|
/**
|
2014-02-07 06:25:28 +00:00
|
|
|
* @property {string} key - The key of the BitmapData in the Cache, if stored there.
|
2013-11-25 03:13:04 +00:00
|
|
|
*/
|
2014-02-07 06:25:28 +00:00
|
|
|
this.key = key;
|
2013-11-13 20:57:09 +00:00
|
|
|
|
2013-11-25 03:13:04 +00:00
|
|
|
/**
|
|
|
|
* @property {number} width - The width of the BitmapData in pixels.
|
2013-11-13 20:57:09 +00:00
|
|
|
*/
|
2013-11-25 03:13:04 +00:00
|
|
|
this.width = width;
|
2014-03-23 07:59:28 +00:00
|
|
|
|
2013-11-25 03:13:04 +00:00
|
|
|
/**
|
|
|
|
* @property {number} height - The height of the BitmapData in pixels.
|
2013-11-13 20:57:09 +00:00
|
|
|
*/
|
2013-11-25 03:13:04 +00:00
|
|
|
this.height = height;
|
2013-11-13 20:57:09 +00:00
|
|
|
|
2013-11-25 03:13:04 +00:00
|
|
|
/**
|
|
|
|
* @property {HTMLCanvasElement} canvas - The canvas to which this BitmapData draws.
|
|
|
|
* @default
|
|
|
|
*/
|
2014-02-28 03:55:06 +00:00
|
|
|
this.canvas = Phaser.Canvas.create(width, height, '', true);
|
2014-03-23 07:59:28 +00:00
|
|
|
|
2013-11-25 03:13:04 +00:00
|
|
|
/**
|
|
|
|
* @property {CanvasRenderingContext2D} context - The 2d context of the canvas.
|
|
|
|
* @default
|
|
|
|
*/
|
2013-11-13 20:57:09 +00:00
|
|
|
this.context = this.canvas.getContext('2d');
|
2013-11-15 20:40:39 +00:00
|
|
|
|
2014-02-13 14:19:41 +00:00
|
|
|
/**
|
|
|
|
* @property {CanvasRenderingContext2D} ctx - A reference to BitmapData.context.
|
|
|
|
*/
|
|
|
|
this.ctx = this.context;
|
|
|
|
|
2013-11-25 03:13:04 +00:00
|
|
|
/**
|
2014-04-24 02:49:49 +00:00
|
|
|
* @property {ImageData} imageData - The context image data.
|
2013-11-25 03:13:04 +00:00
|
|
|
*/
|
|
|
|
this.imageData = this.context.getImageData(0, 0, width, height);
|
|
|
|
|
2014-04-29 14:38:33 +00:00
|
|
|
/**
|
|
|
|
* @property {Uint8ClampedArray} data - A Uint8ClampedArray view into BitmapData.buffer.
|
|
|
|
*/
|
|
|
|
this.data = this.imageData.data;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @property {Uint32Array} pixels - An Uint32Array view into BitmapData.buffer.
|
|
|
|
*/
|
|
|
|
this.pixels = null;
|
|
|
|
|
2013-11-25 03:13:04 +00:00
|
|
|
/**
|
2014-04-24 02:49:49 +00:00
|
|
|
* @property {ArrayBuffer} buffer - An ArrayBuffer the same size as the context ImageData.
|
2013-11-25 03:13:04 +00:00
|
|
|
*/
|
|
|
|
if (this.imageData.data.buffer)
|
|
|
|
{
|
2014-04-24 02:49:49 +00:00
|
|
|
this.buffer = this.imageData.data.buffer;
|
2014-04-29 14:38:33 +00:00
|
|
|
this.pixels = new Uint32Array(this.buffer);
|
2013-11-25 03:13:04 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2014-04-29 14:38:33 +00:00
|
|
|
if (window['ArrayBuffer'])
|
|
|
|
{
|
|
|
|
this.buffer = new ArrayBuffer(this.imageData.data.length);
|
|
|
|
this.pixels = new Uint32Array(this.buffer);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
this.pixels = this.imageData.data;
|
|
|
|
}
|
2013-11-25 03:13:04 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @property {PIXI.BaseTexture} baseTexture - The PIXI.BaseTexture.
|
|
|
|
* @default
|
|
|
|
*/
|
2013-11-13 20:57:09 +00:00
|
|
|
this.baseTexture = new PIXI.BaseTexture(this.canvas);
|
2014-03-23 07:59:28 +00:00
|
|
|
|
2013-11-25 03:13:04 +00:00
|
|
|
/**
|
|
|
|
* @property {PIXI.Texture} texture - The PIXI.Texture.
|
|
|
|
* @default
|
|
|
|
*/
|
2013-11-13 20:57:09 +00:00
|
|
|
this.texture = new PIXI.Texture(this.baseTexture);
|
2014-03-23 07:59:28 +00:00
|
|
|
|
2013-11-25 03:13:04 +00:00
|
|
|
/**
|
|
|
|
* @property {Phaser.Frame} textureFrame - The Frame this BitmapData uses for rendering.
|
|
|
|
* @default
|
|
|
|
*/
|
2013-11-13 20:57:09 +00:00
|
|
|
this.textureFrame = new Phaser.Frame(0, 0, 0, width, height, 'bitmapData', game.rnd.uuid());
|
|
|
|
|
2014-05-24 01:02:49 +00:00
|
|
|
this.texture.frame = this.textureFrame;
|
|
|
|
|
2013-11-13 20:57:09 +00:00
|
|
|
/**
|
2013-11-25 03:13:04 +00:00
|
|
|
* @property {number} type - The const type of this object.
|
2013-11-13 20:57:09 +00:00
|
|
|
* @default
|
2013-11-25 03:13:04 +00:00
|
|
|
*/
|
2013-11-13 20:57:09 +00:00
|
|
|
this.type = Phaser.BITMAPDATA;
|
|
|
|
|
2014-04-24 02:49:49 +00:00
|
|
|
/**
|
|
|
|
* @property {boolean} disableTextureUpload - If disableTextureUpload is true this BitmapData will never send its image data to the GPU when its dirty flag is true.
|
|
|
|
*/
|
|
|
|
this.disableTextureUpload = false;
|
|
|
|
|
2014-03-21 18:04:24 +00:00
|
|
|
/**
|
|
|
|
* @property {boolean} dirty - If dirty this BitmapData will be re-rendered.
|
|
|
|
*/
|
|
|
|
this.dirty = false;
|
2013-11-17 00:55:28 +00:00
|
|
|
|
2014-04-24 02:49:49 +00:00
|
|
|
// Aliases
|
2014-04-23 22:35:36 +00:00
|
|
|
this.cls = this.clear;
|
|
|
|
|
2014-09-03 11:53:07 +00:00
|
|
|
/**
|
|
|
|
* @property {number} _image - Internal cache var.
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
this._image = null;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @property {Phaser.Point} _pos - Internal cache var.
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
this._pos = new Phaser.Point();
|
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
/**
|
|
|
|
* @property {Phaser.Point} _size - Internal cache var.
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
this._size = new Phaser.Point();
|
|
|
|
|
2014-09-03 11:53:07 +00:00
|
|
|
/**
|
|
|
|
* @property {Phaser.Point} _scale - Internal cache var.
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
this._scale = new Phaser.Point();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @property {number} _rotate - Internal cache var.
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
this._rotate = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @property {Object} _alpha - Internal cache var.
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
this._alpha = { prev: 1, current: 1 };
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @property {Phaser.Point} _anchor - Internal cache var.
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
this._anchor = new Phaser.Point();
|
|
|
|
|
2014-04-25 01:45:27 +00:00
|
|
|
/**
|
|
|
|
* @property {number} _tempR - Internal cache var.
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
this._tempR = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @property {number} _tempG - Internal cache var.
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
this._tempG = 0;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @property {number} _tempB - Internal cache var.
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
this._tempB = 0;
|
|
|
|
|
2014-10-03 01:21:09 +00:00
|
|
|
/**
|
|
|
|
* @property {Phaser.Circle} _circle - Internal cache var.
|
|
|
|
* @private
|
|
|
|
*/
|
|
|
|
this._circle = new Phaser.Circle();
|
|
|
|
|
2014-03-23 08:40:24 +00:00
|
|
|
};
|
2013-11-13 20:57:09 +00:00
|
|
|
|
|
|
|
Phaser.BitmapData.prototype = {
|
|
|
|
|
2013-11-25 03:13:04 +00:00
|
|
|
/**
|
2014-02-21 14:50:18 +00:00
|
|
|
* Updates the given objects so that they use this BitmapData as their texture. This will replace any texture they will currently have set.
|
2014-03-23 07:59:28 +00:00
|
|
|
*
|
2013-11-28 15:57:09 +00:00
|
|
|
* @method Phaser.BitmapData#add
|
2014-02-13 14:19:41 +00:00
|
|
|
* @param {Phaser.Sprite|Phaser.Sprite[]|Phaser.Image|Phaser.Image[]} object - Either a single Sprite/Image or an Array of Sprites/Images.
|
2014-09-03 10:12:06 +00:00
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
2013-11-25 03:13:04 +00:00
|
|
|
*/
|
2014-02-13 14:19:41 +00:00
|
|
|
add: function (object) {
|
2013-11-25 03:13:04 +00:00
|
|
|
|
2014-02-13 14:19:41 +00:00
|
|
|
if (Array.isArray(object))
|
2013-11-25 03:13:04 +00:00
|
|
|
{
|
2014-02-13 14:19:41 +00:00
|
|
|
for (var i = 0; i < object.length; i++)
|
2013-11-25 03:13:04 +00:00
|
|
|
{
|
2014-02-13 14:19:41 +00:00
|
|
|
if (object[i]['loadTexture'])
|
|
|
|
{
|
|
|
|
object[i].loadTexture(this);
|
|
|
|
}
|
2013-11-25 03:13:04 +00:00
|
|
|
}
|
|
|
|
}
|
2014-02-13 14:19:41 +00:00
|
|
|
else
|
|
|
|
{
|
|
|
|
object.loadTexture(this);
|
|
|
|
}
|
2013-11-25 03:13:04 +00:00
|
|
|
|
2014-09-03 10:12:06 +00:00
|
|
|
return this;
|
|
|
|
|
2013-11-25 03:13:04 +00:00
|
|
|
},
|
|
|
|
|
2014-05-24 00:29:47 +00:00
|
|
|
/**
|
|
|
|
* Takes the given Game Object, resizes this BitmapData to match it and then draws it into this BitmapDatas canvas, ready for further processing.
|
|
|
|
* The source game object is not modified by this operation.
|
2014-09-04 04:05:30 +00:00
|
|
|
* If the source object uses a texture as part of a Texture Atlas or Sprite Sheet, only the current frame will be used for sizing.
|
2014-05-24 00:29:47 +00:00
|
|
|
* If a string is given it will assume it's a cache key and look in Phaser.Cache for an image key matching the string.
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#load
|
2014-09-04 04:05:30 +00:00
|
|
|
* @param {Phaser.Sprite|Phaser.Image|Phaser.Text|Phaser.BitmapData|HTMLImage|HTMLCanvasElement|string} source - The object that will be used to populate this BitmapData. If you give a string it will try and find the Image in the Game.Cache first.
|
2014-09-03 10:12:06 +00:00
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
2014-05-24 00:29:47 +00:00
|
|
|
*/
|
|
|
|
load: function (source) {
|
|
|
|
|
2014-05-24 01:02:49 +00:00
|
|
|
if (typeof source === 'string')
|
|
|
|
{
|
|
|
|
source = this.game.cache.getImage(source);
|
|
|
|
}
|
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
if (source)
|
2014-05-24 00:29:47 +00:00
|
|
|
{
|
2014-09-04 04:05:30 +00:00
|
|
|
this.resize(source.width, source.height);
|
|
|
|
this.cls();
|
2014-05-24 00:29:47 +00:00
|
|
|
}
|
2014-05-24 01:02:49 +00:00
|
|
|
else
|
2014-05-24 00:29:47 +00:00
|
|
|
{
|
2014-09-04 04:05:30 +00:00
|
|
|
return;
|
2014-05-24 00:29:47 +00:00
|
|
|
}
|
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
this.draw(source);
|
|
|
|
|
2014-05-24 01:43:59 +00:00
|
|
|
this.update();
|
|
|
|
|
2014-09-03 10:12:06 +00:00
|
|
|
return this;
|
|
|
|
|
2014-05-24 00:29:47 +00:00
|
|
|
},
|
|
|
|
|
2013-11-25 03:13:04 +00:00
|
|
|
/**
|
2014-04-24 02:49:49 +00:00
|
|
|
* Clears the BitmapData context using a clearRect.
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#cls
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Clears the BitmapData context using a clearRect.
|
|
|
|
*
|
2013-11-28 15:57:09 +00:00
|
|
|
* @method Phaser.BitmapData#clear
|
2014-09-03 10:12:06 +00:00
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
2013-11-25 03:13:04 +00:00
|
|
|
*/
|
|
|
|
clear: function () {
|
|
|
|
|
|
|
|
this.context.clearRect(0, 0, this.width, this.height);
|
2014-03-23 07:59:28 +00:00
|
|
|
|
2014-03-21 18:04:24 +00:00
|
|
|
this.dirty = true;
|
2013-11-25 03:13:04 +00:00
|
|
|
|
2014-09-03 10:12:06 +00:00
|
|
|
return this;
|
|
|
|
|
2013-11-25 03:13:04 +00:00
|
|
|
},
|
|
|
|
|
2014-02-14 06:04:29 +00:00
|
|
|
/**
|
2014-04-24 02:49:49 +00:00
|
|
|
* Fills the BitmapData with the given color.
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#fill
|
|
|
|
* @param {number} r - The red color value, between 0 and 0xFF (255).
|
|
|
|
* @param {number} g - The green color value, between 0 and 0xFF (255).
|
|
|
|
* @param {number} b - The blue color value, between 0 and 0xFF (255).
|
2014-04-25 14:11:54 +00:00
|
|
|
* @param {number} [a=1] - The alpha color value, between 0 and 1.
|
2014-09-03 10:12:06 +00:00
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
2014-04-24 02:49:49 +00:00
|
|
|
*/
|
|
|
|
fill: function (r, g, b, a) {
|
|
|
|
|
2014-04-25 14:11:54 +00:00
|
|
|
if (typeof a === 'undefined') { a = 1; }
|
2014-04-24 02:49:49 +00:00
|
|
|
|
|
|
|
this.context.fillStyle = 'rgba(' + r + ',' + g + ',' + b + ',' + a + ')';
|
|
|
|
this.context.fillRect(0, 0, this.width, this.height);
|
|
|
|
this.dirty = true;
|
|
|
|
|
2014-09-03 10:12:06 +00:00
|
|
|
return this;
|
|
|
|
|
2014-04-24 02:49:49 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Resizes the BitmapData. This changes the size of the underlying canvas and refreshes the buffer.
|
|
|
|
*
|
2014-02-14 06:04:29 +00:00
|
|
|
* @method Phaser.BitmapData#resize
|
2014-09-03 10:12:06 +00:00
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
2014-02-14 06:04:29 +00:00
|
|
|
*/
|
|
|
|
resize: function (width, height) {
|
|
|
|
|
|
|
|
if (width !== this.width || height !== this.height)
|
|
|
|
{
|
|
|
|
this.width = width;
|
|
|
|
this.height = height;
|
2014-05-24 01:43:59 +00:00
|
|
|
|
2014-02-14 06:04:29 +00:00
|
|
|
this.canvas.width = width;
|
|
|
|
this.canvas.height = height;
|
2014-05-24 01:43:59 +00:00
|
|
|
|
2014-05-24 01:02:49 +00:00
|
|
|
this.baseTexture.width = width;
|
|
|
|
this.baseTexture.height = height;
|
2014-05-24 01:43:59 +00:00
|
|
|
|
2014-02-14 06:04:29 +00:00
|
|
|
this.textureFrame.width = width;
|
|
|
|
this.textureFrame.height = height;
|
2014-05-24 01:43:59 +00:00
|
|
|
|
2014-05-24 01:02:49 +00:00
|
|
|
this.texture.width = width;
|
|
|
|
this.texture.height = height;
|
2014-05-24 01:43:59 +00:00
|
|
|
|
2014-07-18 02:33:17 +00:00
|
|
|
this.texture.crop.width = width;
|
|
|
|
this.texture.crop.height = height;
|
|
|
|
|
2014-08-28 02:40:59 +00:00
|
|
|
this.update();
|
2014-05-24 01:43:59 +00:00
|
|
|
this.dirty = true;
|
2014-02-14 06:04:29 +00:00
|
|
|
}
|
2014-03-23 07:59:28 +00:00
|
|
|
|
2014-09-03 10:12:06 +00:00
|
|
|
return this;
|
|
|
|
|
2014-02-14 06:04:29 +00:00
|
|
|
},
|
|
|
|
|
2014-02-14 12:07:04 +00:00
|
|
|
/**
|
2014-04-24 02:49:49 +00:00
|
|
|
* This re-creates the BitmapData.imageData from the current context.
|
2014-04-24 04:19:45 +00:00
|
|
|
* It then re-builds the ArrayBuffer, the data Uint8ClampedArray reference and the pixels Int32Array.
|
2014-04-24 02:49:49 +00:00
|
|
|
* If not given the dimensions defaults to the full size of the context.
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#update
|
|
|
|
* @param {number} [x=0] - The x coordinate of the top-left of the image data area to grab from.
|
|
|
|
* @param {number} [y=0] - The y coordinate of the top-left of the image data area to grab from.
|
|
|
|
* @param {number} [width] - The width of the image data area.
|
|
|
|
* @param {number} [height] - The height of the image data area.
|
2014-09-03 10:12:06 +00:00
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
2014-04-24 02:49:49 +00:00
|
|
|
*/
|
2014-08-28 02:40:59 +00:00
|
|
|
update: function (x, y, width, height) {
|
2014-04-24 02:49:49 +00:00
|
|
|
|
|
|
|
if (typeof x === 'undefined') { x = 0; }
|
|
|
|
if (typeof y === 'undefined') { y = 0; }
|
|
|
|
if (typeof width === 'undefined') { width = this.width; }
|
|
|
|
if (typeof height === 'undefined') { height = this.height; }
|
2013-11-25 03:13:04 +00:00
|
|
|
|
2014-04-24 02:49:49 +00:00
|
|
|
this.imageData = this.context.getImageData(x, y, width, height);
|
2014-04-29 14:38:33 +00:00
|
|
|
this.data = this.imageData.data;
|
2014-04-24 02:49:49 +00:00
|
|
|
|
|
|
|
if (this.imageData.data.buffer)
|
|
|
|
{
|
|
|
|
this.buffer = this.imageData.data.buffer;
|
2014-04-29 14:38:33 +00:00
|
|
|
this.pixels = new Uint32Array(this.buffer);
|
2014-04-24 02:49:49 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2014-04-29 14:38:33 +00:00
|
|
|
if (window['ArrayBuffer'])
|
|
|
|
{
|
|
|
|
this.buffer = new ArrayBuffer(this.imageData.data.length);
|
|
|
|
this.pixels = new Uint32Array(this.buffer);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
this.pixels = this.imageData.data;
|
|
|
|
}
|
2014-04-24 02:49:49 +00:00
|
|
|
}
|
2013-11-25 03:13:04 +00:00
|
|
|
|
2014-09-03 10:12:06 +00:00
|
|
|
return this;
|
|
|
|
|
2013-11-25 03:13:04 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
2014-04-24 04:19:45 +00:00
|
|
|
* Scans through the area specified in this BitmapData and sends a color object for every pixel to the given callback.
|
2014-04-28 04:33:52 +00:00
|
|
|
* The callback will be sent a color object with 6 properties: `{ r: number, g: number, b: number, a: number, color: number, rgba: string }`.
|
2014-04-24 04:19:45 +00:00
|
|
|
* Where r, g, b and a are integers between 0 and 255 representing the color component values for red, green, blue and alpha.
|
|
|
|
* The `color` property is an Int32 of the full color. Note the endianess of this will change per system.
|
|
|
|
* The `rgba` property is a CSS style rgba() string which can be used with context.fillStyle calls, among others.
|
2014-04-28 04:33:52 +00:00
|
|
|
* The callback will also be sent the pixels x and y coordinates respectively.
|
2014-04-24 04:19:45 +00:00
|
|
|
* The callback must return either `false`, in which case no change will be made to the pixel, or a new color object.
|
|
|
|
* If a new color object is returned the pixel will be set to the r, g, b and a color values given within it.
|
2014-04-23 22:35:36 +00:00
|
|
|
*
|
2014-04-24 04:19:45 +00:00
|
|
|
* @method Phaser.BitmapData#processPixelRGB
|
|
|
|
* @param {function} callback - The callback that will be sent each pixel color object to be processed.
|
|
|
|
* @param {object} callbackContext - The context under which the callback will be called.
|
|
|
|
* @param {number} [x=0] - The x coordinate of the top-left of the region to process from.
|
|
|
|
* @param {number} [y=0] - The y coordinate of the top-left of the region to process from.
|
|
|
|
* @param {number} [width] - The width of the region to process.
|
|
|
|
* @param {number} [height] - The height of the region to process.
|
2014-09-04 15:52:10 +00:00
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
2014-04-23 22:35:36 +00:00
|
|
|
*/
|
2014-04-24 04:19:45 +00:00
|
|
|
processPixelRGB: function (callback, callbackContext, x, y, width, height) {
|
2014-04-23 22:35:36 +00:00
|
|
|
|
2014-04-24 04:19:45 +00:00
|
|
|
if (typeof x === 'undefined') { x = 0; }
|
|
|
|
if (typeof y === 'undefined') { y = 0; }
|
|
|
|
if (typeof width === 'undefined') { width = this.width; }
|
|
|
|
if (typeof height === 'undefined') { height = this.height; }
|
2014-04-23 22:35:36 +00:00
|
|
|
|
2014-04-24 04:19:45 +00:00
|
|
|
var w = x + width;
|
|
|
|
var h = y + height;
|
2014-04-25 01:45:27 +00:00
|
|
|
var pixel = Phaser.Color.createColor();
|
2014-04-24 04:19:45 +00:00
|
|
|
var result = { r: 0, g: 0, b: 0, a: 0 };
|
|
|
|
var dirty = false;
|
|
|
|
|
|
|
|
for (var ty = y; ty < h; ty++)
|
2014-04-23 22:35:36 +00:00
|
|
|
{
|
2014-04-24 04:19:45 +00:00
|
|
|
for (var tx = x; tx < w; tx++)
|
|
|
|
{
|
2014-04-25 01:45:27 +00:00
|
|
|
Phaser.Color.unpackPixel(this.getPixel32(tx, ty), pixel);
|
|
|
|
|
2014-04-28 04:33:52 +00:00
|
|
|
result = callback.call(callbackContext, pixel, tx, ty);
|
2014-04-23 22:35:36 +00:00
|
|
|
|
2014-05-07 01:43:35 +00:00
|
|
|
if (result !== false && result !== null && result !== undefined)
|
2014-04-24 04:19:45 +00:00
|
|
|
{
|
|
|
|
this.setPixel32(tx, ty, result.r, result.g, result.b, result.a, false);
|
|
|
|
dirty = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2014-04-23 22:35:36 +00:00
|
|
|
|
2014-04-24 04:19:45 +00:00
|
|
|
if (dirty)
|
2014-04-23 22:35:36 +00:00
|
|
|
{
|
2014-04-24 04:19:45 +00:00
|
|
|
this.context.putImageData(this.imageData, 0, 0);
|
|
|
|
this.dirty = true;
|
|
|
|
}
|
2014-04-23 22:35:36 +00:00
|
|
|
|
2014-09-04 15:52:10 +00:00
|
|
|
return this;
|
|
|
|
|
2014-04-24 04:19:45 +00:00
|
|
|
},
|
2014-04-23 22:35:36 +00:00
|
|
|
|
2014-04-24 04:19:45 +00:00
|
|
|
/**
|
2014-04-28 04:33:52 +00:00
|
|
|
* Scans through the area specified in this BitmapData and sends the color for every pixel to the given callback along with its x and y coordinates.
|
2014-04-25 01:45:27 +00:00
|
|
|
* Whatever value the callback returns is set as the new color for that pixel, unless it returns the same color, in which case it's skipped.
|
|
|
|
* Note that the format of the color received will be different depending on if the system is big or little endian.
|
|
|
|
* It is expected that your callback will deal with endianess. If you'd rather Phaser did it then use processPixelRGB instead.
|
2014-04-28 04:33:52 +00:00
|
|
|
* The callback will also be sent the pixels x and y coordinates respectively.
|
2014-04-25 01:45:27 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#processPixel
|
|
|
|
* @param {function} callback - The callback that will be sent each pixel color to be processed.
|
|
|
|
* @param {object} callbackContext - The context under which the callback will be called.
|
|
|
|
* @param {number} [x=0] - The x coordinate of the top-left of the region to process from.
|
|
|
|
* @param {number} [y=0] - The y coordinate of the top-left of the region to process from.
|
|
|
|
* @param {number} [width] - The width of the region to process.
|
|
|
|
* @param {number} [height] - The height of the region to process.
|
2014-09-04 15:52:10 +00:00
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
2014-04-25 01:45:27 +00:00
|
|
|
*/
|
|
|
|
processPixel: function (callback, callbackContext, x, y, width, height) {
|
|
|
|
|
|
|
|
if (typeof x === 'undefined') { x = 0; }
|
|
|
|
if (typeof y === 'undefined') { y = 0; }
|
|
|
|
if (typeof width === 'undefined') { width = this.width; }
|
|
|
|
if (typeof height === 'undefined') { height = this.height; }
|
|
|
|
|
|
|
|
var w = x + width;
|
|
|
|
var h = y + height;
|
|
|
|
var pixel = 0;
|
|
|
|
var result = 0;
|
|
|
|
var dirty = false;
|
|
|
|
|
|
|
|
for (var ty = y; ty < h; ty++)
|
|
|
|
{
|
|
|
|
for (var tx = x; tx < w; tx++)
|
|
|
|
{
|
|
|
|
pixel = this.getPixel32(tx, ty);
|
2014-04-28 04:33:52 +00:00
|
|
|
result = callback.call(callbackContext, pixel, tx, ty);
|
2014-04-25 01:45:27 +00:00
|
|
|
|
|
|
|
if (result !== pixel)
|
|
|
|
{
|
|
|
|
this.pixels[ty * this.width + tx] = result;
|
|
|
|
dirty = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (dirty)
|
|
|
|
{
|
|
|
|
this.context.putImageData(this.imageData, 0, 0);
|
|
|
|
this.dirty = true;
|
|
|
|
}
|
|
|
|
|
2014-09-04 15:52:10 +00:00
|
|
|
return this;
|
|
|
|
|
2014-04-25 01:45:27 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Replaces all pixels matching one color with another. The color values are given as two sets of RGBA values.
|
|
|
|
* An optional region parameter controls if the replacement happens in just a specific area of the BitmapData or the entire thing.
|
2014-04-24 04:19:45 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#replaceRGB
|
|
|
|
* @param {number} r1 - The red color value to be replaced. Between 0 and 255.
|
|
|
|
* @param {number} g1 - The green color value to be replaced. Between 0 and 255.
|
|
|
|
* @param {number} b1 - The blue color value to be replaced. Between 0 and 255.
|
|
|
|
* @param {number} a1 - The alpha color value to be replaced. Between 0 and 255.
|
|
|
|
* @param {number} r2 - The red color value that is the replacement color. Between 0 and 255.
|
|
|
|
* @param {number} g2 - The green color value that is the replacement color. Between 0 and 255.
|
|
|
|
* @param {number} b2 - The blue color value that is the replacement color. Between 0 and 255.
|
|
|
|
* @param {number} a2 - The alpha color value that is the replacement color. Between 0 and 255.
|
|
|
|
* @param {Phaser.Rectangle} [region] - The area to perform the search over. If not given it will replace over the whole BitmapData.
|
2014-09-03 10:12:06 +00:00
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
2014-04-24 04:19:45 +00:00
|
|
|
*/
|
|
|
|
replaceRGB: function (r1, g1, b1, a1, r2, g2, b2, a2, region) {
|
|
|
|
|
|
|
|
var sx = 0;
|
|
|
|
var sy = 0;
|
|
|
|
var w = this.width;
|
|
|
|
var h = this.height;
|
2014-04-25 01:45:27 +00:00
|
|
|
var source = Phaser.Color.packPixel(r1, g1, b1, a1);
|
2014-04-23 22:35:36 +00:00
|
|
|
|
2014-04-24 04:19:45 +00:00
|
|
|
if (region !== undefined && region instanceof Phaser.Rectangle)
|
|
|
|
{
|
|
|
|
sx = region.x;
|
|
|
|
sy = region.y;
|
|
|
|
w = region.width;
|
|
|
|
h = region.height;
|
|
|
|
}
|
2014-04-23 22:35:36 +00:00
|
|
|
|
2014-04-24 04:19:45 +00:00
|
|
|
for (var y = 0; y < h; y++)
|
|
|
|
{
|
|
|
|
for (var x = 0; x < w; x++)
|
|
|
|
{
|
|
|
|
if (this.getPixel32(sx + x, sy + y) === source)
|
|
|
|
{
|
|
|
|
this.setPixel32(sx + x, sy + y, r2, g2, b2, a2, false);
|
|
|
|
}
|
|
|
|
}
|
2014-04-23 22:35:36 +00:00
|
|
|
}
|
|
|
|
|
2014-04-24 04:19:45 +00:00
|
|
|
this.context.putImageData(this.imageData, 0, 0);
|
|
|
|
this.dirty = true;
|
|
|
|
|
2014-09-03 10:12:06 +00:00
|
|
|
return this;
|
|
|
|
|
2014-04-23 22:35:36 +00:00
|
|
|
},
|
|
|
|
|
2014-04-25 01:45:27 +00:00
|
|
|
/**
|
2014-04-29 01:34:16 +00:00
|
|
|
* Sets the hue, saturation and lightness values on every pixel in the given region, or the whole BitmapData if no region was specified.
|
2014-04-25 01:45:27 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#setHSL
|
2014-04-25 03:13:59 +00:00
|
|
|
* @param {number} [h=null] - The hue, in the range 0 - 1.
|
|
|
|
* @param {number} [s=null] - The saturation, in the range 0 - 1.
|
|
|
|
* @param {number} [l=null] - The lightness, in the range 0 - 1.
|
|
|
|
* @param {Phaser.Rectangle} [region] - The area to perform the operation on. If not given it will run over the whole BitmapData.
|
2014-09-03 10:12:06 +00:00
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
2014-04-25 01:45:27 +00:00
|
|
|
*/
|
|
|
|
setHSL: function (h, s, l, region) {
|
|
|
|
|
|
|
|
if (typeof h === 'undefined' || h === null) { h = false; }
|
|
|
|
if (typeof s === 'undefined' || s === null) { s = false; }
|
|
|
|
if (typeof l === 'undefined' || l === null) { l = false; }
|
|
|
|
|
|
|
|
if (!h && !s && !l)
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-04-25 03:13:59 +00:00
|
|
|
if (typeof region === 'undefined')
|
2014-04-25 01:45:27 +00:00
|
|
|
{
|
2014-04-25 03:13:59 +00:00
|
|
|
region = new Phaser.Rectangle(0, 0, this.width, this.height);
|
2014-04-25 01:45:27 +00:00
|
|
|
}
|
|
|
|
|
2014-04-25 03:13:59 +00:00
|
|
|
var pixel = Phaser.Color.createColor();
|
|
|
|
|
|
|
|
for (var y = region.y; y < region.bottom; y++)
|
2014-04-25 01:45:27 +00:00
|
|
|
{
|
2014-04-25 03:13:59 +00:00
|
|
|
for (var x = region.x; x < region.right; x++)
|
2014-04-25 01:45:27 +00:00
|
|
|
{
|
2014-04-25 03:13:59 +00:00
|
|
|
Phaser.Color.unpackPixel(this.getPixel32(x, y), pixel, true);
|
2014-04-25 01:45:27 +00:00
|
|
|
|
|
|
|
if (h)
|
|
|
|
{
|
|
|
|
pixel.h = h;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (s)
|
|
|
|
{
|
|
|
|
pixel.s = s;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (l)
|
|
|
|
{
|
|
|
|
pixel.l = l;
|
|
|
|
}
|
|
|
|
|
|
|
|
Phaser.Color.HSLtoRGB(pixel.h, pixel.s, pixel.l, pixel);
|
2014-04-25 03:13:59 +00:00
|
|
|
this.setPixel32(x, y, pixel.r, pixel.g, pixel.b, pixel.a, false);
|
2014-04-25 01:45:27 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
this.context.putImageData(this.imageData, 0, 0);
|
|
|
|
this.dirty = true;
|
|
|
|
|
2014-09-03 10:12:06 +00:00
|
|
|
return this;
|
|
|
|
|
2014-04-25 01:45:27 +00:00
|
|
|
},
|
|
|
|
|
2014-04-25 03:13:59 +00:00
|
|
|
/**
|
|
|
|
* Shifts any or all of the hue, saturation and lightness values on every pixel in the given region, or the whole BitmapData if no region was specified.
|
|
|
|
* Shifting will add the given value onto the current h, s and l values, not replace them.
|
|
|
|
* The hue is wrapped to keep it within the range 0 to 1. Saturation and lightness are clamped to not exceed 1.
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#shiftHSL
|
|
|
|
* @param {number} [h=null] - The amount to shift the hue by.
|
|
|
|
* @param {number} [s=null] - The amount to shift the saturation by.
|
|
|
|
* @param {number} [l=null] - The amount to shift the lightness by.
|
|
|
|
* @param {Phaser.Rectangle} [region] - The area to perform the operation on. If not given it will run over the whole BitmapData.
|
2014-09-03 10:12:06 +00:00
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
2014-04-25 03:13:59 +00:00
|
|
|
*/
|
|
|
|
shiftHSL: function (h, s, l, region) {
|
2014-04-25 01:45:27 +00:00
|
|
|
|
|
|
|
if (typeof h === 'undefined' || h === null) { h = false; }
|
|
|
|
if (typeof s === 'undefined' || s === null) { s = false; }
|
|
|
|
if (typeof l === 'undefined' || l === null) { l = false; }
|
|
|
|
|
|
|
|
if (!h && !s && !l)
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2014-04-25 03:13:59 +00:00
|
|
|
if (typeof region === 'undefined')
|
2014-04-25 01:45:27 +00:00
|
|
|
{
|
2014-04-25 03:13:59 +00:00
|
|
|
region = new Phaser.Rectangle(0, 0, this.width, this.height);
|
2014-04-25 01:45:27 +00:00
|
|
|
}
|
|
|
|
|
2014-04-25 03:13:59 +00:00
|
|
|
var pixel = Phaser.Color.createColor();
|
|
|
|
|
|
|
|
for (var y = region.y; y < region.bottom; y++)
|
2014-04-25 01:45:27 +00:00
|
|
|
{
|
2014-04-25 03:13:59 +00:00
|
|
|
for (var x = region.x; x < region.right; x++)
|
2014-04-25 01:45:27 +00:00
|
|
|
{
|
2014-04-25 03:13:59 +00:00
|
|
|
Phaser.Color.unpackPixel(this.getPixel32(x, y), pixel, true);
|
2014-04-25 01:45:27 +00:00
|
|
|
|
|
|
|
if (h)
|
|
|
|
{
|
|
|
|
pixel.h = this.game.math.wrap(pixel.h + h, 0, 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (s)
|
|
|
|
{
|
|
|
|
pixel.s = this.game.math.limitValue(pixel.s + s, 0, 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (l)
|
|
|
|
{
|
|
|
|
pixel.l = this.game.math.limitValue(pixel.l + l, 0, 1);
|
|
|
|
}
|
|
|
|
|
|
|
|
Phaser.Color.HSLtoRGB(pixel.h, pixel.s, pixel.l, pixel);
|
2014-04-25 03:13:59 +00:00
|
|
|
this.setPixel32(x, y, pixel.r, pixel.g, pixel.b, pixel.a, false);
|
2014-04-25 01:45:27 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
this.context.putImageData(this.imageData, 0, 0);
|
|
|
|
this.dirty = true;
|
|
|
|
|
2014-09-03 10:12:06 +00:00
|
|
|
return this;
|
|
|
|
|
2014-04-25 01:45:27 +00:00
|
|
|
},
|
|
|
|
|
2014-04-23 22:35:36 +00:00
|
|
|
/**
|
|
|
|
* Sets the color of the given pixel to the specified red, green, blue and alpha values.
|
|
|
|
*
|
2013-11-28 15:57:09 +00:00
|
|
|
* @method Phaser.BitmapData#setPixel32
|
2014-04-24 04:19:45 +00:00
|
|
|
* @param {number} x - The x coordinate of the pixel to be set. Must lay within the dimensions of this BitmapData.
|
|
|
|
* @param {number} y - The y coordinate of the pixel to be set. Must lay within the dimensions of this BitmapData.
|
2013-11-25 03:13:04 +00:00
|
|
|
* @param {number} red - The red color value, between 0 and 0xFF (255).
|
|
|
|
* @param {number} green - The green color value, between 0 and 0xFF (255).
|
|
|
|
* @param {number} blue - The blue color value, between 0 and 0xFF (255).
|
|
|
|
* @param {number} alpha - The alpha color value, between 0 and 0xFF (255).
|
2014-04-24 04:19:45 +00:00
|
|
|
* @param {boolean} [immediate=true] - If `true` the context.putImageData will be called and the dirty flag set.
|
2014-09-03 10:12:06 +00:00
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
2013-11-25 03:13:04 +00:00
|
|
|
*/
|
2014-04-24 04:19:45 +00:00
|
|
|
setPixel32: function (x, y, red, green, blue, alpha, immediate) {
|
|
|
|
|
|
|
|
if (typeof immediate === 'undefined') { immediate = true; }
|
2013-11-15 20:40:39 +00:00
|
|
|
|
2013-11-25 03:13:04 +00:00
|
|
|
if (x >= 0 && x <= this.width && y >= 0 && y <= this.height)
|
|
|
|
{
|
2014-04-25 01:45:27 +00:00
|
|
|
if (Phaser.Device.LITTLE_ENDIAN)
|
2013-11-25 03:13:04 +00:00
|
|
|
{
|
2014-04-24 02:49:49 +00:00
|
|
|
this.pixels[y * this.width + x] = (alpha << 24) | (blue << 16) | (green << 8) | red;
|
2013-11-25 03:13:04 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2014-04-24 02:49:49 +00:00
|
|
|
this.pixels[y * this.width + x] = (red << 24) | (green << 16) | (blue << 8) | alpha;
|
2013-11-25 03:13:04 +00:00
|
|
|
}
|
2013-11-15 20:40:39 +00:00
|
|
|
|
2014-04-24 04:19:45 +00:00
|
|
|
if (immediate)
|
|
|
|
{
|
|
|
|
this.context.putImageData(this.imageData, 0, 0);
|
|
|
|
this.dirty = true;
|
|
|
|
}
|
2013-11-25 03:13:04 +00:00
|
|
|
}
|
2013-11-15 20:40:39 +00:00
|
|
|
|
2014-09-03 10:12:06 +00:00
|
|
|
return this;
|
|
|
|
|
2013-11-15 20:40:39 +00:00
|
|
|
},
|
|
|
|
|
2013-11-25 03:13:04 +00:00
|
|
|
/**
|
|
|
|
* Sets the color of the given pixel to the specified red, green and blue values.
|
2014-02-21 14:50:18 +00:00
|
|
|
*
|
2013-11-28 15:57:09 +00:00
|
|
|
* @method Phaser.BitmapData#setPixel
|
2014-04-24 04:19:45 +00:00
|
|
|
* @param {number} x - The x coordinate of the pixel to be set. Must lay within the dimensions of this BitmapData.
|
|
|
|
* @param {number} y - The y coordinate of the pixel to be set. Must lay within the dimensions of this BitmapData.
|
|
|
|
* @param {number} red - The red color value, between 0 and 0xFF (255).
|
|
|
|
* @param {number} green - The green color value, between 0 and 0xFF (255).
|
|
|
|
* @param {number} blue - The blue color value, between 0 and 0xFF (255).
|
|
|
|
* @param {number} alpha - The alpha color value, between 0 and 0xFF (255).
|
|
|
|
* @param {boolean} [immediate=true] - If `true` the context.putImageData will be called and the dirty flag set.
|
2014-09-03 10:12:06 +00:00
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
2013-11-25 03:13:04 +00:00
|
|
|
*/
|
2014-04-24 04:19:45 +00:00
|
|
|
setPixel: function (x, y, red, green, blue, immediate) {
|
2013-11-15 20:40:39 +00:00
|
|
|
|
2014-09-03 10:12:06 +00:00
|
|
|
return this.setPixel32(x, y, red, green, blue, 255, immediate);
|
2013-11-15 20:40:39 +00:00
|
|
|
|
|
|
|
},
|
|
|
|
|
2013-11-25 03:13:04 +00:00
|
|
|
/**
|
2014-04-25 03:13:59 +00:00
|
|
|
* Get the color of a specific pixel in the context into a color object.
|
2014-05-01 01:38:12 +00:00
|
|
|
* If you have drawn anything to the BitmapData since it was created you must call BitmapData.update to refresh the array buffer,
|
|
|
|
* otherwise this may return out of date color values, or worse - throw a run-time error as it tries to access an array element that doesn't exist.
|
2014-02-21 14:50:18 +00:00
|
|
|
*
|
2014-04-25 03:13:59 +00:00
|
|
|
* @method Phaser.BitmapData#getPixel
|
|
|
|
* @param {number} x - The x coordinate of the pixel to be set. Must lay within the dimensions of this BitmapData.
|
|
|
|
* @param {number} y - The y coordinate of the pixel to be set. Must lay within the dimensions of this BitmapData.
|
|
|
|
* @param {object} [out] - An object into which 4 properties will be created: r, g, b and a. If not provided a new object will be created.
|
|
|
|
* @return {object} An object with the red, green, blue and alpha values set in the r, g, b and a properties.
|
2013-11-25 03:13:04 +00:00
|
|
|
*/
|
2014-04-24 02:49:49 +00:00
|
|
|
getPixel: function (x, y, out) {
|
2013-11-15 20:40:39 +00:00
|
|
|
|
2014-04-24 02:49:49 +00:00
|
|
|
if (!out)
|
2013-11-25 03:13:04 +00:00
|
|
|
{
|
2014-04-25 01:45:27 +00:00
|
|
|
out = Phaser.Color.createColor();
|
2013-11-25 03:13:04 +00:00
|
|
|
}
|
2013-11-15 20:40:39 +00:00
|
|
|
|
2014-04-25 01:45:27 +00:00
|
|
|
var index = ~~(x + (y * this.width));
|
|
|
|
|
|
|
|
index *= 4;
|
|
|
|
|
2014-06-09 21:34:06 +00:00
|
|
|
out.r = this.data[index];
|
|
|
|
out.g = this.data[++index];
|
|
|
|
out.b = this.data[++index];
|
|
|
|
out.a = this.data[++index];
|
2014-04-24 02:49:49 +00:00
|
|
|
|
|
|
|
return out;
|
|
|
|
|
2013-11-15 20:40:39 +00:00
|
|
|
},
|
|
|
|
|
2013-11-25 03:13:04 +00:00
|
|
|
/**
|
2014-02-21 14:50:18 +00:00
|
|
|
* Get the color of a specific pixel including its alpha value.
|
2014-05-01 01:38:12 +00:00
|
|
|
* If you have drawn anything to the BitmapData since it was created you must call BitmapData.update to refresh the array buffer,
|
|
|
|
* otherwise this may return out of date color values, or worse - throw a run-time error as it tries to access an array element that doesn't exist.
|
2014-04-24 02:49:49 +00:00
|
|
|
* Note that on little-endian systems the format is 0xAABBGGRR and on big-endian the format is 0xRRGGBBAA.
|
2014-02-21 14:50:18 +00:00
|
|
|
*
|
2014-04-23 22:35:36 +00:00
|
|
|
* @method Phaser.BitmapData#getPixel32
|
2014-04-25 03:13:59 +00:00
|
|
|
* @param {number} x - The x coordinate of the pixel to be set. Must lay within the dimensions of this BitmapData.
|
|
|
|
* @param {number} y - The y coordinate of the pixel to be set. Must lay within the dimensions of this BitmapData.
|
2013-11-25 03:13:04 +00:00
|
|
|
* @return {number} A native color value integer (format: 0xAARRGGBB)
|
|
|
|
*/
|
2013-11-15 20:40:39 +00:00
|
|
|
getPixel32: function (x, y) {
|
|
|
|
|
2013-11-25 03:13:04 +00:00
|
|
|
if (x >= 0 && x <= this.width && y >= 0 && y <= this.height)
|
|
|
|
{
|
2014-04-24 02:49:49 +00:00
|
|
|
return this.pixels[y * this.width + x];
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the color of a specific pixel including its alpha value as a color object containing r,g,b,a and rgba properties.
|
2014-05-01 01:38:12 +00:00
|
|
|
* If you have drawn anything to the BitmapData since it was created you must call BitmapData.update to refresh the array buffer,
|
|
|
|
* otherwise this may return out of date color values, or worse - throw a run-time error as it tries to access an array element that doesn't exist.
|
2014-04-24 02:49:49 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#getPixelRGB
|
2014-04-25 03:13:59 +00:00
|
|
|
* @param {number} x - The x coordinate of the pixel to be set. Must lay within the dimensions of this BitmapData.
|
|
|
|
* @param {number} y - The y coordinate of the pixel to be set. Must lay within the dimensions of this BitmapData.
|
|
|
|
* @param {object} [out] - An object into which 3 properties will be created: r, g and b. If not provided a new object will be created.
|
|
|
|
* @param {boolean} [hsl=false] - Also convert the rgb values into hsl?
|
|
|
|
* @param {boolean} [hsv=false] - Also convert the rgb values into hsv?
|
|
|
|
* @return {object} An object with the red, green and blue values set in the r, g and b properties.
|
2014-04-24 02:49:49 +00:00
|
|
|
*/
|
2014-04-25 03:13:59 +00:00
|
|
|
getPixelRGB: function (x, y, out, hsl, hsv) {
|
2014-04-24 02:49:49 +00:00
|
|
|
|
2014-04-25 03:13:59 +00:00
|
|
|
return Phaser.Color.unpackPixel(this.getPixel32(x, y), out, hsl, hsv);
|
2013-11-15 20:40:39 +00:00
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
2014-02-21 14:50:18 +00:00
|
|
|
* Gets all the pixels from the region specified by the given Rectangle object.
|
|
|
|
*
|
2014-04-23 22:35:36 +00:00
|
|
|
* @method Phaser.BitmapData#getPixels
|
2014-02-21 14:50:18 +00:00
|
|
|
* @param {Phaser.Rectangle} rect - The Rectangle region to get.
|
2014-04-24 02:49:49 +00:00
|
|
|
* @return {ImageData} Returns a ImageData object containing a Uint8ClampedArray data property.
|
2013-11-25 04:40:04 +00:00
|
|
|
*/
|
2013-11-15 20:40:39 +00:00
|
|
|
getPixels: function (rect) {
|
|
|
|
|
2013-11-25 03:13:04 +00:00
|
|
|
return this.context.getImageData(rect.x, rect.y, rect.width, rect.height);
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2014-10-17 15:51:50 +00:00
|
|
|
/**
|
|
|
|
* Scans the BitmapData, pixel by pixel, until it encounters a pixel that isn't transparent (i.e. has an alpha value > 0).
|
|
|
|
* It then stops scanning and returns an object containing the colour of the pixel in r, g and b properties and the location in the x and y properties.
|
|
|
|
*
|
|
|
|
* The direction parameter controls from which direction it should start the scan:
|
|
|
|
*
|
|
|
|
* 0 = top to bottom
|
|
|
|
* 1 = bottom to top
|
|
|
|
* 2 = left to right
|
|
|
|
* 3 = right to left
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#getFirstPixel
|
|
|
|
* @param {number} [direction=0] - The direction in which to scan for the first pixel. 0 = top to bottom, 1 = bottom to top, 2 = left to right and 3 = right to left.
|
|
|
|
* @return {object} Returns an object containing the colour of the pixel in the `r`, `g` and `b` properties and the location in the `x` and `y` properties.
|
|
|
|
*/
|
|
|
|
getFirstPixel: function (direction) {
|
|
|
|
|
|
|
|
if (typeof direction === 'undefined') { direction = 0; }
|
|
|
|
|
|
|
|
var pixel = Phaser.Color.createColor();
|
|
|
|
|
|
|
|
var x = 0;
|
|
|
|
var y = 0;
|
|
|
|
var v = 1;
|
|
|
|
var scan = false;
|
|
|
|
|
|
|
|
if (direction === 1)
|
|
|
|
{
|
|
|
|
v = -1;
|
|
|
|
y = this.height;
|
|
|
|
}
|
|
|
|
else if (direction === 3)
|
|
|
|
{
|
|
|
|
v = -1;
|
|
|
|
x = this.width;
|
|
|
|
}
|
|
|
|
|
|
|
|
do {
|
|
|
|
|
|
|
|
Phaser.Color.unpackPixel(bmd.getPixel32(x, y), pixel);
|
|
|
|
|
|
|
|
if (direction === 0 || direction === 1)
|
|
|
|
{
|
|
|
|
// Top to Bottom / Bottom to Top
|
|
|
|
x++;
|
|
|
|
|
|
|
|
if (x === this.width)
|
|
|
|
{
|
|
|
|
x = 0;
|
|
|
|
y += v;
|
|
|
|
|
|
|
|
if (y >= this.height || y <= 0)
|
|
|
|
{
|
|
|
|
scan = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if (direction === 2 || direction === 3)
|
|
|
|
{
|
|
|
|
// Left to Right / Right to Left
|
|
|
|
y++;
|
|
|
|
|
|
|
|
if (y === this.height)
|
|
|
|
{
|
|
|
|
y = 0;
|
|
|
|
x += v;
|
|
|
|
|
|
|
|
if (x >= this.width || x <= 0)
|
|
|
|
{
|
|
|
|
scan = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
while (pixel.a === 0 && !scan);
|
|
|
|
|
|
|
|
pixel.x = x;
|
|
|
|
pixel.y = y;
|
|
|
|
|
|
|
|
return pixel;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Scans the BitmapData and calculates the bounds. This is a rectangle that defines the extent of all non-transparent pixels.
|
|
|
|
* The rectangle returned will extend from the top-left of the image to the bottom-right, exluding transparent pixels.
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#getBounds
|
|
|
|
* @param {Phaser.Rectangle} [rect] - If provided this Rectangle object will be populated with the bounds, otherwise a new object will be created.
|
|
|
|
* @return {Phaser.Rectangle} A Rectangle whose dimensions encompass the full extent of non-transparent pixels in this BitmapData.
|
|
|
|
*/
|
|
|
|
getBounds: function (rect) {
|
|
|
|
|
|
|
|
if (typeof rect === 'undefined') { rect = new Phaser.Rectangle(); }
|
|
|
|
|
|
|
|
rect.x = this.getFirstPixel(2).x;
|
|
|
|
|
|
|
|
// If we hit this, there's no point scanning any more, the image is empty
|
|
|
|
if (rect.x === this.width)
|
|
|
|
{
|
|
|
|
return rect.setTo(0, 0, 0, 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
rect.y = this.getFirstPixel(0).y;
|
|
|
|
rect.width = (this.getFirstPixel(3).x - rect.x) + 1;
|
|
|
|
rect.height = (this.getFirstPixel(1).y - rect.y) + 1;
|
|
|
|
|
|
|
|
return rect;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2014-05-29 02:30:03 +00:00
|
|
|
/**
|
|
|
|
* Creates a new Phaser.Image object, assigns this BitmapData to be its texture, adds it to the world then returns it.
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#addToWorld
|
2014-09-04 04:05:30 +00:00
|
|
|
* @param {number} [x=0] - The x coordinate to place the Image at.
|
|
|
|
* @param {number} [y=0] - The y coordinate to place the Image at.
|
|
|
|
* @param {number} [anchorX=0] - Set the x anchor point of the Image. A value between 0 and 1, where 0 is the top-left and 1 is bottom-right.
|
|
|
|
* @param {number} [anchorY=0] - Set the y anchor point of the Image. A value between 0 and 1, where 0 is the top-left and 1 is bottom-right.
|
|
|
|
* @param {number} [scaleX=1] - The horizontal scale factor of the Image. A value of 1 means no scaling. 2 would be twice the size, and so on.
|
|
|
|
* @param {number} [scaleY=1] - The vertical scale factor of the Image. A value of 1 means no scaling. 2 would be twice the size, and so on.
|
2014-05-29 02:30:03 +00:00
|
|
|
* @return {Phaser.Image} The newly added Image object.
|
|
|
|
*/
|
2014-09-04 04:05:30 +00:00
|
|
|
addToWorld: function (x, y, anchorX, anchorY, scaleX, scaleY) {
|
|
|
|
|
|
|
|
scaleX = scaleX || 1;
|
|
|
|
scaleY = scaleY || 1;
|
2014-05-29 02:30:03 +00:00
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
var image = this.game.add.image(x, y, this);
|
|
|
|
|
|
|
|
image.anchor.set(anchorX, anchorY);
|
|
|
|
image.scale.set(scaleX, scaleY);
|
|
|
|
|
|
|
|
return image;
|
2014-05-29 02:30:03 +00:00
|
|
|
|
|
|
|
},
|
|
|
|
|
2014-09-03 00:28:58 +00:00
|
|
|
/**
|
2014-09-04 04:05:30 +00:00
|
|
|
* Copies a rectangular area from the source object to this BitmapData. If you give `null` as the source it will copy from itself.
|
2014-09-03 11:53:07 +00:00
|
|
|
* You can optionally resize, translate, rotate, scale, alpha or blend as it's drawn.
|
|
|
|
* All rotation, scaling and drawing takes place around the regions center point by default, but can be changed with the anchor parameters.
|
2014-09-03 10:12:06 +00:00
|
|
|
* Note that the source image can also be this BitmapData, which can create some interesting effects.
|
|
|
|
*
|
2014-09-03 11:53:07 +00:00
|
|
|
* This method has a lot of parameters for maximum control.
|
2014-09-04 04:05:30 +00:00
|
|
|
* You can use the more friendly methods like `copyRect` and `draw` to avoid having to remember them all.
|
2014-09-03 00:28:58 +00:00
|
|
|
*
|
2014-09-03 10:12:06 +00:00
|
|
|
* @method Phaser.BitmapData#copy
|
2014-09-04 04:05:30 +00:00
|
|
|
* @param {Phaser.Sprite|Phaser.Image|Phaser.Text|Phaser.BitmapData|HTMLImage|HTMLCanvasElement|string} [source] - The source to copy from. If you give a string it will try and find the Image in the Game.Cache first. This is quite expensive so try to provide the image itself.
|
2014-09-03 10:12:06 +00:00
|
|
|
* @param {number} [x=0] - The x coordinate representing the top-left of the region to copy from the source image.
|
|
|
|
* @param {number} [y=0] - The y coordinate representing the top-left of the region to copy from the source image.
|
|
|
|
* @param {number} [width] - The width of the region to copy from the source image. If not specified it will use the full source image width.
|
|
|
|
* @param {number} [height] - The height of the region to copy from the source image. If not specified it will use the full source image height.
|
|
|
|
* @param {number} [tx] - The x coordinate to translate to before drawing. If not specified it will default to the `x` parameter.
|
|
|
|
* @param {number} [ty] - The y coordinate to translate to before drawing. If not specified it will default to the `y` parameter.
|
|
|
|
* @param {number} [newWidth] - The new width of the block being copied. If not specified it will default to the `width` parameter.
|
|
|
|
* @param {number} [newHeight] - The new height of the block being copied. If not specified it will default to the `height` parameter.
|
2014-09-03 11:53:07 +00:00
|
|
|
* @param {number} [rotate=0] - The angle in radians to rotate the block to before drawing. Rotation takes place around the center by default, but can be changed with the `anchor` parameters.
|
2014-09-03 19:56:31 +00:00
|
|
|
* @param {number} [anchorX=0] - The anchor point around which the block is rotated and scaled. A value between 0 and 1, where 0 is the top-left and 1 is bottom-right.
|
|
|
|
* @param {number} [anchorY=0] - The anchor point around which the block is rotated and scaled. A value between 0 and 1, where 0 is the top-left and 1 is bottom-right.
|
2014-09-03 00:28:58 +00:00
|
|
|
* @param {number} [scaleX=1] - The horizontal scale factor of the block. A value of 1 means no scaling. 2 would be twice the size, and so on.
|
|
|
|
* @param {number} [scaleY=1] - The vertical scale factor of the block. A value of 1 means no scaling. 2 would be twice the size, and so on.
|
2014-09-03 11:53:07 +00:00
|
|
|
* @param {number} [alpha=1] - The alpha that will be set on the context before drawing. A value between 0 (fully transparent) and 1, opaque.
|
|
|
|
* @param {number} [blendMode=null] - The composite blend mode that will be used when drawing. The default is no blend mode at all.
|
2014-09-03 00:28:58 +00:00
|
|
|
* @param {boolean} [roundPx=false] - Should the x and y values be rounded to integers before drawing? This prevents anti-aliasing in some instances.
|
2014-09-03 10:12:06 +00:00
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
2014-09-03 00:28:58 +00:00
|
|
|
*/
|
2014-09-03 10:12:06 +00:00
|
|
|
copy: function (source, x, y, width, height, tx, ty, newWidth, newHeight, rotate, anchorX, anchorY, scaleX, scaleY, alpha, blendMode, roundPx) {
|
2014-09-02 22:16:10 +00:00
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
if (typeof source === 'undefined' || source === null) { source = this; }
|
|
|
|
|
2014-09-03 11:53:07 +00:00
|
|
|
this._image = source;
|
2014-09-02 22:16:10 +00:00
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
if (source instanceof Phaser.Sprite || source instanceof Phaser.Image || source instanceof Phaser.Text)
|
2014-09-02 22:16:10 +00:00
|
|
|
{
|
2014-09-03 11:53:07 +00:00
|
|
|
// Copy over sprite values
|
2014-09-04 04:05:30 +00:00
|
|
|
this._pos.set(source.texture.crop.x, source.texture.crop.y);
|
|
|
|
this._size.set(source.texture.crop.width, source.texture.crop.height);
|
2014-09-03 11:53:07 +00:00
|
|
|
this._scale.set(source.scale.x, source.scale.y);
|
|
|
|
this._anchor.set(source.anchor.x, source.anchor.y);
|
|
|
|
this._rotate = source.rotation;
|
|
|
|
this._alpha.current = source.alpha;
|
|
|
|
this._image = source.texture.baseTexture.source;
|
2014-09-04 04:05:30 +00:00
|
|
|
|
|
|
|
if (source.texture.trim)
|
|
|
|
{
|
|
|
|
// Offset the translation coordinates by the trim amount
|
|
|
|
tx += source.texture.trim.x - source.anchor.x * source.texture.trim.width;
|
|
|
|
ty += source.texture.trim.y - source.anchor.y * source.texture.trim.height;
|
|
|
|
}
|
2014-09-30 20:07:57 +00:00
|
|
|
|
|
|
|
if (source.tint !== 0xFFFFFF)
|
|
|
|
{
|
|
|
|
if (source.cachedTint !== source.tint)
|
|
|
|
{
|
|
|
|
source.cachedTint = source.tint;
|
|
|
|
source.tintedTexture = PIXI.CanvasTinter.getTintedTexture(source, source.tint);
|
|
|
|
}
|
|
|
|
|
|
|
|
this._image = source.tintedTexture;
|
|
|
|
}
|
2014-09-02 22:16:10 +00:00
|
|
|
}
|
2014-09-03 11:53:07 +00:00
|
|
|
else
|
2014-09-03 00:28:58 +00:00
|
|
|
{
|
2014-09-03 11:53:07 +00:00
|
|
|
// Reset
|
|
|
|
this._pos.set(0);
|
|
|
|
this._scale.set(1);
|
2014-09-03 19:56:31 +00:00
|
|
|
this._anchor.set(0);
|
2014-09-03 11:53:07 +00:00
|
|
|
this._rotate = 0;
|
|
|
|
this._alpha.current = 1;
|
2014-09-02 22:16:10 +00:00
|
|
|
|
2014-09-03 11:53:07 +00:00
|
|
|
if (source instanceof Phaser.BitmapData)
|
|
|
|
{
|
|
|
|
this._image = source.canvas;
|
|
|
|
}
|
|
|
|
else if (typeof source === 'string')
|
2014-09-03 10:12:06 +00:00
|
|
|
{
|
2014-09-03 11:53:07 +00:00
|
|
|
source = this.game.cache.getImage(source);
|
|
|
|
|
|
|
|
if (source === null)
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
this._image = source;
|
|
|
|
}
|
2014-09-03 10:12:06 +00:00
|
|
|
}
|
2014-09-04 04:05:30 +00:00
|
|
|
|
|
|
|
this._size.set(this._image.width, this._image.height);
|
2014-09-03 10:12:06 +00:00
|
|
|
}
|
2014-09-02 22:16:10 +00:00
|
|
|
|
2014-09-03 10:12:06 +00:00
|
|
|
// The source region to copy from
|
|
|
|
if (typeof x === 'undefined' || x === null) { x = 0; }
|
|
|
|
if (typeof y === 'undefined' || y === null) { y = 0; }
|
2014-09-03 19:56:31 +00:00
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
// If they set a width/height then we override the frame values with them
|
|
|
|
if (width)
|
|
|
|
{
|
|
|
|
this._size.x = width;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (height)
|
|
|
|
{
|
|
|
|
this._size.y = height;
|
|
|
|
}
|
2014-09-02 22:16:10 +00:00
|
|
|
|
2014-09-03 10:12:06 +00:00
|
|
|
// The destination region to copy to
|
|
|
|
if (typeof tx === 'undefined' || tx === null) { tx = x; }
|
|
|
|
if (typeof ty === 'undefined' || ty === null) { ty = y; }
|
2014-09-04 04:05:30 +00:00
|
|
|
if (typeof newWidth === 'undefined' || newWidth === null) { newWidth = this._size.x; }
|
|
|
|
if (typeof newHeight === 'undefined' || newHeight === null) { newHeight = this._size.y; }
|
2014-09-02 22:16:10 +00:00
|
|
|
|
2014-09-03 11:53:07 +00:00
|
|
|
// Rotation - if set this will override any potential Sprite value
|
|
|
|
if (typeof rotate === 'number')
|
|
|
|
{
|
|
|
|
this._rotate = rotate;
|
|
|
|
}
|
2014-09-02 22:16:10 +00:00
|
|
|
|
2014-09-03 11:53:07 +00:00
|
|
|
// Anchor - if set this will override any potential Sprite value
|
|
|
|
if (typeof anchorX === 'number')
|
|
|
|
{
|
|
|
|
this._anchor.x = anchorX;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (typeof anchorY === 'number')
|
|
|
|
{
|
|
|
|
this._anchor.y = anchorY;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Scaling - if set this will override any potential Sprite value
|
|
|
|
if (typeof scaleX === 'number')
|
|
|
|
{
|
|
|
|
this._scale.x = scaleX;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (typeof scaleY === 'number')
|
|
|
|
{
|
|
|
|
this._scale.y = scaleY;
|
|
|
|
}
|
2014-09-01 19:22:47 +00:00
|
|
|
|
2014-09-03 10:12:06 +00:00
|
|
|
// Effects
|
2014-09-03 11:53:07 +00:00
|
|
|
if (typeof alpha === 'number')
|
|
|
|
{
|
|
|
|
this._alpha.current = alpha;
|
|
|
|
}
|
|
|
|
|
2014-09-03 10:12:06 +00:00
|
|
|
if (typeof blendMode === 'undefined') { blendMode = null; }
|
|
|
|
if (typeof roundPx === 'undefined') { roundPx = false; }
|
2014-09-02 20:03:16 +00:00
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
if (this._alpha.current <= 0 || this._scale.x === 0 || this._scale.y === 0 || this._size.x === 0 || this._size.y === 0)
|
2014-09-01 19:22:47 +00:00
|
|
|
{
|
2014-09-03 11:53:07 +00:00
|
|
|
// Why bother wasting CPU cycles drawing something you can't see?
|
2014-09-03 10:12:06 +00:00
|
|
|
return;
|
2014-09-01 19:22:47 +00:00
|
|
|
}
|
|
|
|
|
2014-09-03 11:53:07 +00:00
|
|
|
this._alpha.prev = this.context.globalAlpha;
|
2014-09-01 19:22:47 +00:00
|
|
|
|
2014-09-03 10:12:06 +00:00
|
|
|
this.context.save();
|
2014-09-02 20:03:16 +00:00
|
|
|
|
2014-09-03 11:53:07 +00:00
|
|
|
this.context.globalAlpha = this._alpha.current;
|
2014-09-01 19:22:47 +00:00
|
|
|
|
2014-09-03 10:12:06 +00:00
|
|
|
if (blendMode)
|
2014-09-01 19:22:47 +00:00
|
|
|
{
|
2014-09-03 10:12:06 +00:00
|
|
|
this.context.globalCompositeOperation = blendMode;
|
2014-09-01 19:22:47 +00:00
|
|
|
}
|
|
|
|
|
2014-09-03 10:12:06 +00:00
|
|
|
if (roundPx)
|
2014-09-01 19:22:47 +00:00
|
|
|
{
|
2014-09-04 04:05:30 +00:00
|
|
|
tx |= 0;
|
|
|
|
ty |= 0;
|
2014-09-01 19:22:47 +00:00
|
|
|
}
|
|
|
|
|
2014-09-03 10:12:06 +00:00
|
|
|
this.context.translate(tx, ty);
|
2014-09-01 19:22:47 +00:00
|
|
|
|
2014-09-03 11:53:07 +00:00
|
|
|
this.context.scale(this._scale.x, this._scale.y);
|
2014-09-01 19:22:47 +00:00
|
|
|
|
2014-09-03 11:53:07 +00:00
|
|
|
this.context.rotate(this._rotate);
|
2014-09-01 19:22:47 +00:00
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
this.context.drawImage(this._image, this._pos.x + x, this._pos.y + y, this._size.x, this._size.y, -newWidth * this._anchor.x, -newHeight * this._anchor.y, newWidth, newHeight);
|
2014-09-01 19:22:47 +00:00
|
|
|
|
2014-09-02 20:03:16 +00:00
|
|
|
this.context.restore();
|
|
|
|
|
2014-09-03 11:53:07 +00:00
|
|
|
this.context.globalAlpha = this._alpha.prev;
|
2014-09-02 20:03:16 +00:00
|
|
|
|
2014-09-01 19:22:47 +00:00
|
|
|
this.dirty = true;
|
|
|
|
|
2014-09-03 10:12:06 +00:00
|
|
|
return this;
|
|
|
|
|
2014-09-01 19:22:47 +00:00
|
|
|
},
|
|
|
|
|
2014-02-21 14:50:18 +00:00
|
|
|
/**
|
2014-09-04 04:05:30 +00:00
|
|
|
* Copies the area defined by the Rectangle parameter from the source image to this BitmapData at the given location.
|
2014-02-21 14:50:18 +00:00
|
|
|
*
|
2014-09-04 04:05:30 +00:00
|
|
|
* @method Phaser.BitmapData#copyRect
|
|
|
|
* @param {Phaser.Sprite|Phaser.Image|Phaser.Text|Phaser.BitmapData|HTMLImage|string} source - The Image to copy from. If you give a string it will try and find the Image in the Game.Cache.
|
2014-02-21 14:50:18 +00:00
|
|
|
* @param {Phaser.Rectangle} area - The Rectangle region to copy from the source image.
|
2014-05-29 02:30:03 +00:00
|
|
|
* @param {number} x - The destination x coordinate to copy the image to.
|
|
|
|
* @param {number} y - The destination y coordinate to copy the image to.
|
2014-09-03 11:53:07 +00:00
|
|
|
* @param {number} [alpha=1] - The alpha that will be set on the context before drawing. A value between 0 (fully transparent) and 1, opaque.
|
|
|
|
* @param {number} [blendMode=null] - The composite blend mode that will be used when drawing. The default is no blend mode at all.
|
|
|
|
* @param {boolean} [roundPx=false] - Should the x and y values be rounded to integers before drawing? This prevents anti-aliasing in some instances.
|
2014-09-03 10:12:06 +00:00
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
2014-02-21 14:50:18 +00:00
|
|
|
*/
|
2014-09-04 04:05:30 +00:00
|
|
|
copyRect: function (source, area, x, y, alpha, blendMode, roundPx) {
|
2014-02-14 06:04:29 +00:00
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
return this.copy(source, area.x, area.y, area.width, area.height, x, y, area.width, area.height, 0, 0, 0, 1, 1, alpha, blendMode, roundPx);
|
2014-09-03 10:12:06 +00:00
|
|
|
|
2014-02-14 06:04:29 +00:00
|
|
|
},
|
|
|
|
|
2014-02-21 14:50:18 +00:00
|
|
|
/**
|
2014-09-04 04:05:30 +00:00
|
|
|
* Draws the given Phaser.Sprite, Phaser.Image or Phaser.Text to this BitmapData at the coordinates specified.
|
|
|
|
* You can use the optional width and height values to 'stretch' the sprite as it is drawn. This uses drawImage stretching, not scaling.
|
2014-09-03 11:53:07 +00:00
|
|
|
* When drawing it will take into account the Sprites rotation, scale and alpha values.
|
2014-02-21 14:50:18 +00:00
|
|
|
*
|
2014-04-23 22:35:36 +00:00
|
|
|
* @method Phaser.BitmapData#draw
|
2014-09-04 04:05:30 +00:00
|
|
|
* @param {Phaser.Sprite|Phaser.Image|Phaser.Text} source - The Sprite, Image or Text object to draw onto this BitmapData.
|
2014-09-03 11:53:07 +00:00
|
|
|
* @param {number} [x=0] - The x coordinate to translate to before drawing. If not specified it will default to `source.x`.
|
|
|
|
* @param {number} [y=0] - The y coordinate to translate to before drawing. If not specified it will default to `source.y`.
|
|
|
|
* @param {number} [width] - The new width of the Sprite being copied. If not specified it will default to `source.width`.
|
|
|
|
* @param {number} [height] - The new height of the Sprite being copied. If not specified it will default to `source.height`.
|
|
|
|
* @param {number} [blendMode=null] - The composite blend mode that will be used when drawing the Sprite. The default is no blend mode at all.
|
|
|
|
* @param {boolean} [roundPx=false] - Should the x and y values be rounded to integers before drawing? This prevents anti-aliasing in some instances.
|
2014-09-03 10:12:06 +00:00
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
2014-02-21 15:09:04 +00:00
|
|
|
*/
|
2014-09-03 11:53:07 +00:00
|
|
|
draw: function (source, x, y, width, height, blendMode, roundPx) {
|
2014-02-21 15:09:04 +00:00
|
|
|
|
2014-09-03 19:56:31 +00:00
|
|
|
// By specifying null for most parameters it will tell `copy` to use the Sprite values instead, which is what we want here
|
|
|
|
return this.copy(source, null, null, null, null, x, y, width, height, null, null, null, null, null, null, blendMode, roundPx);
|
2014-09-03 10:12:06 +00:00
|
|
|
|
2014-02-21 15:09:04 +00:00
|
|
|
},
|
|
|
|
|
2014-09-30 21:50:08 +00:00
|
|
|
/**
|
|
|
|
* Sets the shadow properties of this BitmapDatas context which will affect all draw operations made to it.
|
|
|
|
* You can cancel an existing shadow by calling this method and passing no parameters.
|
2014-10-01 02:10:13 +00:00
|
|
|
* Note: At the time of writing (October 2014) Chrome still doesn't support shadowBlur used with drawImage.
|
2014-09-30 21:50:08 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#shadow
|
|
|
|
* @param {string} color - The color of the shadow, given in a CSS format, i.e. `#000000` or `rgba(0,0,0,1)`. If `null` or `undefined` the shadow will be reset.
|
|
|
|
* @param {number} [blur=5] - The amount the shadow will be blurred by. Low values = a crisp shadow, high values = a softer shadow.
|
|
|
|
* @param {number} [x=10] - The horizontal offset of the shadow in pixels.
|
|
|
|
* @param {number} [y=10] - The vertical offset of the shadow in pixels.
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
|
|
|
shadow: function (color, blur, x, y) {
|
|
|
|
|
|
|
|
if (typeof color === 'undefined' || color === null)
|
|
|
|
{
|
|
|
|
this.context.shadowColor = 'rgba(0,0,0,0)';
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
this.context.shadowColor = color;
|
|
|
|
this.context.shadowBlur = blur || 5;
|
|
|
|
this.context.shadowOffsetX = x || 10;
|
|
|
|
this.context.shadowOffsetY = y || 10;
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2014-02-21 15:09:04 +00:00
|
|
|
/**
|
2014-09-04 04:05:30 +00:00
|
|
|
* Draws the image onto this BitmapData using an image as an alpha mask.
|
2014-02-21 15:09:04 +00:00
|
|
|
*
|
2014-04-20 20:17:01 +00:00
|
|
|
* @method Phaser.BitmapData#alphaMask
|
2014-09-04 04:05:30 +00:00
|
|
|
* @param {Phaser.Sprite|Phaser.Image|Phaser.Text|Phaser.BitmapData|HTMLImage|HTMLCanvasElement|string} source - The source to copy from. If you give a string it will try and find the Image in the Game.Cache first. This is quite expensive so try to provide the image itself.
|
|
|
|
* @param {Phaser.Sprite|Phaser.Image|Phaser.Text|Phaser.BitmapData|HTMLImage|HTMLCanvasElement|string} [mask] - The object to be used as the mask. If you give a string it will try and find the Image in the Game.Cache first. This is quite expensive so try to provide the image itself. If you don't provide a mask it will use this BitmapData as the mask.
|
2014-09-25 14:28:12 +00:00
|
|
|
* @param {Phaser.Rectangle} [sourceRect] - A Rectangle where x/y define the coordinates to draw the Source image to and width/height define the size.
|
|
|
|
* @param {Phaser.Rectangle} [maskRect] - A Rectangle where x/y define the coordinates to draw the Mask image to and width/height define the size.
|
2014-09-03 10:12:06 +00:00
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
2014-02-21 14:50:18 +00:00
|
|
|
*/
|
2014-09-25 14:28:12 +00:00
|
|
|
alphaMask: function (source, mask, sourceRect, maskRect) {
|
2014-02-21 14:50:18 +00:00
|
|
|
|
2014-09-25 14:28:12 +00:00
|
|
|
if (typeof maskRect === 'undefined' || maskRect === null)
|
|
|
|
{
|
|
|
|
this.draw(mask).blendSourceAtop();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
this.draw(mask, maskRect.x, maskRect.y, maskRect.width, maskRect.height).blendSourceAtop();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (typeof sourceRect === 'undefined' || sourceRect === null)
|
|
|
|
{
|
|
|
|
this.draw(source).blendReset();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
this.draw(source, sourceRect.x, sourceRect.y, sourceRect.width, sourceRect.height).blendReset();
|
|
|
|
}
|
|
|
|
|
|
|
|
return this;
|
2014-09-03 10:12:06 +00:00
|
|
|
|
2014-04-20 20:17:01 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
2014-04-28 04:33:52 +00:00
|
|
|
* Scans this BitmapData for all pixels matching the given r,g,b values and then draws them into the given destination BitmapData.
|
2014-05-24 00:29:47 +00:00
|
|
|
* The original BitmapData remains unchanged.
|
2014-05-24 01:43:59 +00:00
|
|
|
* The destination BitmapData must be large enough to receive all of the pixels that are scanned unless the 'resize' parameter is true.
|
2014-04-28 04:33:52 +00:00
|
|
|
* Although the destination BitmapData is returned from this method, it's actually modified directly in place, meaning this call is perfectly valid:
|
|
|
|
* `picture.extract(mask, r, g, b)`
|
2014-05-24 00:29:47 +00:00
|
|
|
* You can specify optional r2, g2, b2 color values. If given the pixel written to the destination bitmap will be of the r2, g2, b2 color.
|
|
|
|
* If not given it will be written as the same color it was extracted. You can provide one or more alternative colors, allowing you to tint
|
|
|
|
* the color during extraction.
|
2014-04-20 20:17:01 +00:00
|
|
|
*
|
2014-04-28 04:33:52 +00:00
|
|
|
* @method Phaser.BitmapData#extract
|
2014-09-04 15:52:10 +00:00
|
|
|
* @param {Phaser.BitmapData} destination - The BitmapData that the extracted pixels will be drawn to.
|
2014-04-28 04:33:52 +00:00
|
|
|
* @param {number} r - The red color component, in the range 0 - 255.
|
|
|
|
* @param {number} g - The green color component, in the range 0 - 255.
|
|
|
|
* @param {number} b - The blue color component, in the range 0 - 255.
|
2014-05-24 01:43:59 +00:00
|
|
|
* @param {number} [a=255] - The alpha color component, in the range 0 - 255 that the new pixel will be drawn at.
|
|
|
|
* @param {boolean} [resize=false] - Should the destination BitmapData be resized to match this one before the pixels are copied?
|
2014-05-24 00:29:47 +00:00
|
|
|
* @param {number} [r2] - An alternative red color component to be written to the destination, in the range 0 - 255.
|
|
|
|
* @param {number} [g2] - An alternative green color component to be written to the destination, in the range 0 - 255.
|
|
|
|
* @param {number} [b2] - An alternative blue color component to be written to the destination, in the range 0 - 255.
|
2014-04-28 04:33:52 +00:00
|
|
|
* @returns {Phaser.BitmapData} The BitmapData that the extract pixels were drawn on.
|
2014-04-20 20:17:01 +00:00
|
|
|
*/
|
2014-05-24 01:53:48 +00:00
|
|
|
extract: function (destination, r, g, b, a, resize, r2, g2, b2) {
|
2014-04-28 04:33:52 +00:00
|
|
|
|
|
|
|
if (typeof a === 'undefined') { a = 255; }
|
2014-05-24 01:43:59 +00:00
|
|
|
if (typeof resize === 'undefined') { resize = false; }
|
2014-05-24 00:29:47 +00:00
|
|
|
if (typeof r2 === 'undefined') { r2 = r; }
|
|
|
|
if (typeof g2 === 'undefined') { g2 = g; }
|
|
|
|
if (typeof b2 === 'undefined') { b2 = b; }
|
2014-05-24 01:43:59 +00:00
|
|
|
|
|
|
|
if (resize)
|
|
|
|
{
|
|
|
|
destination.resize(this.width, this.height);
|
|
|
|
}
|
2014-04-20 20:17:01 +00:00
|
|
|
|
2014-04-28 04:33:52 +00:00
|
|
|
this.processPixelRGB(
|
2014-05-24 01:43:59 +00:00
|
|
|
function (pixel, x, y)
|
|
|
|
{
|
2014-04-28 04:33:52 +00:00
|
|
|
if (pixel.r === r && pixel.g === g && pixel.b === b)
|
|
|
|
{
|
2014-05-24 01:43:59 +00:00
|
|
|
destination.setPixel32(x, y, r2, g2, b2, a, false);
|
2014-04-28 04:33:52 +00:00
|
|
|
}
|
|
|
|
return false;
|
2014-04-28 12:48:23 +00:00
|
|
|
},
|
|
|
|
this);
|
2014-04-20 20:17:01 +00:00
|
|
|
|
2014-04-28 04:33:52 +00:00
|
|
|
destination.context.putImageData(destination.imageData, 0, 0);
|
|
|
|
destination.dirty = true;
|
2014-04-20 20:17:01 +00:00
|
|
|
|
2014-04-28 04:33:52 +00:00
|
|
|
return destination;
|
2014-04-20 20:17:01 +00:00
|
|
|
|
2014-04-28 03:19:26 +00:00
|
|
|
},
|
|
|
|
|
2014-05-09 15:37:40 +00:00
|
|
|
/**
|
|
|
|
* Draws a filled Rectangle to the BitmapData at the given x, y coordinates and width / height in size.
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#rect
|
|
|
|
* @param {number} x - The x coordinate of the top-left of the Rectangle.
|
|
|
|
* @param {number} y - The y coordinate of the top-left of the Rectangle.
|
|
|
|
* @param {number} width - The width of the Rectangle.
|
|
|
|
* @param {number} height - The height of the Rectangle.
|
|
|
|
* @param {string} [fillStyle] - If set the context fillStyle will be set to this value before the rect is drawn.
|
2014-09-03 10:12:06 +00:00
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
2014-05-09 15:37:40 +00:00
|
|
|
*/
|
|
|
|
rect: function (x, y, width, height, fillStyle) {
|
|
|
|
|
|
|
|
if (typeof fillStyle !== 'undefined')
|
|
|
|
{
|
|
|
|
this.context.fillStyle = fillStyle;
|
|
|
|
}
|
|
|
|
|
|
|
|
this.context.fillRect(x, y, width, height);
|
|
|
|
|
2014-09-03 10:12:06 +00:00
|
|
|
return this;
|
|
|
|
|
2014-05-09 15:37:40 +00:00
|
|
|
},
|
|
|
|
|
2014-04-28 03:19:26 +00:00
|
|
|
/**
|
|
|
|
* Draws a filled Circle to the BitmapData at the given x, y coordinates and radius in size.
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#circle
|
2014-05-07 17:10:13 +00:00
|
|
|
* @param {number} x - The x coordinate to draw the Circle at. This is the center of the circle.
|
|
|
|
* @param {number} y - The y coordinate to draw the Circle at. This is the center of the circle.
|
|
|
|
* @param {number} radius - The radius of the Circle in pixels. The radius is half the diameter.
|
2014-04-28 03:19:26 +00:00
|
|
|
* @param {string} [fillStyle] - If set the context fillStyle will be set to this value before the circle is drawn.
|
2014-09-03 10:12:06 +00:00
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
2014-04-28 03:19:26 +00:00
|
|
|
*/
|
|
|
|
circle: function (x, y, radius, fillStyle) {
|
|
|
|
|
|
|
|
if (typeof fillStyle !== 'undefined')
|
|
|
|
{
|
|
|
|
this.context.fillStyle = fillStyle;
|
|
|
|
}
|
|
|
|
|
|
|
|
this.context.beginPath();
|
|
|
|
this.context.arc(x, y, radius, 0, Math.PI * 2, false);
|
|
|
|
this.context.closePath();
|
|
|
|
|
|
|
|
this.context.fill();
|
|
|
|
|
2014-09-03 10:12:06 +00:00
|
|
|
return this;
|
|
|
|
|
2014-02-21 14:50:18 +00:00
|
|
|
},
|
|
|
|
|
2014-10-03 01:21:09 +00:00
|
|
|
/**
|
|
|
|
* Takes the given Line object and image and renders it to this BitmapData as a repeating texture line.
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#textureLine
|
|
|
|
* @param {Phaser.Line} line - A Phaser.Line object that will be used to plot the start and end of the line.
|
2014-10-09 01:30:31 +00:00
|
|
|
* @param {string|HTMLImage} image - The key of an image in the Phaser.Cache to use as the texture for this line, or an actual Image.
|
2014-10-03 02:57:49 +00:00
|
|
|
* @param {string} [repeat='repeat-x'] - The pattern repeat mode to use when drawing the line. Either `repeat`, `repeat-x` or `no-repeat`.
|
2014-10-03 01:21:09 +00:00
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
2014-10-09 01:30:31 +00:00
|
|
|
textureLine: function (line, image, repeat) {
|
2014-10-03 02:57:49 +00:00
|
|
|
|
|
|
|
if (typeof repeat === 'undefined') { repeat = 'repeat-x'; }
|
2014-10-03 01:21:09 +00:00
|
|
|
|
2014-10-09 01:30:31 +00:00
|
|
|
if (typeof image === 'string')
|
|
|
|
{
|
|
|
|
image = this.game.cache.getImage(image);
|
|
|
|
|
|
|
|
if (!image)
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
var width = line.length;
|
|
|
|
|
|
|
|
if (repeat === 'no-repeat' && width > image.width)
|
|
|
|
{
|
|
|
|
width = image.width;
|
|
|
|
}
|
2014-10-03 01:21:09 +00:00
|
|
|
|
2014-10-03 02:57:49 +00:00
|
|
|
this.context.fillStyle = this.context.createPattern(image, repeat);
|
|
|
|
|
2014-10-03 01:21:09 +00:00
|
|
|
this._circle = new Phaser.Circle(line.start.x, line.start.y, image.height);
|
|
|
|
|
2014-10-03 02:57:49 +00:00
|
|
|
this._circle.circumferencePoint(line.angle - 1.5707963267948966, false, this._pos);
|
2014-10-03 01:21:09 +00:00
|
|
|
|
|
|
|
this.context.save();
|
|
|
|
this.context.translate(this._pos.x, this._pos.y);
|
|
|
|
this.context.rotate(line.angle);
|
2014-10-09 01:30:31 +00:00
|
|
|
this.context.fillRect(0, 0, width, image.height);
|
2014-10-03 01:21:09 +00:00
|
|
|
this.context.restore();
|
|
|
|
|
|
|
|
this.dirty = true;
|
|
|
|
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2013-11-25 03:13:04 +00:00
|
|
|
/**
|
|
|
|
* If the game is running in WebGL this will push the texture up to the GPU if it's dirty.
|
|
|
|
* This is called automatically if the BitmapData is being used by a Sprite, otherwise you need to remember to call it in your render function.
|
2014-04-24 02:49:49 +00:00
|
|
|
* If you wish to suppress this functionality set BitmapData.disableTextureUpload to `true`.
|
2014-02-21 14:50:18 +00:00
|
|
|
*
|
2013-11-28 15:57:09 +00:00
|
|
|
* @method Phaser.BitmapData#render
|
2014-09-04 15:52:10 +00:00
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
2013-11-25 03:13:04 +00:00
|
|
|
*/
|
|
|
|
render: function () {
|
|
|
|
|
2014-10-13 11:20:25 +00:00
|
|
|
if (!this.disableTextureUpload && this.dirty)
|
2013-11-25 03:13:04 +00:00
|
|
|
{
|
2014-10-13 11:20:25 +00:00
|
|
|
this.baseTexture.dirty();
|
2014-03-21 18:04:24 +00:00
|
|
|
this.dirty = false;
|
2013-11-25 03:13:04 +00:00
|
|
|
}
|
|
|
|
|
2014-09-04 15:52:10 +00:00
|
|
|
return this;
|
|
|
|
|
2014-09-03 10:12:06 +00:00
|
|
|
},
|
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
/**
|
|
|
|
* Resets the blend mode (effectively sets it to 'source-over')
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendReset
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
2014-09-03 10:12:06 +00:00
|
|
|
blendReset: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'source-over';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'source-over'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendSourceOver
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
2014-09-03 10:12:06 +00:00
|
|
|
blendSourceOver: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'source-over';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'source-in'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendSourceIn
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
|
|
|
blendSourceIn: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'source-in';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'source-out'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendSourceOut
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
|
|
|
blendSourceOut: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'source-out';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'source-atop'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendSourceAtop
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
|
|
|
blendSourceAtop: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'source-atop';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'destination-over'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendDestinationOver
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
|
|
|
blendDestinationOver: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'destination-over';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'destination-in'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendDestinationIn
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
|
|
|
blendDestinationIn: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'destination-in';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'destination-out'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendDestinationOut
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
|
|
|
blendDestinationOut: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'destination-out';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'destination-atop'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendDestinationAtop
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
|
|
|
blendDestinationAtop: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'destination-atop';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'xor'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendXor
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
|
|
|
blendXor: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'xor';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'lighter'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendAdd
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
2014-09-03 10:12:06 +00:00
|
|
|
blendAdd: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'lighter';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'multiply'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendMultiply
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
2014-09-03 10:12:06 +00:00
|
|
|
blendMultiply: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'multiply';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'screen'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendScreen
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
2014-09-03 10:12:06 +00:00
|
|
|
blendScreen: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'screen';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'overlay'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendOverlay
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
2014-09-03 10:12:06 +00:00
|
|
|
blendOverlay: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'overlay';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'darken'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendDarken
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
2014-09-03 10:12:06 +00:00
|
|
|
blendDarken: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'darken';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'lighten'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendLighten
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
2014-09-03 10:12:06 +00:00
|
|
|
blendLighten: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'lighten';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'color-dodge'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendColorDodge
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
2014-09-03 10:12:06 +00:00
|
|
|
blendColorDodge: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'color-dodge';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'color-burn'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendColorBurn
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
2014-09-03 10:12:06 +00:00
|
|
|
blendColorBurn: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'color-burn';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'hard-light'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendHardLight
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
2014-09-03 10:12:06 +00:00
|
|
|
blendHardLight: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'hard-light';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'soft-light'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendSoftLight
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
2014-09-03 10:12:06 +00:00
|
|
|
blendSoftLight: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'soft-light';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'difference'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendDifference
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
2014-09-03 10:12:06 +00:00
|
|
|
blendDifference: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'difference';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'exclusion'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendExclusion
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
2014-09-03 10:12:06 +00:00
|
|
|
blendExclusion: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'exclusion';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'hue'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendHue
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
2014-09-03 10:12:06 +00:00
|
|
|
blendHue: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'hue';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'saturation'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendSaturation
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
2014-09-03 10:12:06 +00:00
|
|
|
blendSaturation: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'saturation';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'color'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendColor
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
2014-09-03 10:12:06 +00:00
|
|
|
blendColor: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'color';
|
|
|
|
return this;
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2014-09-04 04:05:30 +00:00
|
|
|
/**
|
|
|
|
* Sets the blend mode to 'luminosity'
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData#blendLuminosity
|
|
|
|
* @return {Phaser.BitmapData} This BitmapData object for method chaining.
|
|
|
|
*/
|
2014-09-03 10:12:06 +00:00
|
|
|
blendLuminosity: function () {
|
|
|
|
|
|
|
|
this.context.globalCompositeOperation = 'luminosity';
|
|
|
|
return this;
|
|
|
|
|
2014-09-03 19:56:31 +00:00
|
|
|
}
|
2013-11-13 20:57:09 +00:00
|
|
|
|
2013-12-30 16:54:00 +00:00
|
|
|
};
|
|
|
|
|
2014-09-03 19:56:31 +00:00
|
|
|
/**
|
|
|
|
* @name Phaser.Sprite#smoothed
|
|
|
|
* @property {boolean} smoothed - Gets or sets this BitmapData.contexts smoothing enabled value.
|
|
|
|
*/
|
|
|
|
Object.defineProperty(Phaser.BitmapData.prototype, "smoothed", {
|
|
|
|
|
|
|
|
get: function () {
|
|
|
|
|
|
|
|
Phaser.Canvas.getSmoothingEnabled(this.context);
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
set: function (value) {
|
|
|
|
|
|
|
|
Phaser.Canvas.setSmoothingEnabled(this.context, value);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|
|
|
|
|
2014-09-02 20:03:16 +00:00
|
|
|
/**
|
|
|
|
* Gets a JavaScript object that has 6 properties set that are used by BitmapData in a transform.
|
|
|
|
*
|
|
|
|
* @method Phaser.BitmapData.getTransform
|
|
|
|
* @param {number} translateX - The x translate value.
|
|
|
|
* @param {number} translateY - The y translate value.
|
|
|
|
* @param {number} scaleX - The scale x value.
|
|
|
|
* @param {number} scaleY - The scale y value.
|
|
|
|
* @param {number} skewX - The skew x value.
|
|
|
|
* @param {number} skewY - The skew y value.
|
|
|
|
* @return {Object} A JavaScript object containing all of the properties BitmapData needs for transforms.
|
|
|
|
*/
|
|
|
|
Phaser.BitmapData.getTransform = function (translateX, translateY, scaleX, scaleY, skewX, skewY) {
|
|
|
|
|
|
|
|
if (typeof translateX !== 'number') { translateX = 0; }
|
|
|
|
if (typeof translateY !== 'number') { translateY = 0; }
|
|
|
|
if (typeof scaleX !== 'number') { scaleX = 1; }
|
|
|
|
if (typeof scaleY !== 'number') { scaleY = 1; }
|
|
|
|
if (typeof skewX !== 'number') { skewX = 0; }
|
|
|
|
if (typeof skewY !== 'number') { skewY = 0; }
|
|
|
|
|
|
|
|
return { sx: scaleX, sy: scaleY, scaleX: scaleX, scaleY: scaleY, skewX: skewX, skewY: skewY, translateX: translateX, translateY: translateY, tx: translateX, ty: translateY };
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2013-12-30 16:54:00 +00:00
|
|
|
Phaser.BitmapData.prototype.constructor = Phaser.BitmapData;
|