2017-03-13 23:38:48 +00:00
|
|
|
|
2017-03-15 01:07:58 +00:00
|
|
|
var Class = require('../../../utils/Class');
|
|
|
|
var GameObject = require('../../GameObject');
|
|
|
|
var Components = require('../../../components');
|
|
|
|
var CanvasPool = require('../../../dom/CanvasPool');
|
2017-03-13 23:38:48 +00:00
|
|
|
var TextRender = require('./TextRender');
|
|
|
|
var TextStyle = require('../TextStyle');
|
2017-03-15 01:07:58 +00:00
|
|
|
var GetTextSize = require('../GetTextSize');
|
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,
|
|
|
|
Components.GetBounds,
|
|
|
|
Components.Origin,
|
2017-04-11 13:15:38 +00:00
|
|
|
Components.RenderTarget,
|
2017-03-13 23:38:48 +00:00
|
|
|
Components.ScaleMode,
|
|
|
|
Components.Transform,
|
|
|
|
Components.Visible,
|
2017-03-20 23:37:17 +00:00
|
|
|
Components.Flip,
|
2017-03-13 23:38:48 +00:00
|
|
|
TextRender
|
|
|
|
],
|
|
|
|
|
|
|
|
initialize:
|
|
|
|
|
2017-03-15 01:07:58 +00:00
|
|
|
function Text (state, 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; }
|
|
|
|
if (text === undefined) { text = ''; }
|
|
|
|
|
2017-04-12 23:05:12 +00:00
|
|
|
GameObject.call(this, state, 'Text');
|
2017-03-13 23:38:48 +00:00
|
|
|
|
|
|
|
this.setPosition(x, y);
|
2017-03-20 16:28:09 +00:00
|
|
|
this.setOrigin(0, 0);
|
2017-03-13 23:38:48 +00:00
|
|
|
|
2017-03-15 01:07:58 +00:00
|
|
|
/**
|
|
|
|
* @property {HTMLCanvasElement} canvas - The canvas element that the text is rendered.
|
|
|
|
*/
|
|
|
|
this.canvas = CanvasPool.create(this);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @property {HTMLCanvasElement} context - The context of the canvas element that the text is rendered to.
|
|
|
|
*/
|
|
|
|
this.context = this.canvas.getContext('2d');
|
|
|
|
|
|
|
|
this.style = new TextStyle(this, style);
|
|
|
|
|
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.
|
|
|
|
* @property {Object} splitRegExp
|
|
|
|
*/
|
|
|
|
this.splitRegExp = /(?:\r\n|\r|\n)/;
|
|
|
|
|
2017-03-20 16:48:04 +00:00
|
|
|
this.text = (Array.isArray(text)) ? text.join('\n') : text;
|
2017-03-15 01:07:58 +00:00
|
|
|
|
|
|
|
this.resolution = 1;
|
|
|
|
|
2017-04-25 17:07:15 +00:00
|
|
|
// Move to TextStyle?
|
2017-03-15 01:07:58 +00:00
|
|
|
this.padding = { x: 0, y: 0 };
|
|
|
|
|
2017-03-15 23:08:59 +00:00
|
|
|
this.width = 1;
|
|
|
|
this.height = 1;
|
|
|
|
|
2017-03-21 20:45:57 +00:00
|
|
|
this.canvasTexture = null;
|
2017-03-21 23:14:25 +00:00
|
|
|
this.prevWidth = 0;
|
|
|
|
this.prevHeight = 0;
|
2017-03-21 21:06:36 +00:00
|
|
|
this.dirty = false;
|
2017-03-21 20:08:43 +00:00
|
|
|
|
2017-03-15 01:07:58 +00:00
|
|
|
if (text !== '')
|
|
|
|
{
|
|
|
|
this.updateText();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2017-03-15 23:44:39 +00:00
|
|
|
setText: function (value)
|
|
|
|
{
|
2017-03-20 16:48:04 +00:00
|
|
|
if (Array.isArray(value))
|
|
|
|
{
|
|
|
|
value = value.join('\n');
|
|
|
|
}
|
|
|
|
|
2017-03-15 23:44:39 +00:00
|
|
|
if (value !== this.text)
|
|
|
|
{
|
|
|
|
this.text = value;
|
2017-03-20 16:48:04 +00:00
|
|
|
|
2017-03-15 23:44:39 +00:00
|
|
|
this.updateText();
|
|
|
|
}
|
|
|
|
|
|
|
|
return this;
|
|
|
|
},
|
|
|
|
|
2017-03-16 17:15:58 +00:00
|
|
|
setStyle: function (style)
|
|
|
|
{
|
|
|
|
return this.style.setStyle(style);
|
|
|
|
},
|
|
|
|
|
2017-03-20 16:28:09 +00:00
|
|
|
setFont: function (font)
|
|
|
|
{
|
|
|
|
return this.style.setFont(font);
|
|
|
|
},
|
|
|
|
|
|
|
|
setFixedSize: function (width, height)
|
|
|
|
{
|
|
|
|
return this.style.setFixedSize(width, height);
|
|
|
|
},
|
|
|
|
|
|
|
|
setBackgroundColor: function (color)
|
|
|
|
{
|
|
|
|
return this.style.setBackgroundColor(color);
|
|
|
|
},
|
|
|
|
|
|
|
|
setFill: function (color)
|
|
|
|
{
|
|
|
|
return this.style.setFill(color);
|
|
|
|
},
|
|
|
|
|
|
|
|
setStroke: function (color, thickness)
|
|
|
|
{
|
|
|
|
return this.style.setStroke(color, thickness);
|
|
|
|
},
|
|
|
|
|
|
|
|
setShadow: function (x, y, color, blur, shadowStroke, shadowFill)
|
|
|
|
{
|
|
|
|
return this.style.setShadow(x, y, color, blur, shadowStroke, shadowFill);
|
|
|
|
},
|
|
|
|
|
|
|
|
setShadowOffset: function (x, y)
|
|
|
|
{
|
|
|
|
return this.style.setShadowOffset(x, y);
|
|
|
|
},
|
|
|
|
|
|
|
|
setShadowColor: function (color)
|
|
|
|
{
|
|
|
|
return this.style.setShadowColor(color);
|
|
|
|
},
|
|
|
|
|
|
|
|
setShadowBlur: function (blur)
|
|
|
|
{
|
|
|
|
return this.style.setShadowBlur(blur);
|
|
|
|
},
|
|
|
|
|
|
|
|
setShadowStroke: function (enabled)
|
|
|
|
{
|
|
|
|
return this.style.setShadowStroke(enabled);
|
|
|
|
},
|
|
|
|
|
|
|
|
setShadowFill: function (enabled)
|
|
|
|
{
|
|
|
|
return this.style.setShadowFill(enabled);
|
|
|
|
},
|
|
|
|
|
|
|
|
setAlign: function (align)
|
|
|
|
{
|
|
|
|
return this.style.setAlign(align);
|
|
|
|
},
|
|
|
|
|
|
|
|
setMaxLines: function (max)
|
|
|
|
{
|
|
|
|
return this.style.setMaxLines(max);
|
|
|
|
},
|
|
|
|
|
2017-03-15 01:07:58 +00:00
|
|
|
updateText: function ()
|
|
|
|
{
|
|
|
|
var canvas = this.canvas;
|
|
|
|
var context = this.context;
|
|
|
|
var style = this.style;
|
2017-03-20 16:09:01 +00:00
|
|
|
var size = style.metrics;
|
2017-03-15 01:07:58 +00:00
|
|
|
|
|
|
|
var outputText = this.text;
|
|
|
|
|
|
|
|
// if (style.wordWrap)
|
|
|
|
// {
|
|
|
|
// outputText = this.runWordWrap(this.text);
|
|
|
|
// }
|
|
|
|
|
|
|
|
// 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-03-20 16:09:01 +00:00
|
|
|
if (!style.fixedWidth)
|
|
|
|
{
|
|
|
|
this.width = textSize.width;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!style.fixedHeight)
|
|
|
|
{
|
|
|
|
this.height = textSize.height;
|
|
|
|
}
|
2017-03-15 23:08:59 +00:00
|
|
|
|
2017-03-15 23:44:39 +00:00
|
|
|
this.updateOrigin();
|
|
|
|
|
2017-04-25 18:46:13 +00:00
|
|
|
var padding = this.padding;
|
|
|
|
|
|
|
|
var w = (textSize.width + (padding.x * 2)) * this.resolution;
|
|
|
|
var h = (textSize.height + (padding.y * 2)) * this.resolution;
|
2017-03-20 16:09:01 +00:00
|
|
|
|
|
|
|
if (canvas.width !== w || canvas.height !== h)
|
|
|
|
{
|
|
|
|
canvas.width = w;
|
|
|
|
canvas.height = h;
|
|
|
|
}
|
2017-03-20 16:48:04 +00:00
|
|
|
else
|
|
|
|
{
|
|
|
|
context.clearRect(0, 0, w, h);
|
|
|
|
}
|
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-03-17 00:16:20 +00:00
|
|
|
style.syncFont(canvas, context);
|
2017-03-15 01:07:58 +00:00
|
|
|
|
2017-04-25 18:46:13 +00:00
|
|
|
context.textBaseline = 'middle';
|
|
|
|
|
|
|
|
// Apply padding
|
|
|
|
context.translate(padding.x, padding.y);
|
|
|
|
|
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);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (style.align === 'right')
|
|
|
|
{
|
|
|
|
linePositionX += textSize.width - textSize.lineWidths[i];
|
|
|
|
}
|
|
|
|
else if (style.align === 'center')
|
|
|
|
{
|
|
|
|
linePositionX += (textSize.width - textSize.lineWidths[i]) / 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
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);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (style.fill)
|
|
|
|
{
|
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-03-21 21:06:36 +00:00
|
|
|
this.dirty = true;
|
2017-03-21 20:08:43 +00:00
|
|
|
|
2017-03-20 16:28:09 +00:00
|
|
|
return this;
|
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,
|
|
|
|
text: this.text,
|
2017-04-25 17:24:37 +00:00
|
|
|
style: this.style.toJSON(),
|
2017-04-12 23:35:27 +00:00
|
|
|
resolution: this.resolution,
|
|
|
|
padding: {
|
|
|
|
x: this.padding.x,
|
|
|
|
y: this.padding.y
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
out.data = data;
|
|
|
|
|
|
|
|
return out;
|
2017-03-21 23:14:25 +00:00
|
|
|
}
|
2017-03-13 23:38:48 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
module.exports = Text;
|