2022-12-02 18:07:20 +00:00
|
|
|
/**
|
|
|
|
* @author Richard Davey <rich@photonstorm.com>
|
|
|
|
* @copyright 2022 Photon Storm Ltd.
|
|
|
|
* @license {@link https://opensource.org/licenses/MIT|MIT License}
|
|
|
|
*/
|
|
|
|
|
|
|
|
var NineSlice = require('./NineSlice');
|
|
|
|
var GameObjectFactory = require('../GameObjectFactory');
|
|
|
|
|
|
|
|
/**
|
2022-12-08 22:44:19 +00:00
|
|
|
* A Nine Slice Game Object allows you to display a texture-based object that
|
|
|
|
* can be stretched both horizontally and vertically, but that retains
|
|
|
|
* fixed-sized corners. The dimensions of the corners are set via the
|
|
|
|
* parameters to this class.
|
2022-12-02 18:07:20 +00:00
|
|
|
*
|
2022-12-08 22:44:19 +00:00
|
|
|
* This is extremely useful for UI and button like elements, where you need
|
|
|
|
* them to expand to accomodate the content without distorting the texture.
|
2022-12-02 18:07:20 +00:00
|
|
|
*
|
2022-12-08 22:44:19 +00:00
|
|
|
* The texture you provide for this Game Object should be based on the
|
|
|
|
* following layout structure:
|
2022-12-07 18:28:51 +00:00
|
|
|
*
|
2022-12-08 22:44:19 +00:00
|
|
|
* ```
|
2022-12-07 18:28:51 +00:00
|
|
|
* A B
|
|
|
|
* +---+----------------------+---+
|
|
|
|
* C | 1 | 2 | 3 |
|
|
|
|
* +---+----------------------+---+
|
|
|
|
* | | | |
|
|
|
|
* | 4 | 5 | 6 |
|
|
|
|
* | | | |
|
|
|
|
* +---+----------------------+---+
|
|
|
|
* D | 7 | 8 | 9 |
|
|
|
|
* +---+----------------------+---+
|
2022-12-08 22:44:19 +00:00
|
|
|
* ```
|
2022-12-07 18:28:51 +00:00
|
|
|
*
|
2022-12-08 22:44:19 +00:00
|
|
|
* When changing this objects width and / or height:
|
2022-12-07 18:28:51 +00:00
|
|
|
*
|
2022-12-08 22:44:19 +00:00
|
|
|
* areas 1, 3, 7 and 9 (the corners) will remain unscaled
|
|
|
|
* areas 2 and 8 will be stretched horizontally only
|
|
|
|
* areas 4 and 6 will be stretched vertically only
|
2022-12-07 18:28:51 +00:00
|
|
|
* area 5 will be stretched both horizontally and vertically
|
|
|
|
*
|
2022-12-08 22:44:19 +00:00
|
|
|
* You can also create a 3 slice Game Object:
|
2022-12-07 18:28:51 +00:00
|
|
|
*
|
|
|
|
* This works in a similar way, except you can only stretch it horizontally.
|
|
|
|
* Therefore, it requires less configuration:
|
|
|
|
*
|
2022-12-08 22:44:19 +00:00
|
|
|
* ```
|
2022-12-07 18:28:51 +00:00
|
|
|
* A B
|
|
|
|
* +---+----------------------+---+
|
|
|
|
* | | | |
|
|
|
|
* C | 1 | 2 | 3 |
|
|
|
|
* | | | |
|
|
|
|
* +---+----------------------+---+
|
2022-12-08 22:44:19 +00:00
|
|
|
* ```
|
2022-12-07 18:28:51 +00:00
|
|
|
*
|
2022-12-08 22:44:19 +00:00
|
|
|
* When changing this objects width (you cannot change its height)
|
2022-12-07 18:28:51 +00:00
|
|
|
*
|
2022-12-08 22:44:19 +00:00
|
|
|
* areas 1 and 3 will remain unscaled
|
2022-12-07 18:28:51 +00:00
|
|
|
* area 2 will be stretched horizontally
|
|
|
|
*
|
2022-12-09 18:17:26 +00:00
|
|
|
* The above configuration concept is adapted from the Pixi NineSlicePlane.
|
2022-12-08 22:44:19 +00:00
|
|
|
*
|
|
|
|
* To specify a 3 slice object instead of a 9 slice you should only
|
|
|
|
* provide the `leftWidth` and `rightWidth` parameters. To create a 9 slice
|
|
|
|
* you must supply all parameters.
|
|
|
|
*
|
|
|
|
* The _minimum_ width this Game Object can be is the total of
|
|
|
|
* `leftWidth` + `rightWidth`. The _minimum_ height this Game Object
|
|
|
|
* can be is the total of `topHeight` + `bottomHeight`.
|
|
|
|
* If you need to display this object at a smaller size, you can scale it.
|
|
|
|
*
|
|
|
|
* In terms of performance, using a 3 slice Game Object is the equivalent of
|
|
|
|
* having 3 Sprites in a row. Using a 9 slice Game Object is the equivalent
|
|
|
|
* of having 9 Sprites in a row. The vertices of this object are all batched
|
|
|
|
* together and can co-exist with other Sprites and graphics on the display
|
|
|
|
* list, without incurring any additional overhead.
|
|
|
|
*
|
|
|
|
* As of Phaser 3.60 this Game Object is WebGL only.
|
2022-12-07 18:28:51 +00:00
|
|
|
*
|
2022-12-02 18:07:20 +00:00
|
|
|
* @method Phaser.GameObjects.GameObjectFactory#nineslice
|
|
|
|
* @webglOnly
|
|
|
|
* @since 3.60.0
|
|
|
|
*
|
2022-12-08 22:44:19 +00:00
|
|
|
* @param {number} x - The horizontal position of the center of this Game Object in the world.
|
|
|
|
* @param {number} y - The vertical position of the center of this Game Object in the world.
|
|
|
|
* @param {(string|Phaser.Textures.Texture)} texture - The key, or instance of the Texture this Game Object will use to render with, as stored in the Texture Manager.
|
|
|
|
* @param {(string|number)} [frame] - An optional frame from the Texture this Game Object is rendering with.
|
|
|
|
* @param {number} [width=256] - The width of the Nine Slice Game Object. You can adjust the width post-creation.
|
|
|
|
* @param {number} [height=256] - The height of the Nine Slice Game Object. If this is a 3 slice object the height will be fixed to the height of the texture and cannot be changed.
|
|
|
|
* @param {number} [leftWidth=10] - The size of the left vertical column (A).
|
|
|
|
* @param {number} [rightWidth=10] - The size of the right vertical column (B).
|
|
|
|
* @param {number} [topHeight=0] - The size of the top horiztonal row (C). Set to zero or undefined to create a 3 slice object.
|
|
|
|
* @param {number} [bottomHeight=0] - The size of the bottom horiztonal row (D). Set to zero or undefined to create a 3 slice object.
|
2022-12-02 18:07:20 +00:00
|
|
|
*
|
|
|
|
* @return {Phaser.GameObjects.NineSlice} The Game Object that was created.
|
|
|
|
*/
|
|
|
|
if (typeof WEBGL_RENDERER)
|
|
|
|
{
|
2022-12-07 18:28:51 +00:00
|
|
|
GameObjectFactory.register('nineslice', function (x, y, texture, frame, width, height, leftWidth, rightWidth, topHeight, bottomHeight)
|
2022-12-02 18:07:20 +00:00
|
|
|
{
|
2022-12-07 18:28:51 +00:00
|
|
|
return this.displayList.add(new NineSlice(this.scene, x, y, texture, frame, width, height, leftWidth, rightWidth, topHeight, bottomHeight));
|
2022-12-02 18:07:20 +00:00
|
|
|
});
|
|
|
|
}
|