mirror of
https://github.com/konvajs/konva.git
synced 2025-04-05 03:13:41 +08:00
Add calculation for letter spacing to better align with css letter-spacing properties
This commit is contained in:
parent
09445e0880
commit
a24b30b110
@ -263,7 +263,7 @@ export class Text extends Shape<TextConfig> {
|
||||
var lineTranslateY = 0;
|
||||
var obj = textArr[n],
|
||||
text = obj.text,
|
||||
width = obj.width,
|
||||
width = obj.width + letterSpacing,
|
||||
lastLine = obj.lastInParagraph,
|
||||
spacesNumber,
|
||||
oneWord,
|
||||
@ -310,7 +310,7 @@ export class Text extends Shape<TextConfig> {
|
||||
spacesNumber = text.split(' ').length - 1;
|
||||
oneWord = spacesNumber === 0;
|
||||
lineWidth =
|
||||
align === JUSTIFY && !lastLine ? totalWidth - padding * 2 : width;
|
||||
align === JUSTIFY && !lastLine ? totalWidth - padding * 2 : width;
|
||||
context.lineTo(
|
||||
lineTranslateX + Math.round(lineWidth),
|
||||
translateY + lineTranslateY + yOffset
|
||||
@ -383,7 +383,8 @@ export class Text extends Shape<TextConfig> {
|
||||
return isAuto ? this.getTextWidth() + this.padding() * 2 : this.attrs.width;
|
||||
}
|
||||
getHeight() {
|
||||
const isAuto = this.attrs.height === AUTO || this.attrs.height === undefined;
|
||||
const isAuto =
|
||||
this.attrs.height === AUTO || this.attrs.height === undefined;
|
||||
return isAuto
|
||||
? this.fontSize() * this.textArr.length * this.lineHeight() +
|
||||
this.padding() * 2
|
||||
@ -501,7 +502,9 @@ export class Text extends Shape<TextConfig> {
|
||||
|
||||
this.textArr = [];
|
||||
getDummyContext().font = this._getContextFont();
|
||||
const additionalWidth = shouldAddEllipsis ? this._getTextWidth(ELLIPSIS) : 0;
|
||||
const additionalWidth = shouldAddEllipsis
|
||||
? this._getTextWidth(ELLIPSIS)
|
||||
: 0;
|
||||
for (let i = 0, max = lines.length; i < max; ++i) {
|
||||
let line = lines[i];
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user