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

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

今回は単色だけでなく、グラデーションや透過色を使う方法を紹介します。

線形グラデーション

canvasのグラデーションには線形グラデーションと円形グラデーションの2種類があります。まずは線形グラデーションの使い方を紹介します。

関数

createLinearGradient(始点x座標, 始点y座標, 終点x座標, 終点y座標)

線形グラデーションを使う場合はまずこの関数を使用して、グラデーションのオブジェクトを作成します。

グラデーションを描画するという関数ではなく、グラデーションを定義する関数ですので、この関数を実行しただけではグラデーションは描画されません。

定義したグラデーションオブジェクトをfillStyleなどで指定して、実際に描画する関数fillなどを実行すると、グラデーションが描画されます。

addColorStop(オフセット, 色)

グラデーションの色の配分を定義します。オフセットには定義する位置を指定します。0が始点、1が終点となります。なので、例えばaddColorStop(0, 白)addColorStop(1, 黒)を指定した場合は白から黒に変化するグラデーションが定義されます。

サンプル

左半分は縦のグラデーション、右半分は横のグラデーションを描画しています。

var context = canvas.getContext('2d');
var grad

//縦方向のグラデーションを定義
grad  = context.createLinearGradient(0, 0, 0, 600);

//色の流れを定義
//赤から半分の地点で緑を経由して青に変化するグラデーション
grad.addColorStop(0,'rgb(255, 0, 0)');
grad.addColorStop(0.5,'rgb(0, 255, 0)');
grad.addColorStop(1,'rgb(0, 0, 255)');

//定義したグラデーションをスタイルにして描画
context.fillStyle = grad;
context.fillRect(0, 0, 400, 600);

//横方向のグラデーションを定義
grad  = context.createLinearGradient(400, 0, 800, 0);

//色の流れを定義
//赤から半分の地点で緑を経由して青に変化するグラデーション
grad.addColorStop(0,'rgb(255, 0, 0)');
grad.addColorStop(0.5,'rgb(0, 255, 0)');
grad.addColorStop(1,'rgb(0, 0, 255)');

//定義したグラデーションをスタイルにして描画
context.fillStyle = grad;
context.fillRect(400, 0, 800, 600);

円形グラデーション

基本的な考え方は線形グラデーションと同様です。最初に定義するグラデーションのオブジェクトを変更するだけで円形グラデーションを描画できます。

関数

createRadialGradient(始点x座標, 始点y座標, 始点半径, 終点x座標, 終点y座標, 終点半径)

createLinearGradientと違うところは、引数に半径も指定する必要があります。始点で定義した円から終点で定義した円に向かってグラデーションが定義されます。

サンプル

var context = canvas.getContext('2d');
var grad
//円のグラデーションを定義
grad  = context.createRadialGradient(300, 300, 0, 300, 300, 200);

//色の流れを定義
//赤から半分の地点で緑を経由して青に変化するグラデーション
grad.addColorStop(0,'rgb(255, 0, 0)');
grad.addColorStop(0.5,'rgb(0, 255, 0)');
grad.addColorStop(1,'rgb(0, 0, 255)');

context.beginPath();
context.arc(300, 300, 200, (0/180)*Math.PI, (360/180)*Math.PI);
//定義したグラデーションをスタイルにして描画
context.fillStyle = grad;
context.fill();

関連記事

  • 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のアニメーションの基本的な考え方でcanvasで簡単なアニメーションを表現する方法を紹介しました。今回はアニメーションを応用し軌跡や残像を残したり。フェードアウトする方法を紹介します。...