2018-02-12 16:01:20 +00:00
|
|
|
/**
|
|
|
|
* @author Richard Davey <rich@photonstorm.com>
|
2020-01-15 12:07:09 +00:00
|
|
|
* @copyright 2020 Photon Storm Ltd.
|
2019-05-10 15:15:04 +00:00
|
|
|
* @license {@link https://opensource.org/licenses/MIT|MIT License}
|
2018-02-12 16:01:20 +00:00
|
|
|
*/
|
|
|
|
|
2020-10-13 10:04:46 +00:00
|
|
|
var AddToDOM = require('../../dom/AddToDOM');
|
|
|
|
var CanvasPool = require('../../display/canvas/CanvasPool');
|
|
|
|
var Class = require('../../utils/Class');
|
|
|
|
var Components = require('../components');
|
|
|
|
var GameEvents = require('../../core/events');
|
|
|
|
var GameObject = require('../GameObject');
|
|
|
|
var GetTextSize = require('./GetTextSize');
|
|
|
|
var GetValue = require('../../utils/object/GetValue');
|
|
|
|
var RemoveFromDOM = require('../../dom/RemoveFromDOM');
|
2017-03-13 23:38:48 +00:00
|
|
|
var TextRender = require('./TextRender');
|
2020-10-13 10:04:46 +00:00
|
|
|
var TextStyle = require('./TextStyle');
|
2017-03-13 23:38:48 +00:00
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-02-07 15:27:21 +00:00
|
|
|
* @classdesc
|
2018-09-15 09:31:10 +00:00
|
|
|
* A Text Game Object.
|
2020-09-12 10:55:06 +00:00
|
|
|
*
|
2018-09-15 09:31:10 +00:00
|
|
|
* Text objects work by creating their own internal hidden Canvas and then renders text to it using
|
|
|
|
* the standard Canvas `fillText` API. It then creates a texture from this canvas which is rendered
|
|
|
|
* to your game during the render pass.
|
2020-09-12 10:55:06 +00:00
|
|
|
*
|
2018-09-15 09:31:10 +00:00
|
|
|
* Because it uses the Canvas API you can take advantage of all the features this offers, such as
|
|
|
|
* applying gradient fills to the text, or strokes, shadows and more. You can also use custom fonts
|
|
|
|
* loaded externally, such as Google or TypeKit Web fonts.
|
2020-04-04 17:56:52 +00:00
|
|
|
*
|
|
|
|
* **Important:** The font name must be quoted if it contains certain combinations of digits or
|
|
|
|
* special characters, either when creating the Text object, or when setting the font via `setFont`
|
|
|
|
* or `setFontFamily`, e.g.:
|
|
|
|
*
|
2019-01-22 14:02:25 +00:00
|
|
|
* ```javascript
|
2020-04-04 17:56:52 +00:00
|
|
|
* this.add.text(0, 0, 'Hello World', { fontFamily: 'Georgia, "Goudy Bookletter 1911", Times, serif' });
|
2019-01-22 14:02:25 +00:00
|
|
|
* ```
|
2020-04-04 17:56:52 +00:00
|
|
|
*
|
2019-01-22 14:02:25 +00:00
|
|
|
* ```javascript
|
2020-04-04 17:56:52 +00:00
|
|
|
* this.add.text(0, 0, 'Hello World', { font: '"Press Start 2P"' });
|
2019-01-22 14:02:25 +00:00
|
|
|
* ```
|
2018-09-15 09:31:10 +00:00
|
|
|
*
|
|
|
|
* You can only display fonts that are currently loaded and available to the browser: therefore fonts must
|
|
|
|
* be pre-loaded. Phaser does not do ths for you, so you will require the use of a 3rd party font loader,
|
|
|
|
* or have the fonts ready available in the CSS on the page in which your Phaser game resides.
|
|
|
|
*
|
|
|
|
* See {@link http://www.jordanm.co.uk/tinytype this compatibility table} for the available default fonts
|
|
|
|
* across mobile browsers.
|
2020-09-12 10:55:06 +00:00
|
|
|
*
|
2018-09-15 09:31:10 +00:00
|
|
|
* A note on performance: Every time the contents of a Text object changes, i.e. changing the text being
|
|
|
|
* displayed, or the style of the text, it needs to remake the Text canvas, and if on WebGL, re-upload the
|
|
|
|
* new texture to the GPU. This can be an expensive operation if used often, or with large quantities of
|
|
|
|
* Text objects in your game. If you run into performance issues you would be better off using Bitmap Text
|
|
|
|
* instead, as it benefits from batching and avoids expensive Canvas API calls.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @class Text
|
|
|
|
* @extends Phaser.GameObjects.GameObject
|
2018-10-10 09:49:13 +00:00
|
|
|
* @memberof Phaser.GameObjects
|
2018-02-07 00:18:22 +00:00
|
|
|
* @constructor
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
|
|
|
* @extends Phaser.GameObjects.Components.Alpha
|
|
|
|
* @extends Phaser.GameObjects.Components.BlendMode
|
2018-03-20 19:00:48 +00:00
|
|
|
* @extends Phaser.GameObjects.Components.ComputedSize
|
2018-08-03 18:07:12 +00:00
|
|
|
* @extends Phaser.GameObjects.Components.Crop
|
2018-02-07 00:18:22 +00:00
|
|
|
* @extends Phaser.GameObjects.Components.Depth
|
|
|
|
* @extends Phaser.GameObjects.Components.Flip
|
2021-10-16 14:23:19 +00:00
|
|
|
* @extends Phaser.GameObjects.Components.FX
|
2018-02-07 00:18:22 +00:00
|
|
|
* @extends Phaser.GameObjects.Components.GetBounds
|
2018-04-20 17:57:49 +00:00
|
|
|
* @extends Phaser.GameObjects.Components.Mask
|
2018-02-07 00:18:22 +00:00
|
|
|
* @extends Phaser.GameObjects.Components.Origin
|
|
|
|
* @extends Phaser.GameObjects.Components.Pipeline
|
|
|
|
* @extends Phaser.GameObjects.Components.ScrollFactor
|
|
|
|
* @extends Phaser.GameObjects.Components.Tint
|
|
|
|
* @extends Phaser.GameObjects.Components.Transform
|
|
|
|
* @extends Phaser.GameObjects.Components.Visible
|
|
|
|
*
|
|
|
|
* @param {Phaser.Scene} scene - The Scene to which this Game Object belongs. A Game Object can only belong to one Scene at a time.
|
|
|
|
* @param {number} x - The horizontal position of this Game Object in the world.
|
|
|
|
* @param {number} y - The vertical position of this Game Object in the world.
|
2018-03-20 14:56:31 +00:00
|
|
|
* @param {(string|string[])} text - The text this Text object will display.
|
2019-07-02 11:32:18 +00:00
|
|
|
* @param {Phaser.Types.GameObjects.Text.TextStyle} style - The text style configuration object.
|
2020-04-04 17:56:52 +00:00
|
|
|
*
|
|
|
|
* @see https://developer.mozilla.org/en-US/docs/Web/CSS/font-family#Valid_family_names
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-03-13 23:38:48 +00:00
|
|
|
var Text = new Class({
|
|
|
|
|
2017-04-05 01:10:48 +00:00
|
|
|
Extends: GameObject,
|
|
|
|
|
2017-03-13 23:38:48 +00:00
|
|
|
Mixins: [
|
|
|
|
Components.Alpha,
|
|
|
|
Components.BlendMode,
|
2018-03-20 19:00:48 +00:00
|
|
|
Components.ComputedSize,
|
2018-08-03 18:07:12 +00:00
|
|
|
Components.Crop,
|
2018-02-01 00:50:15 +00:00
|
|
|
Components.Depth,
|
2017-07-04 11:01:27 +00:00
|
|
|
Components.Flip,
|
2021-10-16 14:23:19 +00:00
|
|
|
Components.FX,
|
2017-03-13 23:38:48 +00:00
|
|
|
Components.GetBounds,
|
2018-04-20 17:57:49 +00:00
|
|
|
Components.Mask,
|
2017-03-13 23:38:48 +00:00
|
|
|
Components.Origin,
|
2018-01-29 21:46:48 +00:00
|
|
|
Components.Pipeline,
|
2017-07-04 11:01:27 +00:00
|
|
|
Components.ScrollFactor,
|
|
|
|
Components.Tint,
|
2017-03-13 23:38:48 +00:00
|
|
|
Components.Transform,
|
|
|
|
Components.Visible,
|
|
|
|
TextRender
|
|
|
|
],
|
|
|
|
|
|
|
|
initialize:
|
|
|
|
|
2017-07-14 13:30:20 +00:00
|
|
|
function Text (scene, x, y, text, style)
|
2017-03-13 23:38:48 +00:00
|
|
|
{
|
2017-03-15 01:07:58 +00:00
|
|
|
if (x === undefined) { x = 0; }
|
|
|
|
if (y === undefined) { y = 0; }
|
|
|
|
|
2017-07-14 13:30:20 +00:00
|
|
|
GameObject.call(this, scene, 'Text');
|
2017-03-13 23:38:48 +00:00
|
|
|
|
2018-08-03 18:07:12 +00:00
|
|
|
/**
|
|
|
|
* The renderer in use by this Text object.
|
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.Text#renderer
|
|
|
|
* @type {(Phaser.Renderer.Canvas.CanvasRenderer|Phaser.Renderer.WebGL.WebGLRenderer)}
|
|
|
|
* @since 3.12.0
|
|
|
|
*/
|
2020-10-27 13:55:27 +00:00
|
|
|
this.renderer = scene.sys.renderer;
|
2018-08-03 18:07:12 +00:00
|
|
|
|
2017-03-13 23:38:48 +00:00
|
|
|
this.setPosition(x, y);
|
2017-03-20 16:28:09 +00:00
|
|
|
this.setOrigin(0, 0);
|
2018-09-05 10:19:02 +00:00
|
|
|
this.initPipeline();
|
2017-03-13 23:38:48 +00:00
|
|
|
|
2017-03-15 01:07:58 +00:00
|
|
|
/**
|
2018-02-07 00:18:22 +00:00
|
|
|
* The canvas element that the text is rendered to.
|
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.Text#canvas
|
|
|
|
* @type {HTMLCanvasElement}
|
|
|
|
* @since 3.0.0
|
2017-03-15 01:07:58 +00:00
|
|
|
*/
|
|
|
|
this.canvas = CanvasPool.create(this);
|
|
|
|
|
|
|
|
/**
|
2018-02-07 00:18:22 +00:00
|
|
|
* The context of the canvas element that the text is rendered to.
|
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.Text#context
|
|
|
|
* @type {CanvasRenderingContext2D}
|
|
|
|
* @since 3.0.0
|
2017-03-15 01:07:58 +00:00
|
|
|
*/
|
|
|
|
this.context = this.canvas.getContext('2d');
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* The Text Style object.
|
|
|
|
*
|
|
|
|
* Manages the style of this Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.Text#style
|
2019-01-31 14:47:50 +00:00
|
|
|
* @type {Phaser.GameObjects.TextStyle}
|
2018-02-07 00:18:22 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-03-15 01:07:58 +00:00
|
|
|
this.style = new TextStyle(this, style);
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* Whether to automatically round line positions.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.Text#autoRound
|
|
|
|
* @type {boolean}
|
|
|
|
* @default true
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-03-15 23:08:59 +00:00
|
|
|
this.autoRound = true;
|
2017-03-15 01:07:58 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The Regular Expression that is used to split the text up into lines, in
|
|
|
|
* multi-line text. By default this is `/(?:\r\n|\r|\n)/`.
|
|
|
|
* You can change this RegExp to be anything else that you may need.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.Text#splitRegExp
|
|
|
|
* @type {object}
|
|
|
|
* @since 3.0.0
|
2017-03-15 01:07:58 +00:00
|
|
|
*/
|
|
|
|
this.splitRegExp = /(?:\r\n|\r|\n)/;
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* The text to display.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2018-08-20 16:41:05 +00:00
|
|
|
* @name Phaser.GameObjects.Text#_text
|
2018-02-07 00:18:22 +00:00
|
|
|
* @type {string}
|
2018-08-20 16:41:05 +00:00
|
|
|
* @private
|
|
|
|
* @since 3.12.0
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2019-05-26 12:58:40 +00:00
|
|
|
this._text = undefined;
|
2017-03-15 01:07:58 +00:00
|
|
|
|
2017-04-26 14:34:15 +00:00
|
|
|
/**
|
2018-02-07 00:18:22 +00:00
|
|
|
* Specify a padding value which is added to the line width and height when calculating the Text size.
|
|
|
|
* Allows you to add extra spacing if the browser is unable to accurately determine the true font dimensions.
|
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.Text#padding
|
2020-08-01 11:35:02 +00:00
|
|
|
* @type {Phaser.Types.GameObjects.Text.TextPadding}
|
2018-02-07 00:18:22 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-11-30 17:17:18 +00:00
|
|
|
this.padding = { left: 0, right: 0, top: 0, bottom: 0 };
|
2017-03-15 01:07:58 +00:00
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* The width of this Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.Text#width
|
|
|
|
* @type {number}
|
|
|
|
* @default 1
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-03-15 23:08:59 +00:00
|
|
|
this.width = 1;
|
2018-02-07 00:18:22 +00:00
|
|
|
|
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* The height of this Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.Text#height
|
|
|
|
* @type {number}
|
|
|
|
* @default 1
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-03-15 23:08:59 +00:00
|
|
|
this.height = 1;
|
|
|
|
|
2018-09-12 15:29:38 +00:00
|
|
|
/**
|
|
|
|
* The line spacing value.
|
|
|
|
* This value is added to the font height to calculate the overall line height.
|
|
|
|
* Only has an effect if this Text object contains multiple lines of text.
|
2020-09-12 10:55:06 +00:00
|
|
|
*
|
2018-09-12 15:29:38 +00:00
|
|
|
* If you update this property directly, instead of using the `setLineSpacing` method, then
|
|
|
|
* be sure to call `updateText` after, or you won't see the change reflected in the Text object.
|
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.Text#lineSpacing
|
|
|
|
* @type {number}
|
|
|
|
* @since 3.13.0
|
|
|
|
*/
|
|
|
|
this.lineSpacing = 0;
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* Whether the text or its settings have changed and need updating.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.Text#dirty
|
|
|
|
* @type {boolean}
|
|
|
|
* @default false
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-03-21 21:06:36 +00:00
|
|
|
this.dirty = false;
|
2017-03-21 20:08:43 +00:00
|
|
|
|
2020-09-12 10:55:06 +00:00
|
|
|
// If resolution wasn't set, force it to 1
|
2018-07-17 21:44:12 +00:00
|
|
|
if (this.style.resolution === 0)
|
|
|
|
{
|
2020-09-12 10:55:06 +00:00
|
|
|
this.style.resolution = 1;
|
2018-07-17 21:44:12 +00:00
|
|
|
}
|
|
|
|
|
2018-08-03 18:07:12 +00:00
|
|
|
/**
|
|
|
|
* The internal crop data object, as used by `setCrop` and passed to the `Frame.setCropUVs` method.
|
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.Text#_crop
|
|
|
|
* @type {object}
|
|
|
|
* @private
|
|
|
|
* @since 3.12.0
|
|
|
|
*/
|
|
|
|
this._crop = this.resetCropObject();
|
|
|
|
|
|
|
|
// Create a Texture for this Text object
|
|
|
|
this.texture = scene.sys.textures.addCanvas(null, this.canvas, true);
|
|
|
|
|
|
|
|
// Get the frame
|
|
|
|
this.frame = this.texture.get();
|
|
|
|
|
|
|
|
// Set the resolution
|
|
|
|
this.frame.source.resolution = this.style.resolution;
|
|
|
|
|
2018-10-12 14:08:53 +00:00
|
|
|
if (this.renderer && this.renderer.gl)
|
|
|
|
{
|
|
|
|
// Clear the default 1x1 glTexture, as we override it later
|
|
|
|
this.renderer.deleteTexture(this.frame.source.glTexture);
|
|
|
|
|
|
|
|
this.frame.source.glTexture = null;
|
|
|
|
}
|
|
|
|
|
2017-11-30 01:20:02 +00:00
|
|
|
this.initRTL();
|
|
|
|
|
2019-06-05 22:40:10 +00:00
|
|
|
this.setText(text);
|
|
|
|
|
2017-11-30 17:17:18 +00:00
|
|
|
if (style && style.padding)
|
|
|
|
{
|
|
|
|
this.setPadding(style.padding);
|
|
|
|
}
|
2018-03-19 12:50:32 +00:00
|
|
|
|
2018-03-05 14:35:42 +00:00
|
|
|
if (style && style.lineSpacing)
|
|
|
|
{
|
2019-12-18 14:55:12 +00:00
|
|
|
this.setLineSpacing(style.lineSpacing);
|
2018-03-05 14:35:42 +00:00
|
|
|
}
|
2017-11-30 17:17:18 +00:00
|
|
|
|
2021-06-12 04:44:23 +00:00
|
|
|
scene.sys.game.events.on(GameEvents.CONTEXT_RESTORED, this.onContextRestored, this);
|
2017-03-15 01:07:58 +00:00
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* Initialize right to left text.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#initRTL
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-11-30 01:20:02 +00:00
|
|
|
initRTL: function ()
|
|
|
|
{
|
|
|
|
if (!this.style.rtl)
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Here is where the crazy starts.
|
2017-12-13 21:08:43 +00:00
|
|
|
//
|
2017-11-30 01:20:02 +00:00
|
|
|
// Due to browser implementation issues, you cannot fillText BiDi text to a canvas
|
|
|
|
// that is not part of the DOM. It just completely ignores the direction property.
|
|
|
|
|
|
|
|
this.canvas.dir = 'rtl';
|
|
|
|
|
|
|
|
// Experimental atm, but one day ...
|
|
|
|
this.context.direction = 'rtl';
|
|
|
|
|
|
|
|
// Add it to the DOM, but hidden within the parent canvas.
|
|
|
|
this.canvas.style.display = 'none';
|
|
|
|
|
|
|
|
AddToDOM(this.canvas, this.scene.sys.canvas);
|
|
|
|
|
|
|
|
// And finally we set the x origin
|
|
|
|
this.originX = 1;
|
|
|
|
},
|
|
|
|
|
2017-12-13 21:04:57 +00:00
|
|
|
/**
|
|
|
|
* Greedy wrapping algorithm that will wrap words as the line grows longer than its horizontal
|
|
|
|
* bounds.
|
|
|
|
*
|
2018-02-07 00:18:22 +00:00
|
|
|
* @method Phaser.GameObjects.Text#runWordWrap
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2017-12-13 21:04:57 +00:00
|
|
|
* @param {string} text - The text to perform word wrap detection against.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2017-12-13 21:14:16 +00:00
|
|
|
* @return {string} The text after wrapping has been applied.
|
2017-12-13 21:04:57 +00:00
|
|
|
*/
|
|
|
|
runWordWrap: function (text)
|
|
|
|
{
|
|
|
|
var style = this.style;
|
2018-02-07 00:18:22 +00:00
|
|
|
|
2017-12-13 21:04:57 +00:00
|
|
|
if (style.wordWrapCallback)
|
|
|
|
{
|
|
|
|
var wrappedLines = style.wordWrapCallback.call(style.wordWrapCallbackScope, text, this);
|
2018-02-07 00:18:22 +00:00
|
|
|
|
2017-12-13 21:04:57 +00:00
|
|
|
if (Array.isArray(wrappedLines))
|
|
|
|
{
|
|
|
|
wrappedLines = wrappedLines.join('\n');
|
|
|
|
}
|
2018-02-07 00:18:22 +00:00
|
|
|
|
2017-12-13 21:04:57 +00:00
|
|
|
return wrappedLines;
|
|
|
|
}
|
|
|
|
else if (style.wordWrapWidth)
|
|
|
|
{
|
|
|
|
if (style.wordWrapUseAdvanced)
|
|
|
|
{
|
2017-12-13 21:14:16 +00:00
|
|
|
return this.advancedWordWrap(text, this.context, this.style.wordWrapWidth);
|
2017-12-13 21:04:57 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2017-12-13 21:14:16 +00:00
|
|
|
return this.basicWordWrap(text, this.context, this.style.wordWrapWidth);
|
2017-12-13 21:04:57 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
return text;
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Advanced wrapping algorithm that will wrap words as the line grows longer than its horizontal
|
2017-12-13 21:28:52 +00:00
|
|
|
* bounds. Consecutive spaces will be collapsed and replaced with a single space. Lines will be
|
|
|
|
* trimmed of white space before processing. Throws an error if wordWrapWidth is less than a
|
|
|
|
* single character.
|
2017-12-13 21:04:57 +00:00
|
|
|
*
|
2018-02-07 00:18:22 +00:00
|
|
|
* @method Phaser.GameObjects.Text#advancedWordWrap
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2017-12-13 21:04:57 +00:00
|
|
|
* @param {string} text - The text to perform word wrap detection against.
|
2018-06-14 13:27:31 +00:00
|
|
|
* @param {CanvasRenderingContext2D} context - The Canvas Rendering Context.
|
|
|
|
* @param {number} wordWrapWidth - The word wrap width.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2017-12-13 21:28:52 +00:00
|
|
|
* @return {string} The wrapped text.
|
2017-12-13 21:04:57 +00:00
|
|
|
*/
|
2017-12-13 21:14:16 +00:00
|
|
|
advancedWordWrap: function (text, context, wordWrapWidth)
|
2017-12-13 21:04:57 +00:00
|
|
|
{
|
|
|
|
var output = '';
|
|
|
|
|
2017-12-13 21:30:43 +00:00
|
|
|
// Condense consecutive spaces and split into lines
|
2017-12-13 21:04:57 +00:00
|
|
|
var lines = text
|
|
|
|
.replace(/ +/gi, ' ')
|
2017-12-13 21:44:59 +00:00
|
|
|
.split(this.splitRegExp);
|
2017-12-13 21:04:57 +00:00
|
|
|
|
|
|
|
var linesCount = lines.length;
|
|
|
|
|
|
|
|
for (var i = 0; i < linesCount; i++)
|
|
|
|
{
|
|
|
|
var line = lines[i];
|
|
|
|
var out = '';
|
|
|
|
|
2017-12-13 21:30:43 +00:00
|
|
|
// Trim whitespace
|
2017-12-13 21:04:57 +00:00
|
|
|
line = line.replace(/^ *|\s*$/gi, '');
|
|
|
|
|
2017-12-13 21:30:43 +00:00
|
|
|
// If entire line is less than wordWrapWidth append the entire line and exit early
|
2017-12-13 21:04:57 +00:00
|
|
|
var lineWidth = context.measureText(line).width;
|
|
|
|
|
|
|
|
if (lineWidth < wordWrapWidth)
|
|
|
|
{
|
|
|
|
output += line + '\n';
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2017-12-13 21:30:43 +00:00
|
|
|
// Otherwise, calculate new lines
|
2017-12-13 21:04:57 +00:00
|
|
|
var currentLineWidth = wordWrapWidth;
|
|
|
|
|
2017-12-13 21:30:43 +00:00
|
|
|
// Split into words
|
2017-12-13 21:04:57 +00:00
|
|
|
var words = line.split(' ');
|
|
|
|
|
|
|
|
for (var j = 0; j < words.length; j++)
|
|
|
|
{
|
|
|
|
var word = words[j];
|
|
|
|
var wordWithSpace = word + ' ';
|
|
|
|
var wordWidth = context.measureText(wordWithSpace).width;
|
|
|
|
|
|
|
|
if (wordWidth > currentLineWidth)
|
|
|
|
{
|
2017-12-13 21:30:43 +00:00
|
|
|
// Break word
|
2017-12-13 21:04:57 +00:00
|
|
|
if (j === 0)
|
|
|
|
{
|
2017-12-13 21:30:43 +00:00
|
|
|
// Shave off letters from word until it's small enough
|
2017-12-13 21:04:57 +00:00
|
|
|
var newWord = wordWithSpace;
|
|
|
|
|
|
|
|
while (newWord.length)
|
|
|
|
{
|
|
|
|
newWord = newWord.slice(0, -1);
|
|
|
|
wordWidth = context.measureText(newWord).width;
|
|
|
|
|
|
|
|
if (wordWidth <= currentLineWidth)
|
|
|
|
{
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-12-13 21:30:43 +00:00
|
|
|
// If wordWrapWidth is too small for even a single letter, shame user
|
2017-12-13 21:04:57 +00:00
|
|
|
// failure with a fatal error
|
|
|
|
if (!newWord.length)
|
|
|
|
{
|
|
|
|
throw new Error('This text\'s wordWrapWidth setting is less than a single character!');
|
|
|
|
}
|
|
|
|
|
2017-12-13 21:30:43 +00:00
|
|
|
// Replace current word in array with remainder
|
2017-12-13 21:04:57 +00:00
|
|
|
var secondPart = word.substr(newWord.length);
|
|
|
|
|
|
|
|
words[j] = secondPart;
|
|
|
|
|
2017-12-13 21:30:43 +00:00
|
|
|
// Append first piece to output
|
2017-12-13 21:04:57 +00:00
|
|
|
out += newWord;
|
|
|
|
}
|
|
|
|
|
2017-12-13 21:30:43 +00:00
|
|
|
// If existing word length is 0, don't include it
|
2017-12-13 21:04:57 +00:00
|
|
|
var offset = (words[j].length) ? j : j + 1;
|
|
|
|
|
2017-12-13 21:30:43 +00:00
|
|
|
// Collapse rest of sentence and remove any trailing white space
|
2017-12-13 21:04:57 +00:00
|
|
|
var remainder = words.slice(offset).join(' ')
|
|
|
|
.replace(/[ \n]*$/gi, '');
|
|
|
|
|
2017-12-13 21:30:43 +00:00
|
|
|
// Prepend remainder to next line
|
2017-12-13 21:04:57 +00:00
|
|
|
lines[i + 1] = remainder + ' ' + (lines[i + 1] || '');
|
|
|
|
linesCount = lines.length;
|
|
|
|
|
2017-12-13 21:30:43 +00:00
|
|
|
break; // Processing on this line
|
2017-12-13 21:04:57 +00:00
|
|
|
|
2017-12-13 21:30:43 +00:00
|
|
|
// Append word with space to output
|
2017-12-13 21:04:57 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
out += wordWithSpace;
|
|
|
|
currentLineWidth -= wordWidth;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-12-13 21:30:43 +00:00
|
|
|
// Append processed line to output
|
2017-12-13 21:04:57 +00:00
|
|
|
output += out.replace(/[ \n]*$/gi, '') + '\n';
|
|
|
|
}
|
|
|
|
|
2017-12-13 21:30:43 +00:00
|
|
|
// Trim the end of the string
|
2017-12-13 21:04:57 +00:00
|
|
|
output = output.replace(/[\s|\n]*$/gi, '');
|
|
|
|
|
|
|
|
return output;
|
|
|
|
},
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Greedy wrapping algorithm that will wrap words as the line grows longer than its horizontal
|
2017-12-13 21:28:52 +00:00
|
|
|
* bounds. Spaces are not collapsed and whitespace is not trimmed.
|
2017-12-13 21:04:57 +00:00
|
|
|
*
|
2018-02-07 00:18:22 +00:00
|
|
|
* @method Phaser.GameObjects.Text#basicWordWrap
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2017-12-13 21:04:57 +00:00
|
|
|
* @param {string} text - The text to perform word wrap detection against.
|
2018-06-14 13:27:31 +00:00
|
|
|
* @param {CanvasRenderingContext2D} context - The Canvas Rendering Context.
|
|
|
|
* @param {number} wordWrapWidth - The word wrap width.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2017-12-13 21:28:52 +00:00
|
|
|
* @return {string} The wrapped text.
|
2017-12-13 21:04:57 +00:00
|
|
|
*/
|
2017-12-13 21:14:16 +00:00
|
|
|
basicWordWrap: function (text, context, wordWrapWidth)
|
2017-12-13 21:04:57 +00:00
|
|
|
{
|
|
|
|
var result = '';
|
2017-12-13 21:44:59 +00:00
|
|
|
var lines = text.split(this.splitRegExp);
|
2019-11-27 05:09:07 +00:00
|
|
|
var lastLineIndex = lines.length - 1;
|
|
|
|
var whiteSpaceWidth = context.measureText(' ').width;
|
2017-12-13 21:04:57 +00:00
|
|
|
|
2019-11-27 05:09:07 +00:00
|
|
|
for (var i = 0; i <= lastLineIndex; i++)
|
2017-12-13 21:04:57 +00:00
|
|
|
{
|
2017-12-13 21:14:16 +00:00
|
|
|
var spaceLeft = wordWrapWidth;
|
2017-12-13 21:04:57 +00:00
|
|
|
var words = lines[i].split(' ');
|
2019-11-27 05:09:07 +00:00
|
|
|
var lastWordIndex = words.length - 1;
|
2017-12-13 21:04:57 +00:00
|
|
|
|
2019-11-27 05:09:07 +00:00
|
|
|
for (var j = 0; j <= lastWordIndex; j++)
|
2017-12-13 21:04:57 +00:00
|
|
|
{
|
2019-11-27 05:09:07 +00:00
|
|
|
var word = words[j];
|
|
|
|
var wordWidth = context.measureText(word).width;
|
2020-10-20 06:52:20 +00:00
|
|
|
var wordWidthWithSpace = wordWidth;
|
|
|
|
|
|
|
|
if (j < lastWordIndex)
|
|
|
|
{
|
|
|
|
wordWidthWithSpace += whiteSpaceWidth;
|
|
|
|
}
|
2017-12-13 21:04:57 +00:00
|
|
|
|
|
|
|
if (wordWidthWithSpace > spaceLeft)
|
|
|
|
{
|
|
|
|
// Skip printing the newline if it's the first word of the line that is greater
|
|
|
|
// than the word wrap width.
|
|
|
|
if (j > 0)
|
|
|
|
{
|
|
|
|
result += '\n';
|
2019-11-27 05:09:07 +00:00
|
|
|
spaceLeft = wordWrapWidth;
|
2017-12-13 21:04:57 +00:00
|
|
|
}
|
2019-11-27 05:09:07 +00:00
|
|
|
}
|
2018-04-30 12:03:44 +00:00
|
|
|
|
2019-11-27 05:09:07 +00:00
|
|
|
result += word;
|
|
|
|
|
|
|
|
if (j < lastWordIndex)
|
|
|
|
{
|
|
|
|
result += ' ';
|
|
|
|
spaceLeft -= wordWidthWithSpace;
|
2017-12-13 21:04:57 +00:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-11-27 05:09:07 +00:00
|
|
|
spaceLeft -= wordWidth;
|
2017-12-13 21:04:57 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-11-27 05:09:07 +00:00
|
|
|
if (i < lastLineIndex)
|
2017-12-13 21:04:57 +00:00
|
|
|
{
|
|
|
|
result += '\n';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return result;
|
|
|
|
},
|
2017-12-13 21:09:06 +00:00
|
|
|
|
2017-12-13 21:28:52 +00:00
|
|
|
/**
|
2018-02-07 00:18:22 +00:00
|
|
|
* Runs the given text through this Text objects word wrapping and returns the results as an
|
2017-12-13 21:28:52 +00:00
|
|
|
* array, where each element of the array corresponds to a wrapped line of text.
|
|
|
|
*
|
2018-02-07 00:18:22 +00:00
|
|
|
* @method Phaser.GameObjects.Text#getWrappedText
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
|
|
|
* @param {string} text - The text for which the wrapping will be calculated. If unspecified, the Text objects current text will be used.
|
|
|
|
*
|
|
|
|
* @return {string[]} An array of strings with the pieces of wrapped text.
|
2017-12-13 21:28:52 +00:00
|
|
|
*/
|
2017-12-13 21:09:06 +00:00
|
|
|
getWrappedText: function (text)
|
|
|
|
{
|
2018-08-20 16:41:05 +00:00
|
|
|
if (text === undefined) { text = this._text; }
|
2017-12-13 21:09:06 +00:00
|
|
|
|
2018-03-18 14:53:02 +00:00
|
|
|
this.style.syncFont(this.canvas, this.context);
|
|
|
|
|
2017-12-13 21:09:06 +00:00
|
|
|
var wrappedLines = this.runWordWrap(text);
|
|
|
|
|
2017-12-13 21:44:59 +00:00
|
|
|
return wrappedLines.split(this.splitRegExp);
|
2017-12-13 21:09:06 +00:00
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* Set the text to display.
|
|
|
|
*
|
|
|
|
* An array of strings will be joined with `\n` line breaks.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#setText
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-03-20 14:56:31 +00:00
|
|
|
* @param {(string|string[])} value - The string, or array of strings, to be set as the content of this Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-03-15 23:44:39 +00:00
|
|
|
setText: function (value)
|
|
|
|
{
|
2018-02-27 15:13:39 +00:00
|
|
|
if (!value && value !== 0)
|
2018-02-12 13:37:17 +00:00
|
|
|
{
|
|
|
|
value = '';
|
|
|
|
}
|
|
|
|
|
2017-03-20 16:48:04 +00:00
|
|
|
if (Array.isArray(value))
|
|
|
|
{
|
|
|
|
value = value.join('\n');
|
|
|
|
}
|
|
|
|
|
2018-08-20 16:41:05 +00:00
|
|
|
if (value !== this._text)
|
2017-03-15 23:44:39 +00:00
|
|
|
{
|
2018-08-20 16:41:05 +00:00
|
|
|
this._text = value.toString();
|
2017-03-20 16:48:04 +00:00
|
|
|
|
2017-03-15 23:44:39 +00:00
|
|
|
this.updateText();
|
|
|
|
}
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* Set the text style.
|
|
|
|
*
|
2018-06-14 13:49:29 +00:00
|
|
|
* @example
|
2018-06-14 13:27:31 +00:00
|
|
|
* text.setStyle({
|
2018-06-14 13:41:17 +00:00
|
|
|
* fontSize: '64px',
|
|
|
|
* fontFamily: 'Arial',
|
|
|
|
* color: '#ffffff',
|
|
|
|
* align: 'center',
|
|
|
|
* backgroundColor: '#ff00ff'
|
|
|
|
* });
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#setStyle
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-14 13:27:31 +00:00
|
|
|
* @param {object} style - The style settings to set.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-03-16 17:15:58 +00:00
|
|
|
setStyle: function (style)
|
|
|
|
{
|
|
|
|
return this.style.setStyle(style);
|
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* Set the font.
|
|
|
|
*
|
|
|
|
* If a string is given, the font family is set.
|
|
|
|
*
|
|
|
|
* If an object is given, the `fontFamily`, `fontSize` and `fontStyle`
|
|
|
|
* properties of that object are set.
|
2020-04-04 17:56:52 +00:00
|
|
|
*
|
|
|
|
* **Important:** The font name must be quoted if it contains certain combinations of digits or
|
|
|
|
* special characters:
|
|
|
|
*
|
2019-01-22 14:02:25 +00:00
|
|
|
* ```javascript
|
2020-04-04 17:56:52 +00:00
|
|
|
* Text.setFont('"Press Start 2P"');
|
2019-01-22 14:02:25 +00:00
|
|
|
* ```
|
2020-04-04 17:56:52 +00:00
|
|
|
*
|
2019-01-22 14:02:25 +00:00
|
|
|
* Equally, if you wish to provide a list of fallback fonts, then you should ensure they are all
|
|
|
|
* quoted properly, too:
|
2020-04-04 17:56:52 +00:00
|
|
|
*
|
2019-01-22 14:02:25 +00:00
|
|
|
* ```javascript
|
2020-04-04 17:56:52 +00:00
|
|
|
* Text.setFont('Georgia, "Goudy Bookletter 1911", Times, serif');
|
2019-01-22 14:02:25 +00:00
|
|
|
* ```
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#setFont
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-14 13:27:31 +00:00
|
|
|
* @param {string} font - The font family or font settings to set.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2020-04-04 17:56:52 +00:00
|
|
|
*
|
|
|
|
* @see https://developer.mozilla.org/en-US/docs/Web/CSS/font-family#Valid_family_names
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-03-20 16:28:09 +00:00
|
|
|
setFont: function (font)
|
|
|
|
{
|
|
|
|
return this.style.setFont(font);
|
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* Set the font family.
|
2020-04-04 17:56:52 +00:00
|
|
|
*
|
|
|
|
* **Important:** The font name must be quoted if it contains certain combinations of digits or
|
|
|
|
* special characters:
|
|
|
|
*
|
2019-01-22 14:02:25 +00:00
|
|
|
* ```javascript
|
2020-04-04 17:56:52 +00:00
|
|
|
* Text.setFont('"Press Start 2P"');
|
2019-01-22 14:02:25 +00:00
|
|
|
* ```
|
2020-09-12 10:55:06 +00:00
|
|
|
*
|
2019-01-22 14:02:25 +00:00
|
|
|
* Equally, if you wish to provide a list of fallback fonts, then you should ensure they are all
|
|
|
|
* quoted properly, too:
|
2020-09-12 10:55:06 +00:00
|
|
|
*
|
2019-01-22 14:02:25 +00:00
|
|
|
* ```javascript
|
2020-04-04 17:56:52 +00:00
|
|
|
* Text.setFont('Georgia, "Goudy Bookletter 1911", Times, serif');
|
2019-01-22 14:02:25 +00:00
|
|
|
* ```
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#setFontFamily
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-14 13:27:31 +00:00
|
|
|
* @param {string} family - The font family.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2020-04-04 17:56:52 +00:00
|
|
|
*
|
|
|
|
* @see https://developer.mozilla.org/en-US/docs/Web/CSS/font-family#Valid_family_names
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-11-30 17:17:18 +00:00
|
|
|
setFontFamily: function (family)
|
|
|
|
{
|
|
|
|
return this.style.setFontFamily(family);
|
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* Set the font size.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#setFontSize
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-14 13:27:31 +00:00
|
|
|
* @param {number} size - The font size.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-11-30 17:17:18 +00:00
|
|
|
setFontSize: function (size)
|
|
|
|
{
|
|
|
|
return this.style.setFontSize(size);
|
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* Set the font style.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#setFontStyle
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-14 13:27:31 +00:00
|
|
|
* @param {string} style - The font style.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-11-30 17:17:18 +00:00
|
|
|
setFontStyle: function (style)
|
|
|
|
{
|
|
|
|
return this.style.setFontStyle(style);
|
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* Set a fixed width and height for the text.
|
|
|
|
*
|
|
|
|
* Pass in `0` for either of these parameters to disable fixed width or height respectively.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#setFixedSize
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-14 13:27:31 +00:00
|
|
|
* @param {number} width - The fixed width to set. `0` disables fixed width.
|
|
|
|
* @param {number} height - The fixed height to set. `0` disables fixed height.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-03-20 16:28:09 +00:00
|
|
|
setFixedSize: function (width, height)
|
|
|
|
{
|
|
|
|
return this.style.setFixedSize(width, height);
|
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* Set the background color.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#setBackgroundColor
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-14 13:27:31 +00:00
|
|
|
* @param {string} color - The background color.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-03-20 16:28:09 +00:00
|
|
|
setBackgroundColor: function (color)
|
|
|
|
{
|
|
|
|
return this.style.setBackgroundColor(color);
|
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-10-18 12:27:56 +00:00
|
|
|
* Set the fill style to be used by the Text object.
|
|
|
|
*
|
|
|
|
* This can be any valid CanvasRenderingContext2D fillStyle value, such as
|
|
|
|
* a color (in hex, rgb, rgba, hsl or named values), a gradient or a pattern.
|
|
|
|
*
|
|
|
|
* See the [MDN fillStyle docs](https://developer.mozilla.org/en-US/docs/Web/API/CanvasRenderingContext2D/fillStyle) for more details.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#setFill
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-10-18 12:27:56 +00:00
|
|
|
* @param {(string|any)} color - The text fill style. Can be any valid CanvasRenderingContext `fillStyle` value.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2018-10-18 12:27:56 +00:00
|
|
|
setFill: function (fillStyle)
|
2017-12-01 03:11:41 +00:00
|
|
|
{
|
2018-10-18 12:27:56 +00:00
|
|
|
return this.style.setFill(fillStyle);
|
2017-12-01 03:11:41 +00:00
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* Set the text fill color.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#setColor
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-14 13:27:31 +00:00
|
|
|
* @param {string} color - The text fill color.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-11-30 17:17:18 +00:00
|
|
|
setColor: function (color)
|
2017-03-20 16:28:09 +00:00
|
|
|
{
|
2017-11-30 17:17:18 +00:00
|
|
|
return this.style.setColor(color);
|
2017-03-20 16:28:09 +00:00
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* Set the stroke settings.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#setStroke
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-14 13:27:31 +00:00
|
|
|
* @param {string} color - The stroke color.
|
|
|
|
* @param {number} thickness - The stroke thickness.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-03-20 16:28:09 +00:00
|
|
|
setStroke: function (color, thickness)
|
|
|
|
{
|
|
|
|
return this.style.setStroke(color, thickness);
|
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* Set the shadow settings.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#setShadow
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-14 13:27:31 +00:00
|
|
|
* @param {number} [x=0] - The horizontal shadow offset.
|
|
|
|
* @param {number} [y=0] - The vertical shadow offset.
|
|
|
|
* @param {string} [color='#000'] - The shadow color.
|
|
|
|
* @param {number} [blur=0] - The shadow blur radius.
|
|
|
|
* @param {boolean} [shadowStroke=false] - Whether to stroke the shadow.
|
|
|
|
* @param {boolean} [shadowFill=true] - Whether to fill the shadow.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-03-20 16:28:09 +00:00
|
|
|
setShadow: function (x, y, color, blur, shadowStroke, shadowFill)
|
|
|
|
{
|
|
|
|
return this.style.setShadow(x, y, color, blur, shadowStroke, shadowFill);
|
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* Set the shadow offset.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#setShadowOffset
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-14 13:27:31 +00:00
|
|
|
* @param {number} x - The horizontal shadow offset.
|
|
|
|
* @param {number} y - The vertical shadow offset.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-03-20 16:28:09 +00:00
|
|
|
setShadowOffset: function (x, y)
|
|
|
|
{
|
|
|
|
return this.style.setShadowOffset(x, y);
|
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* Set the shadow color.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#setShadowColor
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-14 13:27:31 +00:00
|
|
|
* @param {string} color - The shadow color.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-03-20 16:28:09 +00:00
|
|
|
setShadowColor: function (color)
|
|
|
|
{
|
|
|
|
return this.style.setShadowColor(color);
|
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* Set the shadow blur radius.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#setShadowBlur
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-14 13:27:31 +00:00
|
|
|
* @param {number} blur - The shadow blur radius.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-03-20 16:28:09 +00:00
|
|
|
setShadowBlur: function (blur)
|
|
|
|
{
|
|
|
|
return this.style.setShadowBlur(blur);
|
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* Enable or disable shadow stroke.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#setShadowStroke
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-14 13:27:31 +00:00
|
|
|
* @param {boolean} enabled - Whether shadow stroke is enabled or not.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-03-20 16:28:09 +00:00
|
|
|
setShadowStroke: function (enabled)
|
|
|
|
{
|
|
|
|
return this.style.setShadowStroke(enabled);
|
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* Enable or disable shadow fill.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#setShadowFill
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-06-14 13:27:31 +00:00
|
|
|
* @param {boolean} enabled - Whether shadow fill is enabled or not.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-03-20 16:28:09 +00:00
|
|
|
setShadowFill: function (enabled)
|
|
|
|
{
|
|
|
|
return this.style.setShadowFill(enabled);
|
|
|
|
},
|
|
|
|
|
2017-12-13 21:28:52 +00:00
|
|
|
/**
|
2018-02-07 02:46:11 +00:00
|
|
|
* Set the width (in pixels) to use for wrapping lines. Pass in null to remove wrapping by width.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#setWordWrapWidth
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-03-20 14:36:03 +00:00
|
|
|
* @param {?number} width - The maximum width of a line in pixels. Set to null to remove wrapping.
|
2018-02-07 02:46:11 +00:00
|
|
|
* @param {boolean} [useAdvancedWrap=false] - Whether or not to use the advanced wrapping
|
|
|
|
* algorithm. If true, spaces are collapsed and whitespace is trimmed from lines. If false,
|
|
|
|
* spaces and whitespace are left as is.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-12-13 21:08:43 +00:00
|
|
|
setWordWrapWidth: function (width, useAdvancedWrap)
|
|
|
|
{
|
|
|
|
return this.style.setWordWrapWidth(width, useAdvancedWrap);
|
|
|
|
},
|
|
|
|
|
2017-12-13 21:28:52 +00:00
|
|
|
/**
|
|
|
|
* Set a custom callback for wrapping lines. Pass in null to remove wrapping by callback.
|
|
|
|
*
|
2018-02-07 02:46:11 +00:00
|
|
|
* @method Phaser.GameObjects.Text#setWordWrapCallback
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2018-03-19 21:27:16 +00:00
|
|
|
* @param {TextStyleWordWrapCallback} callback - A custom function that will be responsible for wrapping the
|
2017-12-13 21:28:52 +00:00
|
|
|
* text. It will receive two arguments: text (the string to wrap), textObject (this Text
|
|
|
|
* instance). It should return the wrapped lines either as an array of lines or as a string with
|
|
|
|
* newline characters in place to indicate where breaks should happen.
|
|
|
|
* @param {object} [scope=null] - The scope that will be applied when the callback is invoked.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-12-13 21:08:43 +00:00
|
|
|
setWordWrapCallback: function (callback, scope)
|
|
|
|
{
|
|
|
|
return this.style.setWordWrapCallback(callback, scope);
|
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2019-06-19 08:46:32 +00:00
|
|
|
* Set the alignment of the text in this Text object.
|
2020-09-12 10:55:06 +00:00
|
|
|
*
|
2019-06-19 08:46:32 +00:00
|
|
|
* The argument can be one of: `left`, `right`, `center` or `justify`.
|
2020-09-12 10:55:06 +00:00
|
|
|
*
|
2019-06-19 08:46:32 +00:00
|
|
|
* Alignment only works if the Text object has more than one line of text.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#setAlign
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2019-06-19 08:46:32 +00:00
|
|
|
* @param {string} [align='left'] - The text alignment for multi-line text.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-03-20 16:28:09 +00:00
|
|
|
setAlign: function (align)
|
|
|
|
{
|
|
|
|
return this.style.setAlign(align);
|
|
|
|
},
|
|
|
|
|
2018-07-18 13:45:10 +00:00
|
|
|
/**
|
|
|
|
* Set the resolution used by this Text object.
|
|
|
|
*
|
|
|
|
* By default it will be set to match the resolution set in the Game Config,
|
|
|
|
* but you can override it via this method, or by specifying it in the Text style configuration object.
|
2020-09-12 10:55:06 +00:00
|
|
|
*
|
2018-07-18 13:45:10 +00:00
|
|
|
* It allows for much clearer text on High DPI devices, at the cost of memory because it uses larger
|
|
|
|
* internal Canvas textures for the Text.
|
2020-09-12 10:55:06 +00:00
|
|
|
*
|
2018-07-18 13:45:10 +00:00
|
|
|
* Therefore, please use with caution, as the more high res Text you have, the more memory it uses.
|
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#setResolution
|
|
|
|
* @since 3.12.0
|
|
|
|
*
|
|
|
|
* @param {number} value - The resolution for this Text object to use.
|
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2018-07-18 13:45:10 +00:00
|
|
|
*/
|
|
|
|
setResolution: function (value)
|
|
|
|
{
|
|
|
|
return this.style.setResolution(value);
|
|
|
|
},
|
|
|
|
|
2018-09-12 15:29:38 +00:00
|
|
|
/**
|
|
|
|
* Sets the line spacing value.
|
|
|
|
*
|
|
|
|
* This value is _added_ to the height of the font when calculating the overall line height.
|
|
|
|
* This only has an effect if this Text object consists of multiple lines of text.
|
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#setLineSpacing
|
|
|
|
* @since 3.13.0
|
|
|
|
*
|
|
|
|
* @param {number} value - The amount to add to the font height to achieve the overall line height.
|
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2018-09-12 15:29:38 +00:00
|
|
|
*/
|
|
|
|
setLineSpacing: function (value)
|
|
|
|
{
|
|
|
|
this.lineSpacing = value;
|
|
|
|
|
|
|
|
return this.updateText();
|
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* Set the text padding.
|
|
|
|
*
|
2018-02-07 02:46:11 +00:00
|
|
|
* 'left' can be an object.
|
2018-06-14 13:27:31 +00:00
|
|
|
*
|
|
|
|
* If only 'left' and 'top' are given they are treated as 'x' and 'y'.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#setPadding
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2019-06-05 22:40:10 +00:00
|
|
|
* @param {(number|Phaser.Types.GameObjects.Text.TextPadding)} left - The left padding value, or a padding config object.
|
2020-08-10 05:21:26 +00:00
|
|
|
* @param {number} [top] - The top padding value.
|
|
|
|
* @param {number} [right] - The right padding value.
|
|
|
|
* @param {number} [bottom] - The bottom padding value.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-11-30 17:17:18 +00:00
|
|
|
setPadding: function (left, top, right, bottom)
|
|
|
|
{
|
|
|
|
if (typeof left === 'object')
|
|
|
|
{
|
|
|
|
var config = left;
|
|
|
|
|
|
|
|
// If they specify x and/or y this applies to all
|
|
|
|
var x = GetValue(config, 'x', null);
|
|
|
|
|
|
|
|
if (x !== null)
|
|
|
|
{
|
|
|
|
left = x;
|
|
|
|
right = x;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
left = GetValue(config, 'left', 0);
|
|
|
|
right = GetValue(config, 'right', left);
|
|
|
|
}
|
|
|
|
|
|
|
|
var y = GetValue(config, 'y', null);
|
|
|
|
|
|
|
|
if (y !== null)
|
|
|
|
{
|
|
|
|
top = y;
|
|
|
|
bottom = y;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
top = GetValue(config, 'top', 0);
|
|
|
|
bottom = GetValue(config, 'bottom', top);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if (left === undefined) { left = 0; }
|
|
|
|
if (top === undefined) { top = left; }
|
|
|
|
if (right === undefined) { right = left; }
|
|
|
|
if (bottom === undefined) { bottom = top; }
|
|
|
|
}
|
|
|
|
|
|
|
|
this.padding.left = left;
|
|
|
|
this.padding.top = top;
|
|
|
|
this.padding.right = right;
|
|
|
|
this.padding.bottom = bottom;
|
|
|
|
|
|
|
|
return this.updateText();
|
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* Set the maximum number of lines to draw.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#setMaxLines
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2020-11-23 10:22:13 +00:00
|
|
|
* @param {number} [max=0] - The maximum number of lines to draw.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-03-20 16:28:09 +00:00
|
|
|
setMaxLines: function (max)
|
|
|
|
{
|
|
|
|
return this.style.setMaxLines(max);
|
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* Update the displayed text.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#updateText
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2020-01-26 13:43:48 +00:00
|
|
|
* @return {this} This Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-03-15 01:07:58 +00:00
|
|
|
updateText: function ()
|
|
|
|
{
|
|
|
|
var canvas = this.canvas;
|
|
|
|
var context = this.context;
|
|
|
|
var style = this.style;
|
2018-07-17 21:44:12 +00:00
|
|
|
var resolution = style.resolution;
|
2017-03-20 16:09:01 +00:00
|
|
|
var size = style.metrics;
|
2017-03-15 01:07:58 +00:00
|
|
|
|
2017-12-13 21:08:43 +00:00
|
|
|
style.syncFont(canvas, context);
|
|
|
|
|
2018-08-20 16:41:05 +00:00
|
|
|
var outputText = this._text;
|
2017-03-15 01:07:58 +00:00
|
|
|
|
2017-12-13 21:08:43 +00:00
|
|
|
if (style.wordWrapWidth || style.wordWrapCallback)
|
|
|
|
{
|
2018-08-20 16:41:05 +00:00
|
|
|
outputText = this.runWordWrap(this._text);
|
2017-12-13 21:08:43 +00:00
|
|
|
}
|
2017-03-15 01:07:58 +00:00
|
|
|
|
|
|
|
// Split text into lines
|
|
|
|
var lines = outputText.split(this.splitRegExp);
|
2017-03-13 23:38:48 +00:00
|
|
|
|
2017-03-15 01:07:58 +00:00
|
|
|
var textSize = GetTextSize(this, size, lines);
|
|
|
|
|
2017-12-01 03:11:41 +00:00
|
|
|
var padding = this.padding;
|
|
|
|
|
2019-05-23 09:22:51 +00:00
|
|
|
var textWidth;
|
|
|
|
|
2018-02-07 02:46:11 +00:00
|
|
|
if (style.fixedWidth === 0)
|
2017-03-20 16:09:01 +00:00
|
|
|
{
|
2019-05-23 08:54:32 +00:00
|
|
|
this.width = textSize.width + padding.left + padding.right;
|
2019-05-30 22:05:06 +00:00
|
|
|
|
2019-05-23 09:22:51 +00:00
|
|
|
textWidth = textSize.width;
|
2017-03-20 16:09:01 +00:00
|
|
|
}
|
2019-03-15 09:11:04 +00:00
|
|
|
else
|
|
|
|
{
|
|
|
|
this.width = style.fixedWidth;
|
2019-05-30 22:05:06 +00:00
|
|
|
|
2019-05-23 09:22:51 +00:00
|
|
|
textWidth = this.width - padding.left - padding.right;
|
2019-05-30 22:05:06 +00:00
|
|
|
|
|
|
|
if (textWidth < textSize.width)
|
2019-05-23 09:30:04 +00:00
|
|
|
{
|
2019-05-23 09:22:51 +00:00
|
|
|
textWidth = textSize.width;
|
|
|
|
}
|
2019-03-15 09:11:04 +00:00
|
|
|
}
|
2017-03-20 16:09:01 +00:00
|
|
|
|
2018-02-07 02:46:11 +00:00
|
|
|
if (style.fixedHeight === 0)
|
2017-03-20 16:09:01 +00:00
|
|
|
{
|
2019-05-23 08:54:32 +00:00
|
|
|
this.height = textSize.height + padding.top + padding.bottom;
|
2017-03-20 16:09:01 +00:00
|
|
|
}
|
2019-03-15 09:11:04 +00:00
|
|
|
else
|
|
|
|
{
|
|
|
|
this.height = style.fixedHeight;
|
|
|
|
}
|
2017-03-15 23:08:59 +00:00
|
|
|
|
2019-05-23 08:54:32 +00:00
|
|
|
var w = this.width;
|
|
|
|
var h = this.height;
|
2017-03-15 23:08:59 +00:00
|
|
|
|
2017-11-07 01:32:53 +00:00
|
|
|
this.updateDisplayOrigin();
|
2017-03-15 23:44:39 +00:00
|
|
|
|
2018-02-12 19:03:13 +00:00
|
|
|
w *= resolution;
|
|
|
|
h *= resolution;
|
2017-03-20 16:09:01 +00:00
|
|
|
|
2018-01-22 12:21:42 +00:00
|
|
|
w = Math.max(w, 1);
|
|
|
|
h = Math.max(h, 1);
|
|
|
|
|
2017-03-20 16:09:01 +00:00
|
|
|
if (canvas.width !== w || canvas.height !== h)
|
|
|
|
{
|
|
|
|
canvas.width = w;
|
|
|
|
canvas.height = h;
|
2018-08-03 18:07:12 +00:00
|
|
|
|
|
|
|
this.frame.setSize(w, h);
|
|
|
|
|
2019-05-30 22:05:06 +00:00
|
|
|
// Because resizing the canvas resets the context
|
|
|
|
style.syncFont(canvas, context);
|
2017-03-20 16:09:01 +00:00
|
|
|
}
|
2017-03-20 16:48:04 +00:00
|
|
|
else
|
|
|
|
{
|
|
|
|
context.clearRect(0, 0, w, h);
|
|
|
|
}
|
2017-03-15 01:07:58 +00:00
|
|
|
|
2017-12-01 16:52:53 +00:00
|
|
|
context.save();
|
2018-02-16 18:17:51 +00:00
|
|
|
|
2018-07-17 21:44:12 +00:00
|
|
|
context.scale(resolution, resolution);
|
2017-12-01 16:52:53 +00:00
|
|
|
|
2017-03-15 01:07:58 +00:00
|
|
|
if (style.backgroundColor)
|
|
|
|
{
|
|
|
|
context.fillStyle = style.backgroundColor;
|
2017-03-20 16:09:01 +00:00
|
|
|
context.fillRect(0, 0, w, h);
|
2017-03-15 01:07:58 +00:00
|
|
|
}
|
|
|
|
|
2017-12-13 21:08:43 +00:00
|
|
|
style.syncStyle(canvas, context);
|
2017-03-15 01:07:58 +00:00
|
|
|
|
2017-04-26 02:55:37 +00:00
|
|
|
context.textBaseline = 'alphabetic';
|
2017-04-25 18:46:13 +00:00
|
|
|
|
|
|
|
// Apply padding
|
2017-11-30 17:17:18 +00:00
|
|
|
context.translate(padding.left, padding.top);
|
2017-04-25 18:46:13 +00:00
|
|
|
|
2017-03-15 01:07:58 +00:00
|
|
|
var linePositionX;
|
|
|
|
var linePositionY;
|
|
|
|
|
|
|
|
// Draw text line by line
|
|
|
|
for (var i = 0; i < textSize.lines; i++)
|
|
|
|
{
|
|
|
|
linePositionX = style.strokeThickness / 2;
|
|
|
|
linePositionY = (style.strokeThickness / 2 + i * textSize.lineHeight) + size.ascent;
|
|
|
|
|
|
|
|
if (i > 0)
|
|
|
|
{
|
|
|
|
linePositionY += (textSize.lineSpacing * i);
|
|
|
|
}
|
|
|
|
|
2017-11-30 01:20:02 +00:00
|
|
|
if (style.rtl)
|
2017-03-15 01:07:58 +00:00
|
|
|
{
|
2017-11-30 01:20:02 +00:00
|
|
|
linePositionX = w - linePositionX;
|
2017-03-15 01:07:58 +00:00
|
|
|
}
|
2017-11-30 17:17:18 +00:00
|
|
|
else if (style.align === 'right')
|
|
|
|
{
|
2019-05-23 09:22:51 +00:00
|
|
|
linePositionX += textWidth - textSize.lineWidths[i];
|
2017-11-30 17:17:18 +00:00
|
|
|
}
|
|
|
|
else if (style.align === 'center')
|
2017-03-15 01:07:58 +00:00
|
|
|
{
|
2019-05-23 09:22:51 +00:00
|
|
|
linePositionX += (textWidth - textSize.lineWidths[i]) / 2;
|
2017-03-15 01:07:58 +00:00
|
|
|
}
|
2019-06-19 08:46:32 +00:00
|
|
|
else if (style.align === 'justify')
|
|
|
|
{
|
|
|
|
// To justify text line its width must be no less than 85% of defined width
|
|
|
|
var minimumLengthToApplyJustification = 0.85;
|
|
|
|
|
|
|
|
if (textSize.lineWidths[i] / textSize.width >= minimumLengthToApplyJustification)
|
|
|
|
{
|
|
|
|
var extraSpace = textSize.width - textSize.lineWidths[i];
|
|
|
|
var spaceSize = context.measureText(' ').width;
|
|
|
|
var trimmedLine = lines[i].trim();
|
|
|
|
var array = trimmedLine.split(' ');
|
2020-09-12 10:55:06 +00:00
|
|
|
|
2019-06-19 08:46:32 +00:00
|
|
|
extraSpace += (lines[i].length - trimmedLine.length) * spaceSize;
|
2020-09-12 10:55:06 +00:00
|
|
|
|
2019-06-19 08:46:32 +00:00
|
|
|
var extraSpaceCharacters = Math.floor(extraSpace / spaceSize);
|
|
|
|
var idx = 0;
|
|
|
|
|
|
|
|
while (extraSpaceCharacters > 0)
|
|
|
|
{
|
|
|
|
array[idx] += ' ';
|
|
|
|
idx = (idx + 1) % (array.length - 1 || 1);
|
|
|
|
--extraSpaceCharacters;
|
|
|
|
}
|
2020-09-12 10:55:06 +00:00
|
|
|
|
2019-06-19 08:46:32 +00:00
|
|
|
lines[i] = array.join(' ');
|
|
|
|
}
|
|
|
|
}
|
2017-03-15 01:07:58 +00:00
|
|
|
|
|
|
|
if (this.autoRound)
|
|
|
|
{
|
|
|
|
linePositionX = Math.round(linePositionX);
|
|
|
|
linePositionY = Math.round(linePositionY);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (style.strokeThickness)
|
|
|
|
{
|
2017-03-20 16:09:01 +00:00
|
|
|
this.style.syncShadow(context, style.shadowStroke);
|
2017-03-15 01:07:58 +00:00
|
|
|
|
|
|
|
context.strokeText(lines[i], linePositionX, linePositionY);
|
|
|
|
}
|
|
|
|
|
2017-11-30 17:17:18 +00:00
|
|
|
if (style.color)
|
2017-03-15 01:07:58 +00:00
|
|
|
{
|
2017-03-20 16:09:01 +00:00
|
|
|
this.style.syncShadow(context, style.shadowFill);
|
2017-03-15 01:07:58 +00:00
|
|
|
|
|
|
|
context.fillText(lines[i], linePositionX, linePositionY);
|
|
|
|
}
|
|
|
|
}
|
2017-03-20 16:28:09 +00:00
|
|
|
|
2017-12-01 16:52:53 +00:00
|
|
|
context.restore();
|
|
|
|
|
2020-02-15 19:50:05 +00:00
|
|
|
if (this.renderer && this.renderer.gl)
|
2018-08-03 18:07:12 +00:00
|
|
|
{
|
2018-10-12 14:08:53 +00:00
|
|
|
this.frame.source.glTexture = this.renderer.canvasToTexture(canvas, this.frame.source.glTexture, true);
|
2018-09-13 12:23:24 +00:00
|
|
|
|
2018-08-03 18:07:12 +00:00
|
|
|
this.frame.glTexture = this.frame.source.glTexture;
|
|
|
|
}
|
|
|
|
|
2017-03-21 21:06:36 +00:00
|
|
|
this.dirty = true;
|
2017-03-21 20:08:43 +00:00
|
|
|
|
2019-04-24 10:21:36 +00:00
|
|
|
var input = this.input;
|
|
|
|
|
|
|
|
if (input && !input.customHitArea)
|
|
|
|
{
|
|
|
|
input.hitArea.width = this.width;
|
|
|
|
input.hitArea.height = this.height;
|
|
|
|
}
|
|
|
|
|
2017-03-20 16:28:09 +00:00
|
|
|
return this;
|
2017-04-12 23:35:27 +00:00
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* Get the current text metrics.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#getTextMetrics
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2020-05-30 12:53:48 +00:00
|
|
|
* @return {Phaser.Types.GameObjects.Text.TextMetrics} The text metrics.
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-04-26 14:54:23 +00:00
|
|
|
getTextMetrics: function ()
|
|
|
|
{
|
|
|
|
return this.style.getTextMetrics();
|
|
|
|
},
|
|
|
|
|
2018-08-20 16:41:05 +00:00
|
|
|
/**
|
|
|
|
* The text string being rendered by this Text Game Object.
|
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.Text#text
|
|
|
|
* @type {string}
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
|
|
|
text: {
|
|
|
|
|
|
|
|
get: function ()
|
|
|
|
{
|
|
|
|
return this._text;
|
|
|
|
},
|
|
|
|
|
|
|
|
set: function (value)
|
|
|
|
{
|
|
|
|
this.setText(value);
|
|
|
|
}
|
|
|
|
|
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-06-14 13:27:31 +00:00
|
|
|
* Build a JSON representation of the Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#toJSON
|
|
|
|
* @since 3.0.0
|
|
|
|
*
|
2019-05-09 11:01:00 +00:00
|
|
|
* @return {Phaser.Types.GameObjects.JSONGameObject} A JSON representation of the Text object.
|
2018-02-07 00:18:22 +00:00
|
|
|
*/
|
2017-04-12 23:35:27 +00:00
|
|
|
toJSON: function ()
|
|
|
|
{
|
|
|
|
var out = Components.ToJSON(this);
|
|
|
|
|
|
|
|
// Extra Text data is added here
|
|
|
|
|
|
|
|
var data = {
|
|
|
|
autoRound: this.autoRound,
|
2018-08-20 16:41:05 +00:00
|
|
|
text: this._text,
|
2017-04-25 17:24:37 +00:00
|
|
|
style: this.style.toJSON(),
|
2017-04-12 23:35:27 +00:00
|
|
|
padding: {
|
2017-11-30 17:17:18 +00:00
|
|
|
left: this.padding.left,
|
|
|
|
right: this.padding.right,
|
|
|
|
top: this.padding.top,
|
|
|
|
bottom: this.padding.bottom
|
2017-04-12 23:35:27 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
out.data = data;
|
|
|
|
|
|
|
|
return out;
|
2017-11-30 01:20:02 +00:00
|
|
|
},
|
|
|
|
|
2021-06-12 04:44:23 +00:00
|
|
|
/**
|
|
|
|
* Internal context-restored handler.
|
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#onContextRestored
|
|
|
|
* @protected
|
2021-09-20 10:41:47 +00:00
|
|
|
* @since 3.60.0
|
2021-06-12 04:44:23 +00:00
|
|
|
*/
|
|
|
|
onContextRestored: function ()
|
|
|
|
{
|
|
|
|
this.dirty = true;
|
|
|
|
},
|
|
|
|
|
2018-02-07 00:18:22 +00:00
|
|
|
/**
|
2018-05-22 14:55:02 +00:00
|
|
|
* Internal destroy handler, called as part of the destroy process.
|
2018-02-07 00:18:22 +00:00
|
|
|
*
|
|
|
|
* @method Phaser.GameObjects.Text#preDestroy
|
2018-05-22 14:55:02 +00:00
|
|
|
* @protected
|
2018-02-07 00:18:22 +00:00
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
2017-11-30 01:20:02 +00:00
|
|
|
preDestroy: function ()
|
|
|
|
{
|
|
|
|
if (this.style.rtl)
|
|
|
|
{
|
|
|
|
RemoveFromDOM(this.canvas);
|
|
|
|
}
|
|
|
|
|
|
|
|
CanvasPool.remove(this.canvas);
|
2018-08-03 18:07:12 +00:00
|
|
|
|
|
|
|
this.texture.destroy();
|
2021-06-12 04:44:23 +00:00
|
|
|
|
|
|
|
this.scene.sys.game.events.off(GameEvents.CONTEXT_RESTORED, this.onContextRestored, this);
|
2017-03-21 23:14:25 +00:00
|
|
|
}
|
2017-11-30 01:20:02 +00:00
|
|
|
|
2019-02-25 17:07:09 +00:00
|
|
|
/**
|
|
|
|
* The horizontal origin of this Game Object.
|
|
|
|
* The origin maps the relationship between the size and position of the Game Object.
|
|
|
|
* The default value is 0.5, meaning all Game Objects are positioned based on their center.
|
|
|
|
* Setting the value to 0 means the position now relates to the left of the Game Object.
|
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.Text#originX
|
|
|
|
* @type {number}
|
|
|
|
* @default 0
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The vertical origin of this Game Object.
|
|
|
|
* The origin maps the relationship between the size and position of the Game Object.
|
|
|
|
* The default value is 0.5, meaning all Game Objects are positioned based on their center.
|
|
|
|
* Setting the value to 0 means the position now relates to the top of the Game Object.
|
|
|
|
*
|
|
|
|
* @name Phaser.GameObjects.Text#originY
|
|
|
|
* @type {number}
|
|
|
|
* @default 0
|
|
|
|
* @since 3.0.0
|
|
|
|
*/
|
|
|
|
|
2017-03-13 23:38:48 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
module.exports = Text;
|