Javascript 如何在HTML画布圆圈中居中放置图像?
我对画布非常陌生,所以我不知道它是如何工作的。 这是我画在屏幕中间的圆的代码。< /P>Javascript 如何在HTML画布圆圈中居中放置图像?,javascript,html,reactjs,canvas,html5-canvas,Javascript,Html,Reactjs,Canvas,Html5 Canvas,我对画布非常陌生,所以我不知道它是如何工作的。 这是我画在屏幕中间的圆的代码。< /P> ctx.save(); ctx.beginPath(); ctx.arc(canvas.width / 2, canvas.height / 2, radius, 0, 2 * Math.PI); ctx.strokeStyle = "#2465D3"; ctx.stroke(); ctx.clip();
ctx.save();
ctx.beginPath();
ctx.arc(canvas.width / 2, canvas.height / 2, radius, 0, 2 * Math.PI);
ctx.strokeStyle = "#2465D3";
ctx.stroke();
ctx.clip();
ctx.drawImage(imageFile, 200, 200, 500, 500);
ctx.restore();
ctx.stroke();
我想展示一张圆圈内的图片。
图片显示在圆圈中的错误位置,带有此代码。我希望图片位于圆圈的中心,如:
根据的语法,我需要dx
和dy
在此ctx.drawImage(image,dx,dy,dWidth,dHeight)
中正确定位画布上的图像(在圆的中心)
我能做些什么,把图片放在圆圈的中心,而不做任何事情
毕达哥拉斯计算
我为什么这样做?
我无法为图片找到一个好的坐标并继续,因为圆的半径不是恒定的,所以这不起作用。每次圆的半径改变,使图片保持在圆的中间时,我需要为图片找到合适的坐标。< /P>
ctx.drawImage(
oneMoreRound,
canvas.width / 2,
canvas.height / 2,
radius * 2,
radius * 2
);
我的思考过程是找到正方形的角坐标,这个圆在这张图中是这样的
然后测量该点与画布宽度之间的距离
我想一定有更好的办法。有更好的方法吗?我在一个React应用程序中使用它。您的图像M的x和y位置必须等于圆。高度和宽度图像M必须具有2r
x = canvas.width / 2;
y = canvas.height / 2
ctx.save();
ctx.beginPath();
ctx.arc(x,y, radius, 0, 2 * Math.PI);
ctx.strokeStyle = "#2465D3";
ctx.stroke();
ctx.clip();
ctx.drawImage(imageFile, x, y, 2 * radius, 2 * radius);
ctx.restore();
ctx.stroke();
此处
canvas.width/2
和canvas.height/2
是圆中心的坐标
ctx.drawImage(
oneMoreRound,
canvas.width / 2,
canvas.height / 2,
radius * 2,
radius * 2
);
仅通过上面的代码,图像的左上角就会位于圆的中心,如下所示:
从x
和y
坐标中减去半径会将图像的左上角置于圆将创建的正方形的左上角。如果图像是正方形,则会将图像放置在正确的位置
这就是解决方案
ctx.drawImage(
oneMoreRound,
canvas.width / 2 - radius,
canvas.height / 2 - radius,
radius * 2,
radius * 2
);
图像是否应该缩放以适应圆?@GabrielePetrioli是的,我希望图像的大小随着圆半径的变化而变化,以便与圆匹配。如果你能展示给我看,我会非常感激。谢谢你,伙计,这有助于解决问题。