gpt4 book ai didi

javascript - HTML5 Canvas lineWidth 被忽略

转载 作者:行者123 更新时间:2023-11-28 20:49:13 26 4
gpt4 key购买 nike

我正在 Canvas 上书写文本,并尝试在其周围添加某种边框,该边框应根据文本大小动态调整大小。

我的代码是:

<script>
var mainText='this is a test';
var mainTextSize=40;
var mainTextDimensions=getTextDimensions(mainText,mainTextSize,'verdana');

var smallStampCanvas=document.createElement("canvas");
smallStampCanvas.width=mainTextDimensions.width;
smallStampCanvas.height=totalHeight;
var smallStampContext=smallStampCanvas.getContext('2d');
smallStampContext.textBaseline='top';

smallStampContext.fillStyle = '#FF0000';
smallStampContext.strokeStyle = smallStampContext.fillStyle;

smallStampContext.font = "bold "+mainTextSize+"px verdana";
smallStampContext.fillText(
mainText,
0,
0
);

smallStampContext.strokeRect(0,0,smallStampCanvas.width,smallStampCanvas.height);
smallStampContext.strokeRect(0,0,smallStampCanvas.width,mainTextDimensions.height);
smallStampContext.lineWidth=Math.ceil(mainTextSize/4);
smallStampContext.moveTo(0,mainTextDimensions.height); smallStampContext.lineTo(smallStampCanvas.width,mainTextDimensions.height);
</script>

除了线宽之外,一切正常。无论输入什么值似乎都没有任何效果。 (行始终为 1px)记录时输入整数 10。

有人知道可能是什么问题吗?

最佳答案

试试这个:

smallStampContext.beginPath();
smallStampContext.lineWidth=Math.ceil(mainTextSize/4);
smallStampContext.moveTo(0,mainTextDimensions.height);
smallStampContext.lineTo(smallStampCanvas.width,mainTextDimensions.height);
smallStampContext.stroke();

moveTolineTo 不绘制“线”。只有lines真正创建了这条线。

关于javascript - HTML5 Canvas lineWidth 被忽略,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12821947/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com