Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/394.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 如何在HTML画布圆圈中居中放置图像?_Javascript_Html_Reactjs_Canvas_Html5 Canvas - Fatal编程技术网

Javascript 如何在HTML画布圆圈中居中放置图像?

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();

我对画布非常陌生,所以我不知道它是如何工作的。 这是我画在屏幕中间的圆的代码。< /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.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是的,我希望图像的大小随着圆半径的变化而变化,以便与圆匹配。如果你能展示给我看,我会非常感激。谢谢你,伙计,这有助于解决问题。