2018-02-12 16:01:20 +00:00
|
|
|
/**
|
|
|
|
* @author Richard Davey <rich@photonstorm.com>
|
|
|
|
* @copyright 2018 Photon Storm Ltd.
|
|
|
|
* @license {@link https://github.com/photonstorm/phaser/blob/master/license.txt|MIT License}
|
|
|
|
*/
|
|
|
|
|
2017-02-23 03:10:48 +00:00
|
|
|
// bitmask flag for GameObject.renderMask
|
|
|
|
var _FLAG = 8; // 1000
|
2017-02-21 01:04:11 +00:00
|
|
|
|
2018-02-01 01:09:34 +00:00
|
|
|
/**
|
|
|
|
* Provides methods used for getting and setting the texture of a Game Object.
|
2018-03-20 14:56:31 +00:00
|
|
|
*
|
2018-02-01 01:09:34 +00:00
|
|
|
* @name Phaser.GameObjects.Components.Texture
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
|
|
|
|
2017-02-23 03:10:48 +00:00
|
|
|
var Texture = {
|
2017-02-21 01:04:11 +00:00
|
|
|
|
2018-02-01 01:09:34 +00:00
|
|
|
/**
|
|
|
|
* The Texture this Game Object is using to render with.
|
2018-03-20 14:56:31 +00:00
|
|
|
*
|
2018-02-01 01:09:34 +00:00
|
|
|
* @name Phaser.GameObjects.Components.Texture#texture
|
2018-04-23 22:39:24 +00:00
|
|
|
* @type {Phaser.Textures.Texture|Phaser.Textures.CanvasTexture}
|
2018-02-01 01:09:34 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-02-23 03:10:48 +00:00
|
|
|
texture: null,
|
2018-02-01 01:09:34 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The Texture Frame this Game Object is using to render with.
|
2018-03-20 14:56:31 +00:00
|
|
|
*
|
2018-02-01 01:09:34 +00:00
|
|
|
* @name Phaser.GameObjects.Components.Texture#frame
|
|
|
|
* @type {Phaser.Textures.Frame}
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-02-23 03:10:48 +00:00
|
|
|
frame: null,
|
|
|
|
|
2018-07-03 15:48:01 +00:00
|
|
|
/**
|
|
|
|
* A boolean flag indicating if this Game Object is being cropped or not.
|
|
|
|
* You can toggle this at any time after `setCrop` has been called, to turn cropping on or off.
|
|
|
|
* Equally, calling `setCrop` with no arguments will reset the crop and disable it.
|
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.Components.Texture#isCropped
|
|
|
|
* @type {boolean}
|
|
|
|
* @since 3.11.0
|
|
|
|
*/
|
|
|
|
isCropped: false,
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The internal crop data object, as used by `setCrop` and passed to the `Frame.getCropUVs` method.
|
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.Components.Texture#isCropped
|
|
|
|
* @type {object}
|
|
|
|
* @private
|
|
|
|
* @since 3.11.0
|
|
|
|
*/
|
2018-07-04 14:18:08 +00:00
|
|
|
_crop: { u0: 0, v0: 0, u1: 0, v1: 0, width: 0, height: 0, x: 0, y: 0, flipX: false, flipY: false },
|
2018-07-03 15:48:01 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Applies a crop to a texture based Game Object, such as a Sprite or Image.
|
|
|
|
*
|
|
|
|
* The crop is a rectangle that limits the area of the texture frame that is visible during rendering.
|
|
|
|
*
|
|
|
|
* Cropping a Game Object does not change its size, dimensions, physics body or hit area, it just
|
|
|
|
* changes what is shown when rendered.
|
|
|
|
*
|
|
|
|
* The crop coordinates are relative to the texture frame, not the Game Object, meaning 0 x 0 is the top-left.
|
|
|
|
*
|
|
|
|
* Therefore, if you had a Game Object that had an 800x600 sized texture, and you wanted to show only the left
|
|
|
|
* half of it, you could call `setCrop(0, 0, 400, 600)`.
|
|
|
|
*
|
|
|
|
* Call this method with no arguments to reset the crop, or toggle the property `isCropped` to `false`.
|
|
|
|
*
|
|
|
|
* You should do this if the crop rectangle becomes the same size as the frame itself, as it will allow
|
|
|
|
* the renderer to skip several internal calculations.
|
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Components.Texture#setCrop
|
|
|
|
* @since 3.11.0
|
|
|
|
*
|
|
|
|
* @param {number} [x] - The x coordinate to start the crop from.
|
|
|
|
* @param {number} [y] - The y coordinate to start the crop from.
|
|
|
|
* @param {number} [width] - The width of the crop rectangle in pixels.
|
|
|
|
* @param {number} [height] - The height of the crop rectangle in pixels.
|
|
|
|
*
|
|
|
|
* @return {this} This Game Object instance.
|
|
|
|
*/
|
|
|
|
setCrop: function (x, y, width, height)
|
|
|
|
{
|
|
|
|
if (x === undefined)
|
|
|
|
{
|
|
|
|
this.isCropped = false;
|
|
|
|
}
|
|
|
|
else if (this.frame)
|
|
|
|
{
|
2018-07-04 14:18:08 +00:00
|
|
|
this.frame.setCropUVs(this._crop, x, y, width, height, this.flipX, this.flipY);
|
2018-07-03 15:48:01 +00:00
|
|
|
|
|
|
|
this.isCropped = true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-02-01 01:09:34 +00:00
|
|
|
/**
|
|
|
|
* Sets the texture and frame this Game Object will use to render with.
|
|
|
|
*
|
|
|
|
* Textures are referenced by their string-based keys, as stored in the Texture Manager.
|
2018-03-20 14:56:31 +00:00
|
|
|
*
|
2018-02-01 01:36:52 +00:00
|
|
|
* @method Phaser.GameObjects.Components.Texture#setTexture
|
2018-02-01 01:09:34 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*
|
|
|
|
* @param {string} key - The key of the texture to be used, as stored in the Texture Manager.
|
2018-03-20 14:56:31 +00:00
|
|
|
* @param {(string|integer)} [frame] - The name or index of the frame within the Texture.
|
|
|
|
*
|
2018-05-22 08:08:44 +00:00
|
|
|
* @return {this} This Game Object instance.
|
2018-02-01 01:09:34 +00:00
|
|
|
*/
|
2017-02-23 03:10:48 +00:00
|
|
|
setTexture: function (key, frame)
|
|
|
|
{
|
2017-07-14 13:30:20 +00:00
|
|
|
this.texture = this.scene.sys.textures.get(key);
|
2017-02-23 03:10:48 +00:00
|
|
|
|
2017-08-14 12:12:45 +00:00
|
|
|
return this.setFrame(frame);
|
|
|
|
},
|
|
|
|
|
2018-02-01 01:09:34 +00:00
|
|
|
/**
|
|
|
|
* Sets the frame this Game Object will use to render with.
|
|
|
|
*
|
|
|
|
* The Frame has to belong to the current Texture being used.
|
|
|
|
*
|
|
|
|
* It can be either a string or an index.
|
2018-03-02 16:23:43 +00:00
|
|
|
*
|
|
|
|
* Calling `setFrame` will modify the `width` and `height` properties of your Game Object.
|
|
|
|
* It will also change the `origin` if the Frame has a custom pivot point, as exported from packages like Texture Packer.
|
2018-03-20 14:56:31 +00:00
|
|
|
*
|
2018-02-01 01:36:52 +00:00
|
|
|
* @method Phaser.GameObjects.Components.Texture#setFrame
|
2018-02-01 01:09:34 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-03-20 14:56:31 +00:00
|
|
|
* @param {(string|integer)} frame - The name or index of the frame within the Texture.
|
2018-03-12 14:45:18 +00:00
|
|
|
* @param {boolean} [updateSize=true] - Should this call adjust the size of the Game Object?
|
|
|
|
* @param {boolean} [updateOrigin=true] - Should this call adjust the origin of the Game Object?
|
2018-03-20 14:56:31 +00:00
|
|
|
*
|
2018-05-22 04:46:26 +00:00
|
|
|
* @return {this} This Game Object instance.
|
2018-02-01 01:09:34 +00:00
|
|
|
*/
|
2018-03-12 14:45:18 +00:00
|
|
|
setFrame: function (frame, updateSize, updateOrigin)
|
2017-08-14 12:12:45 +00:00
|
|
|
{
|
2018-03-12 14:45:18 +00:00
|
|
|
if (updateSize === undefined) { updateSize = true; }
|
|
|
|
if (updateOrigin === undefined) { updateOrigin = true; }
|
|
|
|
|
2017-02-23 03:10:48 +00:00
|
|
|
this.frame = this.texture.get(frame);
|
2017-02-21 01:04:11 +00:00
|
|
|
|
2017-02-23 03:10:48 +00:00
|
|
|
if (!this.frame.cutWidth || !this.frame.cutHeight)
|
|
|
|
{
|
|
|
|
this.renderFlags &= ~_FLAG;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
this.renderFlags |= _FLAG;
|
|
|
|
}
|
2017-03-02 02:05:33 +00:00
|
|
|
|
2018-03-12 14:45:18 +00:00
|
|
|
if (this._sizeComponent && updateSize)
|
2018-03-02 16:23:43 +00:00
|
|
|
{
|
|
|
|
this.setSizeToFrame();
|
|
|
|
}
|
|
|
|
|
2018-03-12 14:45:18 +00:00
|
|
|
if (this._originComponent && updateOrigin)
|
2018-02-09 15:21:39 +00:00
|
|
|
{
|
2018-03-02 16:23:43 +00:00
|
|
|
if (this.frame.customPivot)
|
|
|
|
{
|
|
|
|
this.setOrigin(this.frame.pivotX, this.frame.pivotY);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
this.updateDisplayOrigin();
|
|
|
|
}
|
2018-02-09 15:21:39 +00:00
|
|
|
}
|
|
|
|
|
2018-07-04 14:18:08 +00:00
|
|
|
if (this.isCropped)
|
|
|
|
{
|
|
|
|
this.frame.updateCropUVs(this._crop, this.flipX, this.flipY);
|
|
|
|
}
|
|
|
|
|
2017-03-02 02:05:33 +00:00
|
|
|
return this;
|
2017-02-23 03:10:48 +00:00
|
|
|
}
|
2017-02-21 01:04:11 +00:00
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
module.exports = Texture;
|