vue中将three.js导入的3D模型中原本带有的动画进行播放

1.首先是你要确保模型中是有动画的

2.在加载模型后获取动画混合器并对设置动画的物体进行播放

javascript 复制代码
 loadModel() {
      // 加载3D模型
      const loader = new GLTFLoader();
      loader.load('/models/donghua.glb', (gltf) => {
        this.model = gltf.scene
        this.scene.add(this.model);
        // 获取动画混合器
        const animations = gltf.animations;
        if (animations && animations.length) {
          this.mixer = new THREE.AnimationMixer(gltf.scene);
          for (let i = 0; i < animations.length; i++) {
            const action = this.mixer.clipAction(animations[i]);
            action.play();
          }
        }
      }, (xhr) => {
        console.log(xhr, 'xhr');
      }, (err) => {
        console.log(err, 'err');
      });
}

3.关键的一步在动画的函数中去实时更新模型动画update函数中的值越小转动越快

javascript 复制代码
 animate() {
      this.controls.update()
      this.renderer.render(this.scene, this.camera)
      requestAnimationFrame(this.animate)
       // 更新动画
       if (this.mixer) {
        this.mixer.update(0.05);
      }
}

就愉快的转起来了

相关推荐
艾小码15 分钟前
Vue 3全面解析:Composition API、响应式原理与生态
前端·javascript·vue.js
Process16 分钟前
面试官:Vue和React源码里用到了哪些设计模式?
前端·javascript·面试
华仔啊16 分钟前
Vue3+TS设计模式:5个真实场景让你代码更优雅
前端·javascript·vue.js
兮漫天17 分钟前
bun + vite7 的结合,孕育的 Robot Admin 【靓仔出道】(十六)
前端·javascript·vue.js
qb20 分钟前
vue3.5.18源码:reactive和单例、代理和发布订阅者之间的关系
前端·javascript·vue.js
holidaypenguin22 分钟前
ant-design-vue@4.2.6 自定义表单控件
前端·vue.js
菜牙买菜22 分钟前
深度解析HiCharts联动与交互:手把手实现数据与图表的“对话”
前端·vue.js·数据可视化
草帽lufei23 分钟前
3DMap大屏那些事儿
前端·vue.js·echarts
Momentary_SixthSense26 分钟前
RESP协议
java·开发语言·javascript·redis·后端·python·mysql
yvvvy29 分钟前
一文搞懂 position:从小红点到粘性导航,再到浏览器底层原理
前端·javascript