質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
canvas

HTML5の<canvas>要素用のタグです。CanvasはHTML5から導入された、二次元の図形描写が可能な要素です。

CreateJS

CreateJSは、HTML5でリッチコンテンツを制作できるJavaScriptライブラリ群です。JavaScriptの知識があれば、HTML5のCanvasをコントロールしコンテンツを作ることができます。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

0回答

1088閲覧

canvasのgetImageDataについて

webStudy

総合スコア36

canvas

HTML5の<canvas>要素用のタグです。CanvasはHTML5から導入された、二次元の図形描写が可能な要素です。

CreateJS

CreateJSは、HTML5でリッチコンテンツを制作できるJavaScriptライブラリ群です。JavaScriptの知識があれば、HTML5のCanvasをコントロールしコンテンツを作ることができます。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

0クリップ

投稿2019/06/23 12:17

編集2019/06/23 13:14

前提・実現したいこと

https://codepen.io/prime156/pen/pebwpO
canvasでこちらのコードの写経をしていたのですが、getImageDataで値を格納したものをdataプロパティで条件分岐させている
処理がわかりません
回答よろしくお願いします

該当のソースコード

javascript

1 stage.compositeOperation = "default"; 2 3 stage.addChild(rect); 4 stage.addChild(text); 5 stage.update(); 6 7 var pixels = ctx.getImageData(text.x, text.y, text.w, text.h); 8 9 stage.removeChild(rect); 10 stage.removeChild(text); 11 stage.update(); 12 stage.compositeOperation = "lighter"; 13 14 var i = 0; 15 var particle; 16 for (var w = 0 ; w < text.w; w += cull){ 17 for (var h = 0; h < text.h; h += cull) { 18 if(pixels.data[(w + text.w * h) * 4] !== 0 && i < particles.length){ 19 particle = particles[i]; 20 particle.x = text.x + w; 21 particle.y = text.y + h; 22 particle.vx = 0; 23 particle.vy = 0; 24 scale = 1 + 4 * Math.random(); 25 particle.scaleX = particle.scaleY = 1 + 2 * Math.random() * Math.random(); 26 i++; 27 } 28 } 29 }

補足情報

createjsを使っています。

###情報追記
カンバス上で書いたテキストをgetImageDataでデータを取得した後にremoveChildで削除してからテキストの幅と
高さがあった位置にfor文で2重で回すことによってテキストの文字部分があった場所にシェィプを追加していることまでは分かるのですが、それだけだと長方形に丸のシェイプが連なって文字にはならないのでおそらく、dataプロパティのif文で文字情報があった位置にだけ丸のシェイプを付与していると思うのですがそのif文で計算している箇所が分かりません

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

webStudy

2019/06/23 13:25

質問自体初めてで分からないことも多く申し訳ありません。 情報追記させていただきました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問