美文网首页
粒子效果

粒子效果

作者: R_daa1 | 来源:发表于2017-08-27 19:26 被阅读0次

//获取元素

var canvas = document.getElementById('canvas');

var ctx = canvas.getContext('2d');

var cw = document.documentElement.clientWidth;

var ch = document.documentElement.clientHeight;

canvas.width = cw;

canvas.height = ch;

//初始的HTML5文本

ctx.save();

ctx.font = "300px 黑体";

ctx.fillStyle = "white";

ctx.textAlign = "center";

ctx.textBaseline = "middle";

ctx.fillText("小伍哥",cw/2,ch/2);

ctx.restore();

//随机函数

function rnd(min,max) {return parseInt(Math.random()*(max-min))+min;}

//装载粒子的数组

var partciles = [];

//创建粒子

function Dot(x,y) {

//抽样像素的坐标

this.x = x;

this.y = y;

//开始的随机位置

this.startX = rnd(0,cw);

this.startY = rnd(0,ch);

//颜色

this.color = "rgb("+rnd(0,255)+","+rnd(0,255)+","+rnd(0,255)+")";

// this.color = "green";

//半径

this.radius = 4;

//分多少步走完

this.duration = 50;

//标记动画运行的次数

this.count = 0;

//每次的增量

this.deltaX = (this.x - this.startX)/this.duration;

this.deltaY = (this.y - this.startY)/this.duration;

}

//绘制粒子

Dot.prototype.draw = function() {

ctx.save();

ctx.beginPath();

ctx.fillStyle = this.color;

ctx.arc(this.startX,this.startY,this.radius,0,Math.PI*2,false);

ctx.closePath();

ctx.fill();

ctx.restore();

}

//更新粒子

Dot.prototype.update = function() {

//更新坐标

this.count++;

if(this.count<=this.duration) {

this.startX += this.deltaX;

this.startY += this.deltaY;

}else {

cancelAnimationFrame(raf);

}

}

///////////////////////////////////////////////////////////////////////////

//获取canvas画布上的所有像素点

var pixels = ctx.getImageData(0,0,cw,ch);

for(var x=0;x

for (var y=0;y

//求当前点在pixels.data下的红色通道的下标

var pos = (y*pixels.width+x)*4;

if(pixels.data[pos+3]>128) {

var dot = new Dot(x,y);

partciles.push(dot);

}

}

}

///////////////////////////////////////////////////////////////////////////

//擦除画布

canvas.width = canvas.width;

//遍历装载粒子的数组

for(var i in partciles) {

var dot = partciles[i];

ctx.beginPath();

ctx.fillStyle = dot.color;

ctx.arc(dot.startX,dot.startY,dot.radius,0,Math.PI*2,false);

ctx.closePath();

ctx.fill();

}

function change() {

canvas.width = canvas.width;

raf = requestAnimationFrame(change);

for(var i in partciles) {

var dot = partciles[i];

dot.draw();

dot.update();

}

}

var raf = requestAnimationFrame(change);

效果

相关文章

  • 粒子效果

    特效组件(靠材质体现): component-effect 拖尾效果: 镜头光晕(Lens Flars):涉及到后...

  • 粒子效果

    //获取元素 var canvas = document.getElementById('canvas'); va...

  • 粒子效果

    粒子效果(复制层) 开始 重绘 自定义一个DrawView绑定控制器的viewawakeFromNib中添加手势p...

  • 粒子效果

    粒子效果 说到粒子效果,iPhone用户应该经常见到的,比如下雨天时天气app中的雨滴效果。还有和小伙聊微信时不小...

  • iOS --粒子效果简单实现

    前言 :整个粒子动画效果,学习学习... 看看演示效果 Pragma mark — NO.1 创建最简单的粒子效果...

  • 音视频开发之旅(15) OpenGL ES粒子系统 - 喷泉

    目录 粒子和粒子系统 实践:喷泉效果 遇到的问题 资料 收获 通过该篇的实践实现如下效果 一、什么是粒子和粒子系统...

  • vue粒子效果

    粒子效果是一个很好玩很有趣的东西,前几天有人问我vue怎么使用粒子效果,其实vue使用一些简单粒子效果很容易,下面...

  • vue粒子效果

    粒子效果是一个很好玩很有趣的东西,前几天有人问我vue怎么使用粒子效果,其实vue使用一些简单粒子效果很容易,下面...

  • PS一键制作3D人像粒子打散飞溅效果动作(含视频教学)

    给大家分享一款非常酷炫的ps飞溅粒子效果动作插件,使用飞溅粒子效果动作插件,可以制作出非常酷炫的飞溅粒子效果动作,...

  • canvas 会动的粒子效果

    particle-field canvas实现粒子场的动画效果 实现效果:粒子会动并且在一定范围内粒子之间出现连线...

网友评论

      本文标题:粒子效果

      本文链接:https://www.haomeiwen.com/subject/fgwfdxtx.html