★Canvasリファレンス

当サイトのリンクからサインアップしても、利用者の方に追加料金はかかりませんが、私たちが紹介手数料を受け取る場合があります。

context . clip() …… パスで切り抜き(クリッピング)する
Internet Explorer9
Firefox2Firefox3Firefox4
Google Chrome1Google Chrome2Google Chrome3Google Chrome4Google Chrome5Google Chrome6
Safari3Safari4Safari5
Opera9Opera10
広告



clip()メソッドは、 パスで切り抜き(クリッピング)する際に使用します。
clip()メソッドで切り抜き指定した領域と、その後にパスで描かれた領域の重なる部分だけが切り抜き表示されます。

切り抜き領域が算出される際には、開いているサブパスも暗黙的に閉じられて切り抜きが適用されますが、
実際にサブパスが閉じられるわけではありません。

新規の切り抜き領域を指定した場合には、現在の切り抜き領域と置き換えられます。
また、コンテキストを初期化すると、左上端が(0,0)で幅と高さが座標空間の範囲となる四角形が切り抜き領域として設定されます。

■非ゼロ回転数ルール

clip()メソッドでは、切り抜きの際に「非ゼロ回転数ルール」という切り抜きルールが適用されます。
非ゼロ回転数ルールでは、サブパスが交差して図形同士が重なった部分も切り抜き領域となります。

以下の図は、非ゼロ回転数ルールと偶数奇数ルールの違いを示したものです。
clip()メソッドでは偶数奇数ルールを指定できるわけではありませんが、
比較をすることで非ゼロ回転数ルールを理解しやすくなるのではないかと思います。

四角形や円などの単純な図形の場合には特に意識する必要はありませんが、
サブパス同士が交差するような複雑な図形で切り抜く場合には、
切り抜きルール次第で結果が異なるので、簡単に理解しておくと良いでしょう。


なんとなく混乱しそうなので、あえて以下のメモを付け加えます。

※メモ:fill()のページでの非ゼロ回転数ルールの解説では、星形などの図形は塗りつぶし対象の図形として説明していますが、
このページでの非ゼロ回転数ルールの解説では、星形などの図形はクリップを適用する領域を表す図形として説明しています。
つまり一筆書きで描いた星形図形でクリッピングすると、星形の中央部の五角形の部分も一緒に切り抜き対象となるという意味です。

このページ内の説明には、clip()メソッドによる「切り抜き」と、
偶数奇数ルールにおける「サブパスが交差した場合の図形の抜け」があって紛らわしいですが、混同しないようにしてください。
もし紛らわしければ、この「■非ゼロ回転数ルール」の項目ごと無視してください。
必ずしも非ゼロ回転数ルールを理解する必要は無いと思います。

■clip()メソッドによる切り抜き

clip()メソッドによる切り抜きは、以下のような流れとなります。

  1. 切り抜き領域となる図形(以下の例では星形)をパスで作成する
  2. clip()メソッドを指定することで、作成した図形が切り抜き領域となる
  3. 切り抜かれる図形(以下の例では四角形)を描く
  4. 先に指定した切り抜き領域と重なった部分だけが描画される

■使用例

HTML + JavaScriptソース

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>canvasで図形を描く</title>
<script type="text/javascript">
<!--
function test() {
  //描画コンテキストの取得
  var canvas = document.getElementById('sample');
  if (canvas.getContext) {
    var context = canvas.getContext('2d');
    //ここに具体的な描画内容を指定する
    //一筆書きで星形のパスを描く
    context.beginPath();
    context.moveTo(90,60);
    context.lineTo(210,60);
    context.lineTo(110,130);
    context.lineTo(150,20);
    context.lineTo(190,130);
    context.closePath();

    //上で作成した星形のパスを切り抜き領域とする
    context.clip();

    //左から110上から35の位置に幅80高さ80の塗りつぶしの四角形を描く
    context.fillRect(110,35,80,80);
  }
}
//-->
</script>
</head>
<body onLoad="test()">
<h2>Canvasで図形を描く</h2>
<canvas width="300" height="150" id="sample" style="background-color:yellow;">
図形を表示するには、canvasタグをサポートしたブラウザが必要です。
</canvas>
</body>
</html>
↓↓↓

ブラウザ上の表示

Canvasで図形を描く


図形を表示するには、canvasタグをサポートしたブラウザが必要です。

■関連項目

<canvas> …… 図形を描くHTML5から追加
広告



山田 太郎
テック・リード
山田太郎は、ウェブ開発やグラフィックスプログラミングに10年以上の経験を持つテクノロジーの専門家です。特にHTML5 CanvasやJavaScript、インタラクティブメディアに精通しており、動的なユーザーインターフェースや最先端のウェブアプリケーションの開発に携わってきました。複雑な図形描画や画像操作、リアルタイムグラフィックスに関する知識が豊富で、ウェブ技術の限界を追求する開発者たちにとって頼りになる存在です。知識の共有に情熱を持ち、初心者からプロフェッショナルまで幅広く支援するため、技術フォーラムやブログにも積極的に貢献しています。

ギャンブルガイド もっと見る

カジノファインダー

どのカジノが自分に最適か分からないですか?

サインアップは必要なく、1 分以内に最適なブックメーカーを簡単に見つけることができます。
カジノを探す
Back
質問
Select one of the following options
{"is_any_tile":true}

どのカジノが自分に最適か分からないですか?

Back
Restart
やったー!
これはあなたの選択に基づいた最高のカジノです...
67 users signed up
もっと表示する