新年快乐! javascript实现超级炫酷的3D烟花特效


Posted in Javascript onJanuary 30, 2019

本文实例为大家分享了javascript实现3D烟花特效的具体代码,供大家参考,具体内容如下

<!DOCTYPE html>
<html>
 <head>
 <meta charset="utf-8" />
 <title></title>
 
<meta charset="utf-8">
<title>3D烟花</title>

<style>
html,body{
 margin:0px;
 width:100%;
 height:100%;
 overflow:hidden;
 background:#000;
}

#canvas{
 width:100%;
 height:100%;
}
</style>
</head>
 
 <body>
<canvas id="canvas" width="825" height="631"></canvas><script>
function initVars(){

 pi=Math.PI;
 ctx=canvas.getContext("2d");
 canvas.width=canvas.clientWidth;
 canvas.height=canvas.clientHeight;
 cx=canvas.width/2;
 cy=canvas.height/2;
 playerZ=-25;
 playerX=playerY=playerVX=playerVY=playerVZ=pitch=yaw=pitchV=yawV=0;
 scale=600;
 seedTimer=0;seedInterval=5,seedLife=100;gravity=.02;
 seeds=new Array();
 sparkPics=new Array();
 s="https://cantelope.org/NYE/";
 for(i=1;i<=10;++i){
 sparkPic=new Image();
 sparkPic.src=s+"spark"+i+".png";
 sparkPics.push(sparkPic);
 }
 sparks=new Array();
 pow1=new Audio(s+"pow1.ogg");
 pow2=new Audio(s+"pow2.ogg");
 pow3=new Audio(s+"pow3.ogg");
 pow4=new Audio(s+"pow4.ogg");
 frames = 0;
}

function rasterizePoint(x,y,z){

 var p,d;
 x-=playerX;
 y-=playerY;
 z-=playerZ;
 p=Math.atan2(x,z);
 d=Math.sqrt(x*x+z*z);
 x=Math.sin(p-yaw)*d;
 z=Math.cos(p-yaw)*d;
 p=Math.atan2(y,z);
 d=Math.sqrt(y*y+z*z);
 y=Math.sin(p-pitch)*d;
 z=Math.cos(p-pitch)*d;
 var rx1=-1000,ry1=1,rx2=1000,ry2=1,rx3=0,ry3=0,rx4=x,ry4=z,uc=(ry4-ry3)*(rx2-rx1)-(rx4-rx3)*(ry2-ry1);
 if(!uc) return {x:0,y:0,d:-1};
 var ua=((rx4-rx3)*(ry1-ry3)-(ry4-ry3)*(rx1-rx3))/uc;
 var ub=((rx2-rx1)*(ry1-ry3)-(ry2-ry1)*(rx1-rx3))/uc;
 if(!z)z=.000000001;
 if(ua>0&&ua<1&&ub>0&&ub<1){
 return {
 x:cx+(rx1+ua*(rx2-rx1))*scale,
 y:cy+y/z*scale,
 d:Math.sqrt(x*x+y*y+z*z)
 };
 }else{
 return {
 x:cx+(rx1+ua*(rx2-rx1))*scale,
 y:cy+y/z*scale,
 d:-1
 };
 }
}

function spawnSeed(){
 
 seed=new Object();
 seed.x=-50+Math.random()*100;
 seed.y=25;
 seed.z=-50+Math.random()*100;
 seed.vx=.1-Math.random()*.2;
 seed.vy=-1.5;//*(1+Math.random()/2);
 seed.vz=.1-Math.random()*.2;
 seed.born=frames;
 seeds.push(seed);
}

function splode(x,y,z){
 
 t=5+parseInt(Math.random()*150);
 sparkV=1+Math.random()*2.5;
 type=parseInt(Math.random()*3);
 switch(type){
 case 0:
 pic1=parseInt(Math.random()*10);
 break;
 case 1:
 pic1=parseInt(Math.random()*10);
 do{ pic2=parseInt(Math.random()*10); }while(pic2==pic1);
 break;
 case 2:
 pic1=parseInt(Math.random()*10);
 do{ pic2=parseInt(Math.random()*10); }while(pic2==pic1);
 do{ pic3=parseInt(Math.random()*10); }while(pic3==pic1 || pic3==pic2);
 break;
 }
 for(m=1;m<t;++m){
 spark=new Object();
 spark.x=x; spark.y=y; spark.z=z;
 p1=pi*2*Math.random();
 p2=pi*Math.random();
 v=sparkV*(1+Math.random()/6)
 spark.vx=Math.sin(p1)*Math.sin(p2)*v;
 spark.vz=Math.cos(p1)*Math.sin(p2)*v;
 spark.vy=Math.cos(p2)*v;
 switch(type){
 case 0: spark.img=sparkPics[pic1]; break;
 case 1:
 spark.img=sparkPics[parseInt(Math.random()*2)?pic1:pic2];
 break;
 case 2:
 switch(parseInt(Math.random()*3)){
 case 0: spark.img=sparkPics[pic1]; break;
 case 1: spark.img=sparkPics[pic2]; break;
 case 2: spark.img=sparkPics[pic3]; break;
 }
 break;
 }
 spark.radius=25+Math.random()*50;
 spark.alpha=1;
 spark.trail=new Array();
 sparks.push(spark);
 }
 switch(parseInt(Math.random()*4)){
 case 0: pow=new Audio(s+"pow1.ogg"); break;
 case 1: pow=new Audio(s+"pow2.ogg"); break;
 case 2: pow=new Audio(s+"pow3.ogg"); break;
 case 3: pow=new Audio(s+"pow4.ogg"); break;
 }
 d=Math.sqrt((x-playerX)*(x-playerX)+(y-playerY)*(y-playerY)+(z-playerZ)*(z-playerZ));
 pow.volume=1.5/(1+d/10);
 pow.play();
}

function doLogic(){
 
 if(seedTimer<frames){
 seedTimer=frames+seedInterval*Math.random()*10;
 spawnSeed();
 }
 for(i=0;i<seeds.length;++i){
 seeds[i].vy+=gravity;
 seeds[i].x+=seeds[i].vx;
 seeds[i].y+=seeds[i].vy;
 seeds[i].z+=seeds[i].vz;
 if(frames-seeds[i].born>seedLife){
 splode(seeds[i].x,seeds[i].y,seeds[i].z);
 seeds.splice(i,1);
 }
 }
 for(i=0;i<sparks.length;++i){
 if(sparks[i].alpha>0 && sparks[i].radius>5){
 sparks[i].alpha-=.01;
 sparks[i].radius/=1.02;
 sparks[i].vy+=gravity;
 point=new Object();
 point.x=sparks[i].x;
 point.y=sparks[i].y;
 point.z=sparks[i].z;
 if(sparks[i].trail.length){
 x=sparks[i].trail[sparks[i].trail.length-1].x;
 y=sparks[i].trail[sparks[i].trail.length-1].y;
 z=sparks[i].trail[sparks[i].trail.length-1].z;
 d=((point.x-x)*(point.x-x)+(point.y-y)*(point.y-y)+(point.z-z)*(point.z-z));
 if(d>9){
 sparks[i].trail.push(point);
 }
 }else{
 sparks[i].trail.push(point);
 }
 if(sparks[i].trail.length>5)sparks[i].trail.splice(0,1); 
 sparks[i].x+=sparks[i].vx;
 sparks[i].y+=sparks[i].vy;
 sparks[i].z+=sparks[i].vz;
 sparks[i].vx/=1.075;
 sparks[i].vy/=1.075;
 sparks[i].vz/=1.075;
 }else{
 sparks.splice(i,1);
 }
 }
 p=Math.atan2(playerX,playerZ);
 d=Math.sqrt(playerX*playerX+playerZ*playerZ);
 d+=Math.sin(frames/80)/1.25;
 t=Math.sin(frames/200)/40;
 playerX=Math.sin(p+t)*d;
 playerZ=Math.cos(p+t)*d;
 yaw=pi+p+t;
}

function rgb(col){
 
 var r = parseInt((.5+Math.sin(col)*.5)*16);
 var g = parseInt((.5+Math.cos(col)*.5)*16);
 var b = parseInt((.5-Math.sin(col)*.5)*16);
 return "#"+r.toString(16)+g.toString(16)+b.toString(16);
}

function draw(){
 
 ctx.clearRect(0,0,cx*2,cy*2);
 
 ctx.fillStyle="#ff8";
 for(i=-100;i<100;i+=3){
 for(j=-100;j<100;j+=4){
 x=i;z=j;y=25;
 point=rasterizePoint(x,y,z);
 if(point.d!=-1){
 size=250/(1+point.d);
 d = Math.sqrt(x * x + z * z);
 a = 0.75 - Math.pow(d / 100, 6) * 0.75;
 if(a>0){
 ctx.globalAlpha = a;
 ctx.fillRect(point.x-size/2,point.y-size/2,size,size); 
 }
 }
 }
 }
 ctx.globalAlpha=1;
 for(i=0;i<seeds.length;++i){
 point=rasterizePoint(seeds[i].x,seeds[i].y,seeds[i].z);
 if(point.d!=-1){
 size=200/(1+point.d);
 ctx.fillRect(point.x-size/2,point.y-size/2,size,size);
 }
 }
 point1=new Object();
 for(i=0;i<sparks.length;++i){
 point=rasterizePoint(sparks[i].x,sparks[i].y,sparks[i].z);
 if(point.d!=-1){
 size=sparks[i].radius*200/(1+point.d);
 if(sparks[i].alpha<0)sparks[i].alpha=0;
 if(sparks[i].trail.length){
 point1.x=point.x;
 point1.y=point.y;
 switch(sparks[i].img){
 case sparkPics[0]:ctx.strokeStyle="#f84";break;
 case sparkPics[1]:ctx.strokeStyle="#84f";break;
 case sparkPics[2]:ctx.strokeStyle="#8ff";break;
 case sparkPics[3]:ctx.strokeStyle="#fff";break;
 case sparkPics[4]:ctx.strokeStyle="#4f8";break;
 case sparkPics[5]:ctx.strokeStyle="#f44";break;
 case sparkPics[6]:ctx.strokeStyle="#f84";break;
 case sparkPics[7]:ctx.strokeStyle="#84f";break;
 case sparkPics[8]:ctx.strokeStyle="#fff";break;
 case sparkPics[9]:ctx.strokeStyle="#44f";break;
 }
 for(j=sparks[i].trail.length-1;j>=0;--j){
 point2=rasterizePoint(sparks[i].trail[j].x,sparks[i].trail[j].y,sparks[i].trail[j].z);
 if(point2.d!=-1){
 ctx.globalAlpha=j/sparks[i].trail.length*sparks[i].alpha/2;
 ctx.beginPath();
 ctx.moveTo(point1.x,point1.y);
 ctx.lineWidth=1+sparks[i].radius*10/(sparks[i].trail.length-j)/(1+point2.d);
 ctx.lineTo(point2.x,point2.y);
 ctx.stroke();
 point1.x=point2.x;
 point1.y=point2.y;
 }
 }
 }
 ctx.globalAlpha=sparks[i].alpha;
 ctx.drawImage(sparks[i].img,point.x-size/2,point.y-size/2,size,size);
 }
 }
}

function frame(){

 if(frames>100000){
 seedTimer=0;
 frames=0;
 }
 frames++;
 draw();
 doLogic();
 requestAnimationFrame(frame);
}

window.addEventListener("resize",()=>{
 canvas.width=canvas.clientWidth;
 canvas.height=canvas.clientHeight;
 cx=canvas.width/2;
 cy=canvas.height/2;
});

initVars();
frame();</script>


</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript返回顶部效果(自写代码)
Jan 06 Javascript
jquery ajax实现下拉框三级无刷新联动,且保存保持选中值状态
Oct 29 Javascript
jQuery实现平滑滚动到指定锚点的方法
Mar 20 Javascript
jQuery ajax应用总结
Jun 02 Javascript
jQuery实现的无限级下拉菜单功能示例
Sep 12 Javascript
javascript中的try catch异常捕获机制用法分析
Dec 14 Javascript
Bootstrap 3浏览器兼容性问题及解决方案
Apr 11 Javascript
强大的JavaScript响应式图表Chartist.js的使用
Sep 13 Javascript
微信小程序实现流程进度的图样式功能
Jan 16 Javascript
在layui下对元素进行事件绑定的实例
Sep 06 Javascript
微信小程序实现watch监听
Jun 04 Javascript
uniapp开发小程序实现滑动页面控制元素的显示和隐藏效果
Dec 10 Javascript
JavaScript之解构赋值的理解
Jan 30 #Javascript
JS实现点击按钮随机生成可拖动的不同颜色块示例
Jan 30 #Javascript
JS实现的新闻列表自动滚动效果示例
Jan 30 #Javascript
谈谈为什么你的 JavaScript 代码如此冗长
Jan 30 #Javascript
JS实现头条新闻的经典轮播图效果示例
Jan 30 #Javascript
AJAX在JQuery中的应用详解
Jan 30 #jQuery
JS实现换肤功能的方法实例详解
Jan 30 #Javascript
You might like
php中ob(Output Buffer 输出缓冲)函数使用方法
2007/07/21 PHP
PHP生成excel时单元格内换行问题的解决方法
2010/08/26 PHP
windows下zendframework项目环境搭建(通过命令行配置)
2012/12/06 PHP
Laravel 5 框架入门(二)构建 Pages 的管理功能
2015/04/09 PHP
简单了解将WordPress中的工具栏移到底部的小技巧
2015/12/31 PHP
PHP设计模式之观察者模式定义与用法分析
2019/04/04 PHP
jQuery学习4 浏览器的事件模型
2010/02/07 Javascript
js保留两位小数使用toFixed实现
2013/07/29 Javascript
jquery判断元素的子元素是否存在的示例代码
2014/02/04 Javascript
jquery.Ajax()方法调用Asp.Net后台的方法解析
2014/02/13 Javascript
jquery实现点击消失的代码
2014/03/03 Javascript
2014年50个程序员最适用的免费JQuery插件
2014/12/15 Javascript
JavaScript使用setInterval()函数实现简单轮询操作的方法
2015/02/02 Javascript
AngularJS基础 ng-keyup 指令简单示例
2016/08/02 Javascript
微信小程序模拟cookie的实现
2018/06/20 Javascript
js实现for循环跳过undefined值示例
2019/07/02 Javascript
VUE 解决mode为history页面为空白的问题
2019/11/01 Javascript
Javascript模块化机制实现原理详解
2020/04/02 Javascript
react 不用插件实现数字滚动的效果示例
2020/04/14 Javascript
[59:00]OG vs TNC 2018国际邀请赛小组赛BO2 第一场 8.19
2018/08/21 DOTA
[07:37]DOTA2-DPC中国联赛2月2日Recap集锦
2021/03/11 DOTA
Python通过poll实现异步IO的方法
2015/06/04 Python
python操作redis的方法
2015/07/07 Python
python实现读取并显示图片的两种方法
2017/01/13 Python
Python模拟鼠标点击实现方法(将通过实例自动化模拟在360浏览器中自动搜索python)
2017/08/23 Python
Python利用itchat对微信中好友数据实现简单分析的方法
2017/11/21 Python
Python+Turtle动态绘制一棵树实例分享
2018/01/16 Python
python抓取网页中链接的静态图片
2018/01/29 Python
20个常用Python运维库和模块
2018/02/12 Python
完美解决Python matplotlib绘图时汉字显示不正常的问题
2019/01/29 Python
Django实现auth模块下的登录注册与注销功能
2019/10/10 Python
python OpenCV GrabCut使用实例解析
2019/11/11 Python
Python3并发写文件与Python对比
2019/11/20 Python
纽约复古灵感的现代珠宝品牌:Lulu Frost
2018/03/03 全球购物
新党员入党决心书
2015/09/22 职场文书
吉利入股戴姆勒后smart“长大了”
2022/04/21 数码科技