我目前正在使用 HTML5 的画布使用 fillText 方法呈现多个字符串。这很好用,但我还想给每个字符串一个 1px 的黑色外描边。不幸的是, strokeText 函数似乎应用了一个内部笔划。为了解决这个问题,我编写了一个 drawStrokedText 函数来实现我想要的效果。不幸的是它太慢了(原因很明显)。
是否有一种快速、跨浏览器的方式来使用本机画布功能实现 1px 的外部笔划?
drawStrokedText = function(context, text, x, y)
{
context.fillStyle = "rgb(0,0,0)";
context.fillText(text, x-1, y-1);
context.fillText(text, x+1, y-1);
context.fillText(text, x-1, y);
context.fillText(text, x+1, y);
context.fillText(text, x-1, y+1);
context.fillText(text, x+1, y+1);
context.fillStyle = "rgb(255,255,255)";
context.fillText(text, x, y);
};
这是工作效果的示例:
原文由 ndg 发布,翻译遵循 CC BY-SA 4.0 许可协议
中风怎么了?由于一半的笔划会在形状之外,因此您始终可以先绘制笔划,线宽是您想要的两倍。所以如果你想要一个 4px 的外部描边,你可以这样做:
这使得:
现场小提琴: http://jsfiddle.net/vNWn6/
如果碰巧在较小的文本渲染比例下看起来不那么准确,你总是可以把它画大但按比例缩小(在上面的情况下你会做
ctx.scale(0.25, 0.25)
)