phaser/src/gameobjects/text/TextStyle.js

1100 lines
30 KiB
JavaScript
Raw Normal View History

2018-02-12 16:01:20 +00:00
/**
* @author Richard Davey <rich@photonstorm.com>
2023-01-02 17:36:27 +00:00
* @copyright 2013-2023 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
*/
var Class = require('../../utils/Class');
var GetAdvancedValue = require('../../utils/object/GetAdvancedValue');
2018-02-07 00:18:22 +00:00
var GetValue = require('../../utils/object/GetValue');
var MeasureText = require('./MeasureText');
// Key: [ Object Key, Default Value ]
var propertyMap = {
fontFamily: [ 'fontFamily', 'Courier' ],
fontSize: [ 'fontSize', '16px' ],
fontStyle: [ 'fontStyle', '' ],
backgroundColor: [ 'backgroundColor', null ],
color: [ 'color', '#fff' ],
stroke: [ 'stroke', '#fff' ],
strokeThickness: [ 'strokeThickness', 0 ],
shadowOffsetX: [ 'shadow.offsetX', 0 ],
shadowOffsetY: [ 'shadow.offsetY', 0 ],
shadowColor: [ 'shadow.color', '#000' ],
shadowBlur: [ 'shadow.blur', 0 ],
shadowStroke: [ 'shadow.stroke', false ],
shadowFill: [ 'shadow.fill', false ],
align: [ 'align', 'left' ],
maxLines: [ 'maxLines', 0 ],
2018-02-07 02:46:11 +00:00
fixedWidth: [ 'fixedWidth', 0 ],
fixedHeight: [ 'fixedHeight', 0 ],
resolution: [ 'resolution', 0 ],
rtl: [ 'rtl', false ],
testString: [ 'testString', '|MÉqgy' ],
baselineX: [ 'baselineX', 1.2 ],
baselineY: [ 'baselineY', 1.4 ],
wordWrapWidth: [ 'wordWrap.width', null ],
wordWrapCallback: [ 'wordWrap.callback', null ],
wordWrapCallbackScope: [ 'wordWrap.callbackScope', null ],
wordWrapUseAdvanced: [ 'wordWrap.useAdvancedWrap', false ]
};
2018-02-07 02:46:11 +00:00
/**
2018-02-07 15:27:21 +00:00
* @classdesc
2019-02-01 18:02:58 +00:00
* A TextStyle class manages all of the style settings for a Text object.
2020-07-13 12:01:41 +00:00
*
2019-02-01 18:02:58 +00:00
* Text Game Objects create a TextStyle instance automatically, which is
* accessed via the `Text.style` property. You do not normally need to
* instantiate one yourself.
2018-02-07 02:46:11 +00:00
*
* @class TextStyle
2019-02-01 18:02:58 +00:00
* @memberof Phaser.GameObjects
2018-02-07 02:46:11 +00:00
* @constructor
* @since 3.0.0
*
* @param {Phaser.GameObjects.Text} text - The Text object that this TextStyle is styling.
2019-07-02 11:32:18 +00:00
* @param {Phaser.Types.GameObjects.Text.TextStyle} style - The style settings to set.
2018-02-07 02:46:11 +00:00
*/
var TextStyle = new Class({
initialize:
function TextStyle (text, style)
{
2018-02-07 02:46:11 +00:00
/**
* The Text object that this TextStyle is styling.
*
2019-02-01 18:02:58 +00:00
* @name Phaser.GameObjects.TextStyle#parent
2018-02-07 02:46:11 +00:00
* @type {Phaser.GameObjects.Text}
* @since 3.0.0
*/
this.parent = text;
2018-02-07 02:46:11 +00:00
/**
* The font family.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @name Phaser.GameObjects.TextStyle#fontFamily
2018-02-07 02:46:11 +00:00
* @type {string}
* @default 'Courier'
* @since 3.0.0
*/
this.fontFamily;
2018-02-07 02:46:11 +00:00
/**
* The font size.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @name Phaser.GameObjects.TextStyle#fontSize
2022-09-21 20:10:52 +00:00
* @type {(string|number)}
2018-02-07 02:46:11 +00:00
* @default '16px'
* @since 3.0.0
*/
this.fontSize;
2018-02-07 02:46:11 +00:00
/**
* The font style.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @name Phaser.GameObjects.TextStyle#fontStyle
2018-02-07 02:46:11 +00:00
* @type {string}
* @since 3.0.0
*/
this.fontStyle;
2018-02-07 02:46:11 +00:00
/**
* The background color.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @name Phaser.GameObjects.TextStyle#backgroundColor
2018-02-07 02:46:11 +00:00
* @type {string}
* @since 3.0.0
*/
2017-03-21 20:25:15 +00:00
this.backgroundColor;
2018-02-07 02:46:11 +00:00
/**
* The text fill color.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @name Phaser.GameObjects.TextStyle#color
* @type {string|CanvasGradient|CanvasPattern}
2018-02-07 02:46:11 +00:00
* @default '#fff'
* @since 3.0.0
*/
this.color;
2018-02-07 02:46:11 +00:00
/**
* The text stroke color.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @name Phaser.GameObjects.TextStyle#stroke
* @type {string|CanvasGradient|CanvasPattern}
2018-02-07 02:46:11 +00:00
* @default '#fff'
* @since 3.0.0
*/
2017-03-21 20:25:15 +00:00
this.stroke;
2018-02-07 02:46:11 +00:00
/**
* The text stroke thickness.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @name Phaser.GameObjects.TextStyle#strokeThickness
2018-02-07 02:46:11 +00:00
* @type {number}
* @default 0
* @since 3.0.0
*/
2017-03-21 20:25:15 +00:00
this.strokeThickness;
2018-02-07 02:46:11 +00:00
/**
* The horizontal shadow offset.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @name Phaser.GameObjects.TextStyle#shadowOffsetX
2018-02-07 02:46:11 +00:00
* @type {number}
* @default 0
* @since 3.0.0
*/
2017-03-21 20:25:15 +00:00
this.shadowOffsetX;
2018-02-07 02:46:11 +00:00
/**
* The vertical shadow offset.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @name Phaser.GameObjects.TextStyle#shadowOffsetY
2018-02-07 02:46:11 +00:00
* @type {number}
* @default 0
* @since 3.0.0
*/
2017-03-21 20:25:15 +00:00
this.shadowOffsetY;
2018-02-07 02:46:11 +00:00
/**
* The shadow color.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @name Phaser.GameObjects.TextStyle#shadowColor
2018-02-07 02:46:11 +00:00
* @type {string}
* @default '#000'
* @since 3.0.0
*/
2017-03-21 20:25:15 +00:00
this.shadowColor;
2018-02-07 02:46:11 +00:00
/**
* The shadow blur radius.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @name Phaser.GameObjects.TextStyle#shadowBlur
2018-02-07 02:46:11 +00:00
* @type {number}
* @default 0
* @since 3.0.0
*/
2017-03-21 20:25:15 +00:00
this.shadowBlur;
2018-02-07 02:46:11 +00:00
/**
* Whether shadow stroke is enabled or not.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @name Phaser.GameObjects.TextStyle#shadowStroke
2018-02-07 02:46:11 +00:00
* @type {boolean}
* @default false
* @since 3.0.0
*/
2017-03-21 20:25:15 +00:00
this.shadowStroke;
2018-02-07 02:46:11 +00:00
/**
* Whether shadow fill is enabled or not.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @name Phaser.GameObjects.TextStyle#shadowFill
2018-02-07 02:46:11 +00:00
* @type {boolean}
* @default false
* @since 3.0.0
*/
2017-03-21 20:25:15 +00:00
this.shadowFill;
2018-02-07 02:46:11 +00:00
/**
* The text alignment.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @name Phaser.GameObjects.TextStyle#align
2018-02-07 02:46:11 +00:00
* @type {string}
* @default 'left'
* @since 3.0.0
*/
2017-03-21 20:25:15 +00:00
this.align;
2018-02-07 02:46:11 +00:00
/**
* The maximum number of lines to draw.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @name Phaser.GameObjects.TextStyle#maxLines
2020-11-23 10:22:13 +00:00
* @type {number}
2018-02-07 02:46:11 +00:00
* @default 0
* @since 3.0.0
*/
2017-03-21 20:25:15 +00:00
this.maxLines;
2018-02-07 02:46:11 +00:00
/**
* The fixed width of the text.
*
* `0` means no fixed with.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @name Phaser.GameObjects.TextStyle#fixedWidth
2018-02-07 02:46:11 +00:00
* @type {number}
* @default 0
* @since 3.0.0
*/
2017-03-21 20:25:15 +00:00
this.fixedWidth;
2018-02-07 02:46:11 +00:00
/**
* The fixed height of the text.
*
* `0` means no fixed height.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @name Phaser.GameObjects.TextStyle#fixedHeight
2018-02-07 02:46:11 +00:00
* @type {number}
* @default 0
* @since 3.0.0
*/
2017-03-21 20:25:15 +00:00
this.fixedHeight;
2018-02-07 02:46:11 +00:00
/**
* The resolution the text is rendered to its internal canvas at.
* The default is 0, which means it will use the resolution set in the Game Config.
*
2019-02-01 18:02:58 +00:00
* @name Phaser.GameObjects.TextStyle#resolution
* @type {number}
* @default 0
* @since 3.12.0
*/
this.resolution;
2018-02-07 02:46:11 +00:00
/**
* Whether the text should render right to left.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @name Phaser.GameObjects.TextStyle#rtl
2018-02-07 02:46:11 +00:00
* @type {boolean}
* @default false
* @since 3.0.0
*/
2017-03-21 20:25:15 +00:00
this.rtl;
2018-02-07 02:46:11 +00:00
/**
* The test string to use when measuring the font.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @name Phaser.GameObjects.TextStyle#testString
2018-02-07 02:46:11 +00:00
* @type {string}
* @default '|MÉqgy'
* @since 3.0.0
*/
this.testString;
2017-03-21 20:25:15 +00:00
/**
* The amount of horizontal padding added to the width of the text when calculating the font metrics.
*
2019-02-01 18:02:58 +00:00
* @name Phaser.GameObjects.TextStyle#baselineX
* @type {number}
* @default 1.2
* @since 3.3.0
*/
this.baselineX;
/**
* The amount of vertical padding added to the height of the text when calculating the font metrics.
*
2019-02-01 18:02:58 +00:00
* @name Phaser.GameObjects.TextStyle#baselineY
* @type {number}
* @default 1.4
* @since 3.3.0
*/
this.baselineY;
/**
* The maximum width of a line of text in pixels. Null means no line wrapping. Setting this
* property directly will not re-run the word wrapping algorithm. To change the width and
* re-wrap, use {@link Phaser.GameObjects.TextStyle#setWordWrapWidth}.
*
* @name Phaser.GameObjects.TextStyle#wordWrapWidth
* @type {number | null}
* @default null
2020-07-13 12:01:41 +00:00
* @since 3.24.0
*/
this.wordWrapWidth;
/**
* A custom function that will be responsible for wrapping the 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. Setting this directly will not re-run the
* word wrapping algorithm. To change the callback and re-wrap, use
* {@link Phaser.GameObjects.TextStyle#setWordWrapCallback}.
2020-07-13 12:01:41 +00:00
*
* @name Phaser.GameObjects.TextStyle#wordWrapCallback
* @type {TextStyleWordWrapCallback | null}
* @default null
2020-07-13 12:01:41 +00:00
* @since 3.24.0
*/
this.wordWrapCallback;
/**
* The scope that will be applied when the wordWrapCallback is invoked. Setting this directly will not re-run the
* word wrapping algorithm. To change the callback and re-wrap, use
* {@link Phaser.GameObjects.TextStyle#setWordWrapCallback}.
2020-07-13 12:01:41 +00:00
*
* @name Phaser.GameObjects.TextStyle#wordWrapCallbackScope
* @type {object | null}
* @default null
2020-07-13 12:01:41 +00:00
* @since 3.24.0
*/
this.wordWrapCallbackScope;
/**
* 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. Setting
* this property directly will not re-run the word wrapping algorithm. To change the
* advanced setting and re-wrap, use {@link Phaser.GameObjects.TextStyle#setWordWrapWidth}.
2020-07-13 12:01:41 +00:00
*
* @name Phaser.GameObjects.TextStyle#wordWrapUseAdvanced
* @type {boolean}
* @default false
2020-07-13 12:01:41 +00:00
* @since 3.24.0
*/
this.wordWrapUseAdvanced;
2018-02-07 02:46:11 +00:00
/**
* The font style, size and family.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @name Phaser.GameObjects.TextStyle#_font
2018-02-07 02:46:11 +00:00
* @type {string}
* @private
* @since 3.0.0
*/
this._font;
// Set to defaults + user style
this.setStyle(style, false, true);
},
2018-02-07 02:46:11 +00:00
/**
* Set the text style.
*
* @example
* text.setStyle({
* fontSize: '64px',
* fontFamily: 'Arial',
* color: '#ffffff',
* align: 'center',
* backgroundColor: '#ff00ff'
* });
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#setStyle
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*
2019-07-02 11:32:18 +00:00
* @param {Phaser.Types.GameObjects.Text.TextStyle} style - The style settings to set.
* @param {boolean} [updateText=true] - Whether to update the text immediately.
* @param {boolean} [setDefaults=false] - Use the default values is not set, or the local values.
2018-02-07 02:46:11 +00:00
*
* @return {Phaser.GameObjects.Text} The parent Text object.
2018-02-07 02:46:11 +00:00
*/
setStyle: function (style, updateText, setDefaults)
2017-03-21 20:25:15 +00:00
{
if (updateText === undefined) { updateText = true; }
if (setDefaults === undefined) { setDefaults = false; }
// Avoid type mutation
2020-07-13 12:01:41 +00:00
// eslint-disable-next-line no-prototype-builtins
if (style && style.hasOwnProperty('fontSize') && typeof style.fontSize === 'number')
{
style.fontSize = style.fontSize.toString() + 'px';
}
2017-03-21 20:25:15 +00:00
for (var key in propertyMap)
{
var value = (setDefaults) ? propertyMap[key][1] : this[key];
if (key === 'wordWrapCallback' || key === 'wordWrapCallbackScope')
{
// Callback & scope should be set without processing the values
this[key] = GetValue(style, propertyMap[key][0], value);
}
else
{
this[key] = GetAdvancedValue(style, propertyMap[key][0], value);
}
}
2017-12-01 03:11:57 +00:00
// Allow for 'font' override
var font = GetValue(style, 'font', null);
if (font !== null)
2017-12-01 03:11:57 +00:00
{
this.setFont(font, false);
2017-12-01 03:11:57 +00:00
}
2018-10-19 12:35:30 +00:00
this._font = [ this.fontStyle, this.fontSize, this.fontFamily ].join(' ').trim();
2017-12-01 03:11:57 +00:00
// Allow for 'fill' to be used in place of 'color'
var fill = GetValue(style, 'fill', null);
if (fill !== null)
{
this.color = fill;
}
var metrics = GetValue(style, 'metrics', false);
// Provide optional TextMetrics in the style object to avoid the canvas look-up / scanning
// Doing this is reset if you then change the font of this TextStyle after creation
if (metrics)
{
this.metrics = {
ascent: GetValue(metrics, 'ascent', 0),
descent: GetValue(metrics, 'descent', 0),
fontSize: GetValue(metrics, 'fontSize', 0)
};
}
2022-06-22 13:22:52 +00:00
else if (updateText || !this.metrics)
{
this.metrics = MeasureText(this);
}
if (updateText)
{
return this.parent.updateText();
}
else
{
return this.parent;
2017-03-21 20:25:15 +00:00
}
},
2018-02-07 02:46:11 +00:00
/**
* Synchronize the font settings to the given Canvas Rendering Context.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#syncFont
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*
* @param {HTMLCanvasElement} canvas - The Canvas Element.
* @param {CanvasRenderingContext2D} context - The Canvas Rendering Context.
2018-02-07 02:46:11 +00:00
*/
syncFont: function (canvas, context)
{
context.font = this._font;
},
2018-02-07 02:46:11 +00:00
/**
* Synchronize the text style settings to the given Canvas Rendering Context.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#syncStyle
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*
* @param {HTMLCanvasElement} canvas - The Canvas Element.
* @param {CanvasRenderingContext2D} context - The Canvas Rendering Context.
2018-02-07 02:46:11 +00:00
*/
syncStyle: function (canvas, context)
{
context.textBaseline = 'alphabetic';
context.fillStyle = this.color;
context.strokeStyle = this.stroke;
context.lineWidth = this.strokeThickness;
context.lineCap = 'round';
context.lineJoin = 'round';
},
2018-02-07 02:46:11 +00:00
/**
* Synchronize the shadow settings to the given Canvas Rendering Context.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#syncShadow
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*
* @param {CanvasRenderingContext2D} context - The Canvas Rendering Context.
* @param {boolean} enabled - Whether shadows are enabled or not.
2018-02-07 02:46:11 +00:00
*/
2017-03-20 16:48:04 +00:00
syncShadow: function (context, enabled)
{
2017-03-20 16:48:04 +00:00
if (enabled)
{
2017-03-21 20:25:15 +00:00
context.shadowOffsetX = this.shadowOffsetX;
context.shadowOffsetY = this.shadowOffsetY;
context.shadowColor = this.shadowColor;
context.shadowBlur = this.shadowBlur;
}
2017-03-20 16:48:04 +00:00
else
{
context.shadowOffsetX = 0;
context.shadowOffsetY = 0;
context.shadowColor = 0;
context.shadowBlur = 0;
}
},
2018-02-07 02:46:11 +00:00
/**
* Update the style settings for the parent Text object.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#update
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*
* @param {boolean} recalculateMetrics - Whether to recalculate font and text metrics.
2018-02-07 02:46:11 +00:00
*
* @return {Phaser.GameObjects.Text} The parent Text object.
*/
update: function (recalculateMetrics)
{
if (recalculateMetrics)
{
this._font = [ this.fontStyle, this.fontSize, this.fontFamily ].join(' ').trim();
this.metrics = MeasureText(this);
}
return this.parent.updateText();
},
2018-02-07 02:46:11 +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.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#setFont
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*
* @param {(string|object)} font - The font family or font settings to set.
* @param {boolean} [updateText=true] - Whether to update the text immediately.
2018-02-07 02:46:11 +00:00
*
* @return {Phaser.GameObjects.Text} The parent Text object.
*/
setFont: function (font, updateText)
{
if (updateText === undefined) { updateText = true; }
2018-10-09 09:50:21 +00:00
var fontFamily = font;
var fontSize = '';
var fontStyle = '';
if (typeof font !== 'string')
2017-12-01 03:11:57 +00:00
{
fontFamily = GetValue(font, 'fontFamily', 'Courier');
fontSize = GetValue(font, 'fontSize', '16px');
fontStyle = GetValue(font, 'fontStyle', '');
2017-12-01 03:11:57 +00:00
}
else
{
var fontSplit = font.split(' ');
2018-10-19 12:35:30 +00:00
var i = 0;
2018-10-19 12:35:30 +00:00
fontStyle = (fontSplit.length > 2) ? fontSplit[i++] : '';
fontSize = fontSplit[i++] || '16px';
fontFamily = fontSplit[i++] || 'Courier';
}
if (fontFamily !== this.fontFamily || fontSize !== this.fontSize || fontStyle !== this.fontStyle)
2017-12-01 03:11:57 +00:00
{
this.fontFamily = fontFamily;
this.fontSize = fontSize;
this.fontStyle = fontStyle;
2018-10-09 09:50:21 +00:00
if (updateText)
{
this.update(true);
}
2017-12-01 03:11:57 +00:00
}
return this.parent;
},
2018-02-07 02:46:11 +00:00
/**
* Set the font family.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#setFontFamily
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*
* @param {string} family - The font family.
2018-02-07 02:46:11 +00:00
*
* @return {Phaser.GameObjects.Text} The parent Text object.
*/
setFontFamily: function (family)
{
if (this.fontFamily !== family)
{
this.fontFamily = family;
this.update(true);
}
return this.parent;
},
2018-02-07 02:46:11 +00:00
/**
* Set the font style.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#setFontStyle
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*
* @param {string} style - The font style.
2018-02-07 02:46:11 +00:00
*
* @return {Phaser.GameObjects.Text} The parent Text object.
*/
setFontStyle: function (style)
{
if (this.fontStyle !== style)
{
this.fontStyle = style;
this.update(true);
}
return this.parent;
},
2018-02-07 02:46:11 +00:00
/**
2022-09-21 20:10:52 +00:00
* Set the font size. Can be a string with a valid CSS unit, i.e. `16px`, or a number.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#setFontSize
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*
* @param {(number|string)} size - The font size.
2018-02-07 02:46:11 +00:00
*
* @return {Phaser.GameObjects.Text} The parent Text object.
*/
setFontSize: function (size)
{
if (typeof size === 'number')
{
size = size.toString() + 'px';
}
if (this.fontSize !== size)
{
this.fontSize = size;
this.update(true);
}
return this.parent;
},
2018-02-07 02:46:11 +00:00
/**
* Set the test string to use when measuring the font.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#setTestString
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*
* @param {string} string - The test string to use when measuring the font.
2018-02-07 02:46:11 +00:00
*
* @return {Phaser.GameObjects.Text} The parent Text object.
*/
setTestString: function (string)
{
this.testString = string;
return this.update(true);
},
2018-02-07 02:46:11 +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 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#setFixedSize
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*
* @param {number} width - The fixed width to set.
* @param {number} height - The fixed height to set.
2018-02-07 02:46:11 +00:00
*
* @return {Phaser.GameObjects.Text} The parent Text object.
*/
setFixedSize: function (width, height)
{
this.fixedWidth = width;
this.fixedHeight = height;
if (width)
{
this.parent.width = width;
}
if (height)
{
this.parent.height = height;
}
return this.update(false);
},
2018-02-07 02:46:11 +00:00
/**
* Set the background color.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#setBackgroundColor
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*
* @param {string} color - The background color.
2018-02-07 02:46:11 +00:00
*
* @return {Phaser.GameObjects.Text} The parent Text object.
*/
setBackgroundColor: function (color)
{
this.backgroundColor = color;
return this.update(false);
},
2018-02-07 02:46:11 +00:00
/**
* Set the text fill color.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#setFill
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*
* @param {string} color - The text fill color.
2018-02-07 02:46:11 +00:00
*
* @return {Phaser.GameObjects.Text} The parent Text object.
*/
2017-12-01 03:11:57 +00:00
setFill: function (color)
{
this.color = color;
return this.update(false);
},
2018-02-07 02:46:11 +00:00
/**
* Set the text fill color.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#setColor
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*
* @param {string|CanvasGradient|CanvasPattern} color - The text fill color.
2018-02-07 02:46:11 +00:00
*
* @return {Phaser.GameObjects.Text} The parent Text object.
*/
setColor: function (color)
{
this.color = color;
return this.update(false);
},
2018-07-18 13:45:10 +00:00
/**
* Set the resolution used by the Text object.
*
2023-10-13 13:45:49 +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-07-13 12:01:41 +00:00
*
2018-07-18 13:45:10 +00:00
* Please use with caution, as the more high res Text you have, the more memory it uses up.
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#setResolution
2018-07-18 13:45:10 +00:00
* @since 3.12.0
*
* @param {number} value - The resolution for this Text object to use.
*
* @return {Phaser.GameObjects.Text} The parent Text object.
*/
setResolution: function (value)
{
this.resolution = value;
return this.update(false);
},
2018-02-07 02:46:11 +00:00
/**
* Set the stroke settings.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#setStroke
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*
* @param {string|CanvasGradient|CanvasPattern} color - The stroke color.
* @param {number} thickness - The stroke thickness.
2018-02-07 02:46:11 +00:00
*
* @return {Phaser.GameObjects.Text} The parent Text object.
*/
setStroke: function (color, thickness)
{
if (thickness === undefined) { thickness = this.strokeThickness; }
if (color === undefined && this.strokeThickness !== 0)
{
// Reset the stroke to zero (disabling it)
this.strokeThickness = 0;
this.update(true);
}
else if (this.stroke !== color || this.strokeThickness !== thickness)
{
this.stroke = color;
this.strokeThickness = thickness;
this.update(true);
}
return this.parent;
},
2018-02-07 02:46:11 +00:00
/**
* Set the shadow settings.
2020-07-13 12:01:41 +00:00
*
* Calling this method always re-measures the parent Text object,
* so only call it when you actually change the shadow settings.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#setShadow
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*
* @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 02:46:11 +00:00
*
* @return {Phaser.GameObjects.Text} The parent Text object.
*/
setShadow: function (x, y, color, blur, shadowStroke, shadowFill)
{
2017-03-20 16:48:04 +00:00
if (x === undefined) { x = 0; }
if (y === undefined) { y = 0; }
if (color === undefined) { color = '#000'; }
if (blur === undefined) { blur = 0; }
if (shadowStroke === undefined) { shadowStroke = false; }
2017-08-11 15:59:29 +00:00
if (shadowFill === undefined) { shadowFill = true; }
this.shadowOffsetX = x;
this.shadowOffsetY = y;
this.shadowColor = color;
this.shadowBlur = blur;
this.shadowStroke = shadowStroke;
this.shadowFill = shadowFill;
return this.update(false);
},
2018-02-07 02:46:11 +00:00
/**
* Set the shadow offset.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#setShadowOffset
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*
* @param {number} [x=0] - The horizontal shadow offset.
* @param {number} [y=0] - The vertical shadow offset.
2018-02-07 02:46:11 +00:00
*
* @return {Phaser.GameObjects.Text} The parent Text object.
*/
setShadowOffset: function (x, y)
{
if (x === undefined) { x = 0; }
if (y === undefined) { y = x; }
this.shadowOffsetX = x;
this.shadowOffsetY = y;
return this.update(false);
},
2018-02-07 02:46:11 +00:00
/**
* Set the shadow color.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#setShadowColor
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*
* @param {string} [color='#000'] - The shadow color.
2018-02-07 02:46:11 +00:00
*
* @return {Phaser.GameObjects.Text} The parent Text object.
*/
setShadowColor: function (color)
{
if (color === undefined) { color = '#000'; }
this.shadowColor = color;
return this.update(false);
},
2018-02-07 02:46:11 +00:00
/**
* Set the shadow blur radius.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#setShadowBlur
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*
* @param {number} [blur=0] - The shadow blur radius.
2018-02-07 02:46:11 +00:00
*
* @return {Phaser.GameObjects.Text} The parent Text object.
*/
setShadowBlur: function (blur)
{
if (blur === undefined) { blur = 0; }
this.shadowBlur = blur;
return this.update(false);
},
2018-02-07 02:46:11 +00:00
/**
* Enable or disable shadow stroke.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#setShadowStroke
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*
* @param {boolean} enabled - Whether shadow stroke is enabled or not.
2018-02-07 02:46:11 +00:00
*
* @return {Phaser.GameObjects.Text} The parent Text object.
*/
setShadowStroke: function (enabled)
{
this.shadowStroke = enabled;
return this.update(false);
},
2018-02-07 02:46:11 +00:00
/**
* Enable or disable shadow fill.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#setShadowFill
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*
* @param {boolean} enabled - Whether shadow fill is enabled or not.
2018-02-07 02:46:11 +00:00
*
* @return {Phaser.GameObjects.Text} The parent Text object.
*/
setShadowFill: function (enabled)
{
this.shadowFill = enabled;
return this.update(false);
},
2017-12-13 21:28:52 +00:00
/**
* Set the width (in pixels) to use for wrapping lines.
*
* Pass in null to remove wrapping by width.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#setWordWrapWidth
2018-02-07 02:46:11 +00:00
* @since 3.0.0
2017-12-13 21:28:52 +00:00
*
2018-02-07 02:46:11 +00:00
* @param {number} width - The maximum width of a line in pixels. Set to null to remove wrapping.
2017-12-13 21:28:52 +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 02:46:11 +00:00
*
* @return {Phaser.GameObjects.Text} The parent Text object.
2017-12-13 21:28:52 +00:00
*/
setWordWrapWidth: function (width, useAdvancedWrap)
{
if (useAdvancedWrap === undefined) { useAdvancedWrap = false; }
this.wordWrapWidth = width;
this.wordWrapUseAdvanced = useAdvancedWrap;
return this.update(false);
},
2017-12-13 21:28:52 +00:00
/**
* Set a custom callback for wrapping lines.
*
* Pass in null to remove wrapping by callback.
2017-12-13 21:28:52 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#setWordWrapCallback
2018-02-07 02:46:11 +00:00
* @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 02:46:11 +00:00
*
* @return {Phaser.GameObjects.Text} The parent Text object.
2017-12-13 21:28:52 +00:00
*/
setWordWrapCallback: function (callback, scope)
{
if (scope === undefined) { scope = null; }
this.wordWrapCallback = callback;
this.wordWrapCallbackScope = scope;
return this.update(false);
},
2018-02-07 02:46:11 +00:00
/**
* Set the alignment of the text in this Text object.
2020-07-13 12:01:41 +00:00
*
* The argument can be one of: `left`, `right`, `center` or `justify`.
2020-07-13 12:01:41 +00:00
*
* Alignment only works if the Text object has more than one line of text.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#setAlign
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*
* @param {string} [align='left'] - The text alignment for multi-line text.
2018-02-07 02:46:11 +00:00
*
* @return {Phaser.GameObjects.Text} The parent Text object.
*/
setAlign: function (align)
{
if (align === undefined) { align = 'left'; }
this.align = align;
return this.update(false);
},
2018-02-07 02:46:11 +00:00
/**
* Set the maximum number of lines to draw.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#setMaxLines
2018-02-07 02:46:11 +00:00
* @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 02:46:11 +00:00
*
* @return {Phaser.GameObjects.Text} The parent Text object.
*/
setMaxLines: function (max)
{
if (max === undefined) { max = 0; }
this.maxLines = max;
return this.update(false);
},
2018-02-07 02:46:11 +00:00
/**
* Get the current text metrics.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#getTextMetrics
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*
2019-05-09 14:32:53 +00:00
* @return {Phaser.Types.GameObjects.Text.TextMetrics} The text metrics.
2018-02-07 02:46:11 +00:00
*/
getTextMetrics: function ()
{
var metrics = this.metrics;
return {
ascent: metrics.ascent,
descent: metrics.descent,
fontSize: metrics.fontSize
};
},
2018-02-07 02:46:11 +00:00
/**
* Build a JSON representation of this Text Style.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#toJSON
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*
* @return {object} A JSON representation of this Text Style.
2018-02-07 02:46:11 +00:00
*/
toJSON: function ()
{
var output = {};
for (var key in propertyMap)
{
output[key] = this[key];
}
output.metrics = this.getTextMetrics();
return output;
},
2018-02-07 02:46:11 +00:00
/**
* Destroy this Text Style.
2018-02-07 02:46:11 +00:00
*
2019-02-01 18:02:58 +00:00
* @method Phaser.GameObjects.TextStyle#destroy
2018-02-07 02:46:11 +00:00
* @since 3.0.0
*/
destroy: function ()
{
this.parent = undefined;
}
});
2017-03-13 23:38:48 +00:00
module.exports = TextStyle;