今日は旧正月ですが、旧正月には花火を上げることしか思いつきません。 。 。 。そこで、キャンバスを使用して花火のエフェクトを作成しました。マウスをクリックすると花火が生成されますが、花火から放出されるパーティクルは 30 ~ 200 個です。ページ上のパーティクルの数が一定に達すると、花火が生成されます。時々、ページが非常に固まってしまうことがありますが、私は意図的に Shenma を最適化しませんでした。それについては後で時間があるときに話しましょう。
原理は非常にシンプルです。 。 。 firework クラスと debris クラスを作成し、それをインスタンス化して飛ばすだけです。そして、一定のポイントに達したら、firework オブジェクトの Dead 属性を true に設定し、その後、一定数の debris オブジェクトをインスタンス化し、ランダムに作成します。デブリ オブジェクトが到達するターゲット ポイントを指定し、そこにすべてのデブリ オブジェクトを飛行させます。
XML/HTML コードコンテンツをクリップボードにコピー
- var ブーム = 関数(x,r,c,boomArea,shape){ / /烟火对象
-
this.booms = [];
-
this.x = x;
-
this.y = (canvas.height r);
-
this.r = r;
-
this.c = c;
-
this.shape = shape || 間違い;
-
this.boomArea = boomArea;
-
this.theta = 0;
-
this.dead = false;
-
this.ba = parseInt(getRandom(80 , 200));
- }
-
Boom.prototype = {
- _paint:function(){
- ctx.save();
- ctx.beginPath();
- ctx.arc(this.x,this.y,this.r,0,2*Math.PI);
-
ctx.fillStyle = this.c;
- ctx.fill();
- ctx.restore();
- },
- _move:function(){
-
var dx = this.boomArea.x - this.x , dy = this.boomArea.y - this.y;
-
thisthis.x = this.x dx*0.01;
-
thisthis.y = this.y dy*0.01;
-
-
if(Math.abs(dx)<=this.ba && Math.abs(dy)< =this.ba){
- if(this.shape){
- this._shapBoom();
- }
- else this._boom();
- this.dead = true;
- }
- else {
- this._paint();
- }
- }、
- _drawLight:function(){
- ctx.save();
- ctx.fillStyle = "rgba(255,228,150,0.3)";
- ctx.beginPath();
- ctx.arc(this.x , this.y , this.r 3*Math.random() 1 , 0 , 2*Math.PI);
- ctx.fill();
- ctx.restore();
- },
- _boom:function(){ //普通爆裂
- var fragNum = getRandom(30 , 200);
- var style = getRandom(0,10)> =5? 1:2;
- var color;
-
if(スタイル===1){
-
色 = {
- a:parseInt(getRandom(128,255)),
- b:parseInt(getRandom(128,255)),
- c:parseInt(getRandom(128,255))
- }
- }
-
-
var fanwei = parseInt(getRandom(300, 400));
-
for(var i=0;i<fragNum;i ){
-
if(スタイル===2){
-
色 = {
- a:parseInt(getRandom(128,255)),
- b:parseInt(getRandom(128,255)),
- c:parseInt(getRandom(128,255))
- }
- }
-
var a = getRandom(-Math.PI, Math.PI);
-
var x = getRandom(0, fanwei) * Math.cos(a) this.x;
-
var y = getRandom(0, fanwei) * Math.sin(a) this.y;
-
var 半径 = getRandom(0 , 2)
-
var frag = new Frag(this.x , this.y , radius , color , x , y );
- this.booms.push(frag);
- }
- }、
- _shapBoom:function(){ //形状のある爆裂
-
var あれ = これ;
- putValue(ocas , octx , this.shape , 5, function(dots){
-
var dx = canvas.width/2-that.x;
-
var dy = canvas.height/2-that.y;
-
for(var i=0;i<dots.length;i ){
-
色 = {a:dots[i].a,b:dots[i].b,c:dots[i].c}
-
var x = ドット[i].x;
-
var y = ドット[i].y;
-
var 半径 = 1;
-
var frag = new Frag(that.x , that.y , radius , color , x- dx、y-dy);
- that.booms.push(frag);
- }
- })
- }
- }
フォント、画像など、花火を希望の形にします。これは、オフスクリーン キャンバスとキャンバスの getImageData メソッドを使用して行うこともできます。オフスクリーン キャンバスは、名前が示すように、目に見えないキャンバスです。dom オブジェクトがボディに割り当てられていない限り、js で直接 document.createElement("canvas") を使用できます。キャンバス オブジェクトはオフスクリーン オブジェクトと同等であり、このオフスクリーン キャンバスのコンテキスト オブジェクトを取得して、ユーザーが見えない場所でやりたいことを何でも実行できます。
花火を希望の形にするには、まずオフスクリーン キャンバスにテキストまたは画像を描画し、次に getImageData を使用してキャンバス上のピクセル配列を取得し、次に配列を走査して色付きピクセルを取得します。これが目的です。コンテンツが保存されると、メインのキャンバス オブジェクトに表示されます。
前回のブログで getImageData のピクセル処理について説明しましたが、使い方がわからない場合は、ここをクリックしてください: Canvas を使用してテキストと画像の粒子化を実現する方法について話しましょう