javascript - 如何计算圆弧起点和终点的精确点位置

标签 javascript html canvas

我想通过计算找到圆弧的终点和起点。

您可以输入

范围半径:150

范围起始 Angular :60

范围结束 Angular :160

请参阅Demo jsFiddle

link to screen shot demonstrating problem

非常感谢

function draw(val,StartAngle,EndAngle,XAxis,YAxis){
        var canvas = document.getElementById('canvas');
        var context = canvas.getContext('2d'),
        x = 200,//center raduis
        y = 400;//center raduis
        d = EndAngle;//End Angle
        s = StartAngle;//Start angle
        X_Axis = XAxis;//feature to enable to move the circle on axis X
        Y_Axis = YAxis;// feature to enable to move the circle on axis Y

        p ={}
        p.r = val;
        p.d = d*2*Math.PI/360;
        p.s = s*2*Math.PI/360;
        p.x = X_Axis + p.d*Math.cos(p.r);
        p.y = Y_Axis + p.d*Math.sin(p.r);

        p.pex = p.x + p.r*Math.cos(d);
        p.pey = p.y - p.r*Math.sin(s);

        p.psx = p.x - Math.sin(s) * p.r;
        p.psy = p.y - Math.cos(s) * p.r ;

        context.clearRect(0, 0, canvas.width, canvas.height);

        context.beginPath();
        context.lineWidth = 1;

        context.arc(p.x ,p.y ,p.r,p.s,p.d);

        context.fillStyle = 'green';
        context.fillRect(x,y+val,2,2); // crnter circle

        context.fillStyle = 'yellow';
        context.moveTo(x-p.d,y+p.d);
        context.lineTo(x+p.d,y+p.d);

        context.stroke();

        // line color
        context.strokeStyle = 'black';
        context.stroke();

        // Cut off the top of the circle.
        //context.clearRect(0, 0, canvas.width, y);

        // This stuff's just to show some dots
        context.fillStyle = 'red';
        context.fillRect(x-1,y-1,2,2); // Middle
        context.fillRect(p.pex,p.pey,4,4);//Target point 1
        context.fillRect(p.psx,p.psy,4,4);// Target point 2

        context.fillRect(x-2,y+d+val-2,4,4); // Point on circle
        context.fillStyle = 'black';


    }

最佳答案

通用解决方案

  var r_length = ... // radius
  var r_start_angle = RangeStartAngle / 360 * 2 * Math.PI; // lets convert degrees to radians
  var r_end_angle = RangeEndAngle / 360 * 2 * Math.PI;

起始位置

  x = circle_center_x + Math.cos(r_start_angle) * r_length;
  y = circle_center_y + Math.sin(r_start_angle) * r_length;

结束位置

  x = circle_center_x + Math.cos(r_end_angle) * r_length;
  y = circle_center_y + Math.sin(r_end_angle) * r_length;

绘制圆弧

  context.arc(circle_center_x ,circle_center_y, r_start_angle, r_end_angle);

您可能想使用这些知识重写您的函数

关于javascript - 如何计算圆弧起点和终点的精确点位置,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14550278/

相关文章:

javascript - 卡住了 mootools 脚本。图像自动切换

html - 剪辑路径渐变动画在 Safari 中不起作用

javascript - 如何同时旋转整个 Canvas 和绘制到 Canvas 中的图像?

javascript - Canvas - 未捕获的类型错误 : Cannot read property 'getContext' of null

javascript - 如何在 Flot 折线图中的可悬停数据点中显示格式化时间戳?

javascript - 如何清空plupload队列

javascript - 为什么我的 CoffeeScript 函数没有执行?

javascript - d3.js : non linear graph axis

javascript - 为什么我总是无法通过 javascript 对复选框进行复选标记?

javascript - 添加浏览器历史记录和导航到 JavaScript DOM 页面更改功能