JavaScript实现飞舞的泡泡效果


Posted in Javascript onFebruary 07, 2020

本文实例为大家分享了JavaScript实现飞舞泡泡效果的具体代码,供大家参考,具体内容如下

示例

JavaScript实现飞舞的泡泡效果

CSS

html,
body {
 margin: 0;
 padding: 0;
 width: 100%;
 height: 100%;
}

canvas {
 position: fixed;
 width: 100%;
 height: 100%;
}

JS

const nbObjects = 800;
var conf, scene, camera, cameraCtrl, light, renderer;
var whw, whh;

var objects;
var spriteMap, spriteMaterial;

var mouse = new THREE.Vector2();
var mouseOver = false;
var mousePlane = new THREE.Plane(new THREE.Vector3(0, 0, 1), 0);
var mousePosition = new THREE.Vector3();
var raycaster = new THREE.Raycaster();

function init() {
 conf = {
 opacity: 0.8
 };

 scene = new THREE.Scene();
 camera = new THREE.PerspectiveCamera(100, window.innerWidth / window.innerHeight, 0.1, 1000);
 cameraCtrl = new THREE.OrbitControls(camera);
 cameraCtrl.autoRotate = true;
 cameraCtrl.autoRotateSpeed = 5;

 renderer = new THREE.WebGLRenderer();
 renderer.setSize(window.innerWidth, window.innerHeight);
 document.body.appendChild(renderer.domElement);

 initScene();

 onWindowResize();
 window.addEventListener('resize', onWindowResize, false);

 animate();
};

function initScene() {
 scene = new THREE.Scene();
 scene.background = new THREE.Color(0xFFF8DC);

 camera.position.z = 30;
 camera.position.y = 20;
 camera.lookAt(0, 0, 0);

 spriteMap = new THREE.Texture();
 var bubble = new Image();
 bubble.src = "";
 bubble.onload = function () {
 spriteMap.image = bubble;
 spriteMap.needsUpdate = true;
 };

 objects = [];
 for (var i = 0; i < nbObjects; i++) {
 var object = new Truc();
 objects.push(object);
 scene.add(object.sprite);
 }
}

function animate() {
 requestAnimationFrame(animate);

 cameraCtrl.update();

 renderer.render(scene, camera);
};

function Truc() {
 this.init();
 this.shuffle();
}

Truc.prototype.init = function () {
 this.material = new THREE.SpriteMaterial({
 color: randomColor({ luminosity: 'light' }),
 map: spriteMap,
 transparent: true,
 opacity: 1,
 depthTest: false,
 depthWrite: false,
 blending: THREE.AdditiveBlending
 });
 this.sprite = new THREE.Sprite(this.material);
};

Truc.prototype.shuffle = function () {
 this.scale1 = 0.1;
 this.scale2 = 2 + rnd(3);
 this.sprite.scale.set(this.scale1, this.scale1, 1);

 var rndv = getRandomVec3();
 this.sprite.position.set(rndv.x, rndv.y, rndv.z).multiplyScalar(50);
 this.sprite.position.y -= 25;

 this.material.opacity = conf.opacity;

 this.tt = this.scale2;
 TweenMax.to(this.sprite.scale, 1, { x: this.scale2, y: this.scale2, ease: Power2.easeIn });
 TweenMax.to(this.sprite.position, this.scale2, { y: this.sprite.position.y + 100, ease: Power2.easeIn });

 this.t1 = 1;
 TweenMax.to(this.sprite.position, this.t1, {
 x: this.sprite.position.x + rnd(10, true),
 z: this.sprite.position.z + rnd(10, true),
 ease:Linear.ease,
 repeat: Math.floor((this.tt/this.t1)/2),
 yoyo: true
 });

 TweenMax.to(this.material, 1, {
 opacity: 0,
 delay: this.tt-1,
 ease: Power2.easeIn,
 onCompleteParams: [this],
 onComplete: function (o) {
  o.shuffle();
 }
 });
};

function getRandomVec3() {
 const u = Math.random();
 const v = Math.random();
 const theta = u * 2.0 * Math.PI;
 const phi = Math.acos(2.0 * v - 1.0);
 const r = Math.cbrt(Math.random());
 const sinTheta = Math.sin(theta);
 const cosTheta = Math.cos(theta);
 const sinPhi = Math.sin(phi);
 const cosPhi = Math.cos(phi);
 const x = r * sinPhi * cosTheta;
 const y = r * sinPhi * sinTheta;
 const z = r * cosPhi;
 return { x: x, y: y, z: z };
}

function rnd(max, negative) {
 return negative ? Math.random() * 2 * max - max : Math.random() * max;
}

function onWindowResize() {
 whw = window.innerWidth / 2;
 whh = window.innerHeight / 2;
 camera.aspect = window.innerWidth / window.innerHeight;
 camera.updateProjectionMatrix();
 renderer.setSize(window.innerWidth, window.innerHeight);
}

init();

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

Javascript 相关文章推荐
跟着Jquery API学Jquery之一 选择器
Apr 07 Javascript
jquery 取子节点及当前节点属性值
Jul 25 Javascript
js光标定位文本框回车表单提交问题的解决方法
May 11 Javascript
七夕情人节丘比特射箭小游戏
Aug 20 Javascript
Validform表单验证总结篇
Oct 31 Javascript
Spring Boot+AngularJS+BootStrap实现进度条示例代码
Mar 02 Javascript
用vue和node写的简易购物车实现
Apr 25 Javascript
基于ExtJs在页面上window再调用Window的事件处理方法
Jul 26 Javascript
Javascript 对象(object)合并操作实例分析
Jul 30 Javascript
微信小程序页面调用自定义组件内的事件详解
Sep 12 Javascript
layui加载数据显示loading加载完成loading消失的实例代码
Sep 23 Javascript
springboot+vue实现文件上传下载
Nov 17 Vue.js
JavaScript实现Excel表格效果
Feb 07 #Javascript
js实现自动播放匀速轮播图
Feb 06 #Javascript
node爬取新型冠状病毒的疫情实时动态
Feb 06 #Javascript
vue 检测用户上传图片宽高的方法
Feb 06 #Javascript
vue中对象数组去重的实现
Feb 06 #Javascript
2019最新21个MySQL高频面试题介绍
Feb 06 #Javascript
node.JS路径解析之PATH模块使用方法详解
Feb 06 #Javascript
You might like
php下拉选项的批量操作的实现代码
2013/10/14 PHP
php生成二维码
2015/08/10 PHP
深入浅析PHP7.0新特征(五大新特征)
2015/10/29 PHP
PHP入门教程之数组用法汇总(创建,删除,遍历,排序等)
2016/09/11 PHP
浅析PHP反序列化中过滤函数使用不当导致的对象注入问题
2020/02/15 PHP
JS跨域总结
2012/08/30 Javascript
js 固定悬浮效果实现思路代码
2013/08/02 Javascript
jQuery实现公告文字左右滚动的实例代码
2013/10/29 Javascript
jQuery实现图片加载完成后改变图片大小的方法
2016/03/29 Javascript
jQuery hover事件简单实现同时绑定2个方法
2016/06/07 Javascript
全面了解JS中的匿名函数
2016/06/29 Javascript
js 获取当前web应用的上下文路径实现方法
2016/08/19 Javascript
微信小程序 教程之数据绑定
2016/10/18 Javascript
Nodejs下用submit提交表单提示cannot post错误的解决方法
2016/11/21 NodeJs
Ionic2系列之使用DeepLinker实现指定页面URL
2016/11/21 Javascript
Vue获取DOM元素样式和样式更改示例
2017/03/07 Javascript
js 两数组去除重复数值的实例
2017/12/06 Javascript
Angular实现点击按钮后在上方显示输入内容的方法
2017/12/27 Javascript
JS实现在线ps功能详解
2019/07/31 Javascript
查找Vue中下标的操作(some和findindex)
2020/08/12 Javascript
Python获取单个程序CPU使用情况趋势图
2015/03/10 Python
python SMTP实现发送带附件电子邮件
2018/05/22 Python
从请求到响应过程中django都做了哪些处理
2018/08/01 Python
python实现批量修改服务器密码的方法
2019/08/13 Python
Django Serializer HiddenField隐藏字段实例
2020/03/31 Python
巴西最大的体育用品商城:Netshoes巴西
2016/11/29 全球购物
波兰品牌内衣及泳装网上商店:Astratex.pl
2017/02/03 全球购物
卫校中专生个人自我评价
2013/09/19 职场文书
建筑文秘专业个人求职信范文
2013/12/28 职场文书
《小儿垂钓》教学反思
2014/02/23 职场文书
社区矫正工作方案
2014/06/04 职场文书
机关作风建设自查报告
2014/10/22 职场文书
2015年街道办事处工作总结
2015/05/22 职场文书
小学教师读书笔记
2015/07/01 职场文书
MySQL命令行操作时的编码问题详解
2021/04/14 MySQL
ubuntu端向日葵键盘输入卡顿问题及解决
2022/12/24 Servers