Tween.js 使用文档 --- Three.js

Tween.js官网文档:tween.js user guide | tween.js (tweenjs.github.io)

Tween.js 基本使用

1. 引入Tween.js

import TWEEN from "./tween.js-master/dist/tween.esm.js"

 

2. 定义基本Tween动画 

目的:将model模型的位置,从原来的(0,0,0)位置,经过1s移动到(20,50,30)的位置。

模式一:

 

// 1 设置动画
const action=new TWEEN.Tween({x:0,y:0,z:0}) // 初始值.to({x:20,y:50,z:30},1000) // 目标值,毫秒数// 在动画执行期,不断被调用。其中obj为"to"里面的内容.onUpdate(function(obj){ model.position.x=obj.x; // x:20model.position.y=obj.y;model.position.z=obj.z;}).start()// 2 启动动画
function loop(){// 更新动画TWEEN.update() requestAnimationFrame(render);
}

模式二:

const action=new TWEEN.Tween(model.position) // 初始值:模型的初始位置.to({x:20,y:50,z:30},1000) // 目标值,毫秒数.start()

 3 字段说明

const action=new TWEEN.Tween(需添加动画的属性) 

字段含义示例备注
start执行动画action.start( ) action.start(num).start(毫秒数):延迟n毫秒之后运行动画
stop停止动画action.stop( )停止的动画必须为正在运行的动画
chain链式执行动画actA.chain(actB,actC)1. 当actA动画执行完后,立即执行actBactC动画,其中B和C同时被执行。2. 前提:actA.start( ), actB和actC不需要开启.start( )
repeat重复执行动画action.repeat(num) action.repeat(Infinity)1. num 重复执行的次数 2. Infinity 无限循环
yoyo重复执行时是否衔接(起始值-结束值-起始值)溜溜球action.yoyo(true)只有在repeat( )独立使用时有效
delay延迟执行动画action.delay(num)action.delay(1000).start( ) 延迟1000毫秒后执行动画,delaystart之前
to控制动画结束时的目标值+动画持续时间(毫秒)action.to(object,num)
easing缓动动画TWEEN.Easing.easing函数.easing类型easing函数:算法->运动效果 easing函数:算法起作用的地方InOutInOut
onUpdate在动画播放时,一直被调用onUpdate(function)function(obj){ } 形参obj指目标值(to( )的第1个参数)
onStart动画开始播放时被调用一次onStart(function)
onComplete动画结束时被调用一次onComplete(function)

警告:调用 actA.chain(actB) 实际上修改了actA,所以chain 的返回值只是actA,不是一个新的tween。

警告:yoyo(true) 只有在repeat(Infinity||200)单独使用时有效

4 easing 缓动动画 

 地址:/tween.js-master/examples/03_graphs.html 官方网址 · GitHub

 

 

// 动画开始缓动-类比加速器
action.easing(TWEEN.Easing.Sinusoidal.In);
// 动画结束时缓动-类比减速刹车
action.easing(TWEEN.Easing.Sinusoidal.Out);
// 同时设置In和Out
action.easing(TWEEN.Easing.Sinusoidal.InOut);

 

5 例:相机旋转+模型淡入淡出动画

目的:

  1. 当镜头移动时,镜头始终对准model模型,模型呈现淡入的效果
  2. 当移动返回时,镜头始终对准model模型,模型呈现淡出的效果

镜头移动动画:

const cameraAct=new TWEEN.Tween(camera.position).to({x:-100},3000)// 相机移动时,焦点始终为模型的位置.onUpdate(function(){camera.lookAt(model.position)}).start()

 

模型淡入动画:

const meshActIn = new TWEEN.Tween({ opacity: 0.0 }).to({ opacity: 1.0 }, 3000)// 动画开始:开启材质的透明度.onStart(function () {mat.transparent = true;}).onUpdate(function (obj) {mat.opacity = obj.opacity;})// 动画结束:关闭材质的透明度.onComplete(function () {mat.transparent = false;}).start();

 模型淡出动画:

const meshActOut =new TWEEN.Tween({opacity:mat.opacity}).to({opacity:0.0}, 3000)// 动画开始:允许透明opacity属性才能生效.onStart(function(){material.transparent = true;}).onUpdate(function(obj){material.opacity = obj.opacity}).start();

备注

  1. 材质需开启transparent,才能设置透明程度opacity
    const mat = new THREE.MeshLambertMaterial({color: 0x00ffff,transparent: true,opacity: 0.8,
    });

  2. 调用 actA.chain(actB) 实际上修改了actA,所以chain 的返回值只是actA,不是一个新的tween。
  3. yoyo(true) 只有在repeat(Infinity||200)单独使用时有效

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/428033.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

杰卡德距离(Jaccard Distance)

杰卡德距离(Jaccard Distance),是用于衡量两个集合差异性的一种指标,它是杰卡德相似系数的补集,可以用来区分集合(如知识图谱)。 杰卡德相似系数 杰卡德相似系数(Jaccard similari…

橘子学Mybatis08之Mybatis关于一级缓存的使用和适配器设计模式

前面我们说了mybatis的缓存设计体系,这里我们来正式看一下这玩意到底是咋个用法。 首先我们是知道的,Mybatis中存在两级缓存。分别是一级缓存(会话级),和二级缓存(全局级)。 下面我们就来看看这两级缓存。 一、准备工作 1、准备数据库 在此之…

深度学习在物理层信号处理中的应用研究

随着移动流量呈现的爆发式增长、高可靠性和低时延的通信场景给当前网络带来了更大的复杂性和计算挑战。据IBM报道,移动数据量到2020年将超过40万亿Gbits,比2009年增加44倍,连接总设备量将达到500亿。为了满足这一需求,需要新的通信…

云卷云舒:PostgreSQL的事儿你听说了吗?

最近,PostgreSQL公布了全球贡献者名单。 以上是全球贡献者主要成员,可以看出都是外国人,除了一名台湾省贡献者外,几乎再看不到中国贡献者的身影。 那么偌大的中国,为什么在PostgreSQL的全球贡献者名单里面就看不到人呢…

【GitHub项目推荐--一款美观的开源社区系统】【转载】

推荐一款开源社区系统,该系统基于主流的 Java Web 技术栈,如果你是一名 Java 新手掌握了基本 JavaEE 框架知识,可以拿本项目作为练手项目。 开源社区系统功能还算完善包含发布帖子、发布评论、私信、系统通知、点赞、关注、搜索、用户设置、…

遇到DNS劫持怎么办

什么是DNS劫持? DNS劫持又称域名劫持,是攻击者利用缺陷对用户的DNS进行篡改,将域名由正常IP指向攻击者控制的IP,从而导致访客被劫持到一个不可达或者假冒的网站,以此达到非法窃取用户信息或者破坏正常网络服务的目的。…

一个使用pyqt的word文档查重工具

一个使用pyqt的word文档查重工具 使用场景代码使用截图打包好的软件下载链接结尾 使用场景 有时我们在借鉴一篇文档之后还不想有太多重复,这个时候可以使用这个工具对两个word文档进行对比 代码 import sys from PyQt5.QtWidgets import QApplication, QMainWind…

计算机设计大赛 交通目标检测-行人车辆检测流量计数 - 计算机设计大赛

文章目录 0 前言1\. 目标检测概况1.1 什么是目标检测?1.2 发展阶段 2\. 行人检测2.1 行人检测简介2.2 行人检测技术难点2.3 行人检测实现效果2.4 关键代码-训练过程 最后 0 前言 🔥 优质竞赛项目系列,今天要分享的是 🚩 毕业设计…

Hudi学习笔记(一)

大数据发展背景 Hudi用于管理分布式文件系统上大型分析数据集存储,支持Spark和Flink整合。它能够是DFS数据集在分钟级时延内支持变更,也支持下游系统对这个数据集的增量处理。 学习目标 什么是数据湖为什么使用数据湖Hudi基本功能如何编译Hudi源码Hud…

NAT地址转换协议

目录 NAT应用场景静态NAT动态NATNAPTEasy IPNAT服务器 点击跳转NAT配置(动态nat,静态nat,Easy IP) NAT应用场景 - 随着网络设备的数量不断增长,对IPv4地址的需求也不断增加,导致可用IPv4地址空间逐渐耗尽…

Mysql全局优化

Mysql全局优化总结 从上图可以看出SQL及索引的优化效果是最好的,而且成本最低,所以工作中我们要在这块花更多时间。 补充一点配置文件my.ini或my.cnf的全局参数: 假设服务器配置为: CPU:32核内存:64GDIS…

利用git上传本地文件

1、建立仓库 2.然后刷新网站,获取下载链接,备用。 3、接下来在本地创建一个文件夹, 4、把github上面的仓库克隆到本地 git clone https://github.com/xxxxx(https://github.com/xxxxx替换成你之前复制的地址) 5、把…