canvas结合三角函数实现一个视频直播效果

canvas可以说是html5其中的一大亮点,有了它,我们可以基于canvas画布实现很多之前只有flash和视频才能实现的效果。废话少说,先上效果。

canvas结合三角函数实现一个视频直播效果

* {

margin: 0;

padding: 0;

}

html,

body {

font-size: 0;

height: 100%;

}

canvas {

background: #000;

}

(function (document) {

class Point {

constructor(option) {

this.x = option.context.canvas.width / 1.5;//对象的X坐标

this.y = Math.random() * option.context.canvas.height/2 + option.context.canvas.height / 2 ;//对象的Y坐标

this.defaultX = this.x;

this.defaultY = this.y;

this.img = option.img;

this.angle = Math.random()*360 | 0;

this.context = option.context;

this.width = this.context.canvas.width;

this.height = this.context.canvas.height;

this.speedX = 0;//元素在x轴上的速度,下面要通过三角函数来实现。

this.speedY = -4* Math.random() - 8;

this.alpha = 1;

this.render();

}

render() {

var {

context,

img,

x,

y

} = this;

context.save();

context.globalAlpha = this.alpha ;

context.drawImage(img, x, y,img.width/2,img.height/2);

context.restore();

}

animate() {

this.angle +=3;

this.angle %= 360;

this.speedX = 4* Math.sin(this.angle/180*Math.PI*2);

this.x += this.speedX;

this.y += this.speedY;

var {width,height} = this;

this.alpha = this.y / height / 2 + .2;

if (Math.abs(this.y <= height / 2)) {

this.y = height;

this.angle = Math.random() * 360 | 0;

this.alpha = 1;

this.x = this.defaultX;

}

this.render();

}

}

var zmitiUtil = {

viewW: window.innerWidth,

viewH: window.innerHeight,

init() {

this.setSize();

this.createParticals();

this.animate();

},

setSize() {

this.canvas = document.querySelector('#canvas');

this.context = this.canvas.getContext('2d');

this.canvas.width = this.viewW;

this.canvas.height = this.viewH;

},

createParticals(){

this.particals = [];

var img = new Image();

var self = this;

img.onload = function(){

var _this = this;//这里面this指向的是img对象

for (var i = 0; i < 30; i++) {

self.particals.push(new Point({

img: _this,

context: self.context

}))

}

}

img.src = './images/heart.png';

},

animate(){

var _this = this;

(function render(){//这里面this 发生了变化,请注意哦,因为出现了function 哦

requestAnimationFrame(render);

_this.context.clearRect(0,0,_this.viewW,_this.viewH);

_this.particals.forEach(partical => {

partical.animate();

})

})();

}

};

zmitiUtil.init();

})(document);

技术总结:

先来简单回顾下高中的正弦曲线

我们会发现,图中的曲线和我们的效果是反着来的,所以我们要把x,y对应的调换下位置即可,运动起来就会在X轴的速度上体现出来了。具体可参考下源代码。

简单的解释下 this.speedX = 4* Math.sin(this.angle/180*Math.PI); this.angle为当前的角度,取值范围为:[0,360],js提供的三角函数是要接收一下弧度的,所以我们需要转一下。

解释 this.angle = Math.random() * 360 | 0; // 有的可能不太知道后面的 ”| 0“是什么意思,本屌之前也不知道是什么意思,自己试,多试几次,于是就知道了,这个是去掉了小数的部分,相当于 Math.floor() , 但要问这是什么原理,好像是二进制的算法,其实我也不知道,但我知道这个用法就行了。

注意下这个代码里在的有几个地方涉及到了this的指向问题哦。我在代码中已有注释。

像这种粒子动画的实现原理,先实现一个粒子的动画,然后循环生成一堆,把所有的push到一个数组中去。然后用动画函数遍历数组,执行数组中的每一个对象的运动函数。

html5 canvas 画布一是无状态的机制。像类似 context 的 globalAlpha,translate,rotate等一些属性在操作之前需要加上context.save();在后面再context.restore();代码中也有体现。如果我们不加上context.save()那么,会给所有的粒子都设置了相同的透明试,这可不是我想要的。

ES6的类的创建,解构赋值。

写在最后:

我们可以看到很漂亮的数学曲线,应用到web页面上,充分体现出了数学之美。希望大家在学习上遇到一些自己不懂的写法,一定要自己先去尝试,一定要自己尝试,还要要想尽办法应该到你们的项目中,这样我们印象才深刻。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352

推荐阅读更多精彩内容