html5 canvasで円・円弧を描画する

html5 canvasで色の指定と四角形の描画は複雑な多角形を描画する方法を紹介しました。

今回は直線だけでなく、円を描画する方法を紹介します。

円の描画方法

自由自在に曲線を描画するのは複雑な考え方が必要ですが、円(正円)を描画するだけなら1つの関数だけでできます。

円を描画する関数は半円を描画することも想定して、開始角度と終了角度も指定する必要があります。角度はrad(ラジアン)という単位で指定する必要があります。

rad(ラジアン)

高校の数学で習う内容なのですが、忘れてしまった方も多くいると思います。馴染みのある度(°)rad(ラジアン)の対応表は下記のようになります。

対応表
度(°)rad(ラジアン)
0π rad
30°1/6π rad
45°1/4π rad
60°1/3π rad
90°1/2π rad
180°π rad
360°2π rad

JavaScriptπMath.PIで取得できます。なので、180°はMath.PI、90°は(1/2)*Math.PIで指定することができます。

わかりづらい場合は、1°が(1/180)*Math.PIなので、X°を指定したい場合は(X/180)*Math.PIとすればよいです。

関数

arc(x座標, y座標, 半径, 開始角度, 終了角度 [, 方向 ] )

html5 canvasで色の指定と四角形の描画で紹介したパスの一部として使用します。

中心の座標と半径さえ指定されれば円は描画することが可能なのですが、用意されている関数はいろいろな引数を指定する必要があります。

この関数では半円を描画することも想定して、開始角度と終了角度も指定する必要があります。

$(function ($) {
  var canvas;
  var context;

  canvas = $('#c1')[0];
  if (canvas.getContext){
    context = canvas.getContext('2d');

    //パスの初期化
    context.beginPath();
    //中心座標(200,200)、半径100の円弧を、開始角度30度、終了角度180度で、時計回りに作成する
    context.arc(200, 200, 100, (30/180)*Math.PI, Math.PI);

    //定義したサブパスの線を描画
    context.strokeStyle = 'rgb(255, 0, 0)';
    context.stroke();

    //パスの初期化
    context.beginPath();
    //中心座標(400,200)、半径100の円弧を、開始角度90度、終了角度270度で、反時計回りに作成する
    context.arc(400, 200, 100, (90/180)*Math.PI, (270/180)*Math.PI, true);
    //定義したサブパスの線を描画
    context.strokeStyle = 'rgb(0, 0, 255)';
    context.stroke();

    //パスの初期化
    context.beginPath();
    //中心座標(300,300)、半径100の円弧を、開始角度0度、終了角度360度で、時計回りに作成する
    context.arc(300, 300, 100, (0/180)*Math.PI, (360/180)*Math.PI);
    //定義したサブパスの線を描画
    context.strokeStyle = 'rgb(0, 255, 0)';
    context.stroke();
  }
});

関連記事

  • html5 marginとpaddingで余白を設定する

    htmlで余白の設定をするときは、marginとpaddingのスタイルを使用します。例えば、以下のように色を分けて表示しても、要素どうしがくっついてしまい、わかりづらくなってしまいますので、余白を設...


  • html5 classを使って同じstyleをまとめる

    スタイルを各要素の中にたくさん書くとわかりづらくなってしまいます。以下のように、同じスタイルを複数の箇所に記載しているときは、classを使えば同じスタイルを1箇所にまとめることができます。クラスはh...


  • html5 ブロック要素とインライン要素を理解する

    htmlの要素には大きく分けてブロック要素とインライン要素があります。今回はこの2つの要素の違いについて説明します。例えば以下のhtmlで、トマトについての説明の箇所の背景色を赤、ピーマンについての説...


  • html5 ボーダーのスタイルで罫線を表示する

    pタグとh1タグの段落と見出しで読みやすい文章構成を作成する方法は段落と見出しを表示して、見た目をわかりやすくしました。今回は罫線を引いて、より見た目をわかりやすくする方法を紹介します。文字色を変える...


  • pタグとh1タグの段落と見出しで読みやすい文章構成を作成する方法

    前回ホームページ入門・初心者向け html5の基本的な文法までで、htmlをブラウザで表示することができるようになりました。今回からは、実際にhtmlでのいろいろな表現方法を紹介していき、最終的にはき...


  • ホームページ入門・初心者向け html5の基本的な文法

    前回初めてのホームページ作成のためのhtmlの基本でホームページの作成にあたって、「htmlとは何か?」ということを説明しました。今回は、実際にhtmlをどのように書いていくのか説明します。※この記事...


  • 初めてのホームページ作成のためのhtmlの基本

    プログラミングの経験もなく、初めてホームページを作成しようと考えている人に向けて、htmlの基本を数回に分けて説明します。予備知識としてホームページの基本的な仕組みと考え方でホームページの基本的な仕組...


  • cssで三角形を表示する方法

    画像を使わずに、cssでスタイルを指定するだけで三角形を表示させる方法を紹介します。三角形を表示させるにはborder(枠線)を使用します。なぜborderで三角形を作れるのか、まずはその説明をします...


  • cssだけでホバー時にバルーンポップアップを表示させる

    javascriptを使わず、cssだけでマウスホバー時に、バルーンポップアップを表示させる方法を紹介します。完成形は以下のようなイメージです。最初に完成形のcssを記載します。cssはjavascr...


  • canvasでグラデーションを表現する

    canvasのアニメーションで軌跡・残像・フェードアウトを表現するまではいろいろな図形を描画したり、描画した図形を動かしてアニメーションを表現する方法を紹介しました。今回は単色だけでなく、グラデーショ...