位图的canvas一直不会被svg比下去的原因了。 俗话说,须弥芥子,是大小之说,也有以小见大之说,颗颗粒子,足以构建宏大效果。 这是一篇炒鸡简单的canvas粒子教程,主要是讲如何粒子特效的原理,一点运动中的公式。

有所准备

首先,当我们知道要做粒子的效果的时候,我们要思考我们如何来实现,而且还要尽可能的面对我们亲爱的对象,于是便有了如下的思考。

  1. 要有粒子
  2. 粒子在运动,运动就需要速度
  3. 匀速运动/变速运动
  4. 运动之外还需要哪些处理

全局中的永恒

这里我定义了时间与粒子生成的数量,还有一个粒子池。

也许会很奇怪,我们在运动的过程中每一帧都是时间,为什么还要再设置这个时间,浏览器的渲染可以被看作正常流逝的时间,这里的time则是相对时间 如果感觉晕晕的,

这里可以举个小李子:

光在世界中沿直线传播,你现在所能看到的月光是很久之前的月光,这就说明很久之前的月光一直在传播,同时也意味着你的一切动作都还在传播的过程中,只要你的速度足够快,就可以追上你的过去。

开个小玩笑了,其实time的意思就是你的1s对于小球而言是2s,浏览器渲染设置的时间只是为了让你的视觉上看不出图像的卡顿

const time=2;
const num=20;
var dots=[];

粒子类

function dot(x,y,vx,vy){
//接收粒子点的坐标与方向速度量
this.x=x;
this.y=y;
this.vx=vx;
this.vy=vy;
//随机粒子大小
this.size=Math.ceil(Math.random()*3+2);
this.ctx={};
}
//粒子渲染
dot.prototype.render = function(ctx) {
ctx.save();
this.ctx=ctx;
this.ctx.beginPath();
this.ctx.fillStyle='lightgray';
this.ctx.arc(this.x-this.size/2,this.y-this.size/2,this.size,0,Math.PI*2);
this.ctx.closePath();
this.ctx.fill();
ctx.restore();
};
//对当前粒子属性做逻辑计算
dot.prototype.update = function() {
this.ctx.clearRect(0,0,canvas.width,canvas.heihgt);
this.x=this.x+this.vx*time;
this.y=this.y+this.vy*time;
this.vx = (this.x < canvas.width && this.x > 0) ? this.vx : (-this.vx);
this.vy = (this.y < canvas.height && this.y > 0) ? this.vy : (-this.vy);
this.render(this.ctx);
};

在当前粒子类中,我只给了速度的方向量,因为我们只要求粒子做匀速运动,这里的计算公式则是x=vt(x:位移 v:平均速度 t:运动时间)

如果要对粒子施加力或者变速运动,则需要this.a=a来添加一个加速度的属性。然后根据加速度的方向做水平与垂直的分解,并且对速度的方向量产生作用,从而进行变速运动,这里的公式如下

  1. v=at
  2. x=(v0+at/2)*t
    v0为初速度,a为加速度的方向量,x为方向上的位移

祸乱世界的粒子

for(let i=0;i<num;i++){
var x=Math.ceil(Math.random()*canvas.width);
var y=Math.ceil(Math.random()*canvas.height);
var vx=Math.ceil(Math.random()*2);
var vy=Math.ceil(Math.random()*2);
var d=new dot(x,y,vx,vy);
d.render(ctx);
dots.push(d);
}

通过对canvas的宽高进行随机取整来获取随机的坐标点。并且实例化我们的粒子。并且推入粒子池中。 这里因为我们在update方法中会直接调用render,所以我们只需要在实例化的时候执行一次renderctx环境传入,后面就可以全部交给update来完成了。

躁动吧 粒子球

requestAnimFrame(anim);
function anim(){
for(let i=0;i<dots.length;i++){
dots[i].update();
}
requestAnimFrame(anim);
}

这里我们只需要对粒子池中的粒子进行数据持续更新,就可以让粒子们跑起来了。

粒子的教程比较简单,但确是几乎所有粒子效果的依托,粒子已经可以生成,那么只需要让粒子在我们的规定路径上运动,就可以达到我们所需要的效果了。

拓展思维

  1. 知乎背景的网状效果

    遍历所有粒子点,如果在范围内,则使用moveTo与llineTo来生成连接线。

  2. 粒子成字

    将文字先绘制在离屏canvas上,然后返回所有不透明像素点的坐标,遍历时可以直接遍历,也可以使用widthheight来计算,如果当前点需要绘制,就生成粒子。

    这里说到像素点不透明,是因为在canvas上,你只要不设置,默认是不存在背景色,也就说,所有绘制的所有像素都可以通过判断其alpha值是否为0来判断,也可以通过设置alpha的阈值来将一些填充度不够的点给扔除。比如说当alpha对应为128的时候,透明度约为0.5,这也是为什么很多人的博客里都用到了128这个判断值。

    还有很多的效果,粒子特效是一个很大的话题,如AE Unity等软件中都会有内置的粒子插件与外置的大量粒子效果插件。

后面还会写一些有些高度的粒子效果

不定期更新canvas与svg的相关技术教程,有实战型,也会有主原理型的,2d 2.5d 3d都会包含到,同时涉及的有 线性代数 物理 图形学等相关的基础知识。

本次demo源码:粒子效果

炒鸡简单的canvas粒子(山东数漫江湖)的更多相关文章

  1. Redux系列02:一个炒鸡简单的react+redux例子

    前言 在<Redux系列01:从一个简单例子了解action.store.reducer>里面,我们已经对redux的核心概念做了必要的讲解.接下来,同样是通过一个简单的例子,来讲解如何将 ...

  2. 啊啊啊啊啊啊啊今天就写,炒鸡简单 数据库Sqlite的创建,库的增删改查

    啦啦啦啦啦啦啦 写这个不用多长时间,我直接写代码注释都是些语句,Sql语句和Api来操作数据库 ,语句的参数我会注释 SQLite数据库创建数据库需要使用的api:SQLiteOpenHelper必须 ...

  3. Python制作动态二维码只需要一行代码!炒鸡简单!

    分享一个比较有意思的项目,只需要一行Python代码就可以快捷方便生成普通二维码.艺术二维码(黑白/彩色)和动态GIF二维码. 用法比较简单,直接通过pip安装即可. pip3 install myq ...

  4. 炒鸡简单的javaScript的call和apply方法

    解释一 作者:杨志 链接:https://www.zhihu.com/question/20289071/answer/14644278 来源:知乎 著作权归作者所有.商业转载请联系作者获得授权,非商 ...

  5. ES6中Fetch的封装及使用,炒鸡简单~

    之前写过一篇<ajax.axios.fetch之间的详细区别以及优缺点> 戳这里 1.封装 (http.js) class Ajax { get(url) { return new Pro ...

  6. 教你 Shiro 整合 SpringBoot,避开各种坑(山东数漫江湖)

    依赖包 <dependency> <groupId>org.apache.shiro</groupId> <artifactId>shiro-sprin ...

  7. 老生常谈-Activity(山东数漫江湖)

    对于activity的七个声生命周期回调,总是被大家翻来覆去的说,甚至说的都有些厌烦了,这部分知识虽然基础但也很重要,谁都不想在面试的时候只说出个一知半解,下面的分析是对阅读<安卓开发艺术探索& ...

  8. Web Session 浅入浅出(山东数漫江湖)

    使用过几种Web App开发语言和框架,都会接触到Session的概念.即使是一个简单站点访问计数的功能,也常常使用Session来实现的.其他常用的领域还有购物车,登录用户等.但是,对Session ...

  9. Hadoop大数据生态系统及常用组件(山东数漫江湖)

    经过多年信息化建设,我们已经进入一个神奇的“大数据”时代,无论是在通讯社交过程中使用的微信.QQ.电话.短信,还是吃喝玩乐时的用到的团购.电商.移动支付,都不断产生海量信息数据,数据和我们的工作生活密 ...

随机推荐

  1. eg_1

    1. 编写一个程序,输出一个字符串中的大写英文字母个数,小写英文字母个数以及非英文字母个数. 第一种方法: public class Test { public static void main(St ...

  2. css深入理解之 border

    一 border-width不支持百分比值 1 不符合客观逻辑 2 w3成都一种约定吧 3 边框本身就像是一个包裹内容的界限 类似的还有outline,box-shadow text-shadow均不 ...

  3. win7系统日志分支删除方法

    这篇日志有问题,自己亲身尝试失败,这里只提供思路,谢谢(改天突破再做修改) 之前电脑装过德国的叫啥子软件来着,当时在系统自动创建了日志,后来软件卸载了,发现还是有这个日志主键,(我有强迫症)心里不爽, ...

  4. php裁剪图片(支持定点裁剪)

    /** * 图片裁剪函数,支持指定定点裁剪和方位裁剪两种裁剪模式 * @param <string> $src_file 原图片路径 * @param <int> $new_w ...

  5. sql sever 数据表

    对视图进行操作,要在第三块区域进行添加记录操作,回车,然后会同步到所有相关数据表中. 记录不是列,而是行,不要混淆. 第二块区域是各个属性,就是说明: 第一块区域是要进行显示的字段,选中什么 显示什么 ...

  6. [STL] vector基本用法

    vector的数据安排以及操作方式,与array非常相似.两者的唯一区别在于空间的运用的灵活性.array是静态空间,一旦配置了就不能改变.vector是动态空间,随着元素的加入,它的内部机制会自行扩 ...

  7. Luogu1155 NOIP2008双栈排序(并查集)

    两个位置i和j上的元素不能被放进同一个栈的充要条件显然是存在k使i<j<k且ak<ai<aj.由此在保证合法的情况下贪心地放就是正确的了. 至于如何判断,可以记一下后缀最小值, ...

  8. BZOJ5336:[TJOI2018]游园会——题解

    https://www.lydsy.com/JudgeOnline/problem.php?id=5336 https://www.luogu.org/problemnew/show/P4590 小豆 ...

  9. 使用javaScript和JQuery制作经典面试题:光棒效果

    使用javaScript与jQuery添加CSS样式的区别和步骤 使用javaScript制作光棒效果 --首先是javaScript <script> $(function () { v ...

  10. 【二分】【P1314】 【NOIP2011D2T2】聪明的质监员

    传送门 Description 小T 是一名质量监督员,最近负责检验一批矿产的质量.这批矿产共有 \(n\) 个矿石,从 \(1\) 到 \(n\) 逐一编号,每个矿石都有自己的重量 \(w_i\) ...