ОНОВЛЕННЯ - для прикладу цієї роботи я використав цю техніку в редакторі Carota .
Виходячи з відповіді ellisbben, ось розширена версія для отримання підйому і спуску з базової лінії, тобто такою ж, як tmAscent
і tmDescent
повертається GetTextMetric API Win32 . Це потрібно, якщо ви хочете виконати текстовий текст із прольотами в різних шрифтах / розмірах.
Наведене вище зображення було сформовано на полотні в Safari, червоний колір - це верхня лінія, де на полотні було сказано намалювати текст, зелений - основна лінія, а синій - нижній (таким чином червоний - синій - повна висота).
Використання jQuery для лаконічності:
var getTextHeight = function(font) {
var text = $('<span>Hg</span>').css({ fontFamily: font });
var block = $('<div style="display: inline-block; width: 1px; height: 0px;"></div>');
var div = $('<div></div>');
div.append(text, block);
var body = $('body');
body.append(div);
try {
var result = {};
block.css({ verticalAlign: 'baseline' });
result.ascent = block.offset().top - text.offset().top;
block.css({ verticalAlign: 'bottom' });
result.height = block.offset().top - text.offset().top;
result.descent = result.height - result.ascent;
} finally {
div.remove();
}
return result;
};
На додаток до текстового елемента, я додаю div з, display: inline-block
щоб я міг встановити його vertical-align
стиль, а потім з’ясувати, куди його розмістив браузер.
Таким чином, ви отримуєте назад об’єкт з ascent
, descent
і height
(що просто ascent
+ descent
для зручності). Щоб перевірити це, варто мати функцію, яка малює горизонтальну лінію:
var testLine = function(ctx, x, y, len, style) {
ctx.strokeStyle = style;
ctx.beginPath();
ctx.moveTo(x, y);
ctx.lineTo(x + len, y);
ctx.closePath();
ctx.stroke();
};
Потім ви можете бачити, як текст розташований на полотні відносно верхньої, базової та нижньої:
var font = '36pt Times';
var message = 'Big Text';
ctx.fillStyle = 'black';
ctx.textAlign = 'left';
ctx.textBaseline = 'top'; // important!
ctx.font = font;
ctx.fillText(message, x, y);
// Canvas can tell us the width
var w = ctx.measureText(message).width;
// New function gets the other info we need
var h = getTextHeight(font);
testLine(ctx, x, y, w, 'red');
testLine(ctx, x, y + h.ascent, w, 'green');
testLine(ctx, x, y + h.height, w, 'blue');