html5 canvasの基本的な使い方

html5でアニメーションや図形などを作成するcanvas要素の基本的な使い方を学習します。

canvasjavascritpで描画するので、複雑なアニメーションを動的に描画する場合はhtmlの知識だけでなく、プログラミングの知識も必要になってきます。

下準備

html

htmlの要素としてcanvasタグを定義します。

<canvas id="canvas" width="800px" height="600px" style="border:1px solid #000;background-color: #fffac;" ></canvas>

上記ように定義すると黒枠で囲われた横300×縦200のcanvasが表示されます。

この中にjavascriptでいろいろな図形を描画していきます。

注意

canvasのサイズをstyle(css)で設定しないよう注意が必要です。

内部的にはcanvasの座標で描画したものを、styleのサイズに拡大・縮小して表示するので、canvasのサイズとstyleのサイズが違っていると正しく表示されないことがあります。

今後は以下のcanvasを使用します。

canvasのサイズをwidth=800px,height=600pxで定義し、styleはブラウザの横幅に合わせるようにします。

javascript

javascriptでは下記のように定義します。古いブラウザなどcanvasが対応していない場合も考慮する必要があります。

$(function ($) {
  //jQueryを使用しています
  //画面ロードイベントでcanvasの描画処理を実行します
  var canvas = $('#canvas')[0];
  if (canvas.getContext){ //古いブラウザなどcanvasが未対応の場合は処理を行わない
    var context = canvas.getContext('2d');
    //以降に描画内容を記載する

  }
});

canvas.getContext('2d')で2D(二次元)で描画するということを定義します。引数は2dのみ有効です。

座標の考え方

実際にcanvasに図形を描画する際に、描画する位置を指定する必要があります。四角形や円などを描画するいろいろな関数が用意されていますが、ほとんどの関数で描画する位置として、x座標とy座標を引数として渡す必要があります。

(x座標, y座標)として、(0, 0)が左上になります。


関連記事

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

    htmlで余白の設定をするときは、marginとpaddingのスタイルを使用します。要素と要素の間の余白を設定する場合はmarginを使用します。paddingは要素の内側の余白を設定します。


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

    以下のように、同じスタイルを複数の箇所に記載しているときは、classを使えば同じスタイルを1箇所にまとめることができます。クラスはhtmlのhead部分に記載します。スタイルタグを記載し、その中に先...


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

    htmlの要素には大きく分けてブロック要素とインライン要素があります。インライン要素で指定すると、要素ごとの背景色は変更できているのですが、要素と要素の間については色が反映されません。ブロック要素でひ...


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

    罫線を引いて、より見た目をわかりやすくする方法を紹介します。ボーダーにはスタイル、色、太さなどの項目を設定する必要があります。


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

    段落と見出しを表示して、読みやすい文章のレイアウトを表現する方法を紹介します。作文などで文章を書くときは、文の区切りには段落を入れて読みやすくすることがあります。htmlでも段落を意味するタグがありま...


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

    日本語や英語に文法があるように、htmlにも文法があります。文法を正しく記述しなければ、ブラウザが理解できずに正しく表示できなくなります。ブラウザには「このファイルの内容はhtmlで記載されています」...


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

    プログラミングの経験もなく、初めてホームページを作成しようと考えている人に向けて、htmlの基本を数回に分けて説明します。htmlとはウェブブラウザにどのようにホームページを表示させるのか理解させるた...


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

    画像を使わずに、cssでスタイルを指定するだけで三角形を表示させる方法を紹介します。三角形を表示させるにはborder(枠線)を使用します。縦と横が重なる部分は、どちらかのスタイル(青か赤)を優先させ...


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

    javascriptを使わず、cssだけでマウスホバー時に、バルーンポップアップを表示させる方法を紹介します。cssはjavascriptと違い、イベントを定義できませんが、擬似クラスという機能が用意...


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

    線形グラデーションを使う場合はまずこの関数を使用して、グラデーションのオブジェクトを作成します。グラデーションを描画するという関数ではなく、グラデーションを定義する関数ですので、この関数を実行しただけ...