Canvasによる2つの直線を接線とする円弧の描画サンプル

icon 項目のみ表示/展開表示の切り替え

Canvasによる2つの直線を接線とする円弧の描画サンプル

最後に描画した点(x0,y0)からarcToで指定する1個目の点(x1,y1)と2個目の点(x2,y2)で指定される2つの直線を接線とする半径rの円弧を描画します。
なおx0,y0と円弧を結ぶ直線も描画されます。最後に描画される点は円弧の終点となります。

サンプル

以下の黒い点がarcToで指定している点です。

<!DOCTYPE html>
<html lang="ja">
<head>
  <meta charset="utf-8">
</head>
<body>
  <canvas id="t1" width="120" height="100">
  </canvas>
  <script type="text/javascript">
    window.onload = function(){
      var canvas = document.getElementById('t1');
      if (canvas.getContext){
        var ctx = canvas.getContext('2d');
        ctx.beginPath();
        ctx.strokeStyle = 'red';
        ctx.moveTo(10,10);
        ctx.arcTo(100,10,100,90,30);
        ctx.stroke();
      }
    }
  </script>
</body>
</html>
ソースファイルのダウンロード(arcto.zip)