Three.js 骨骼动画工程实战:AnimationMixer、剪辑与混合权重调参

文章目录

Three.js 骨骼动画工程实战:AnimationMixer、剪辑与混合权重调参

GLTF 角色落地后,真正决定「手感」的是 AnimationMixerAnimationAction 的组合使用:谁在更新时钟、谁在裁剪骨骼、混合权重如何衰减,都直接影响性能与表现。

一、最小可用管线

  1. mixer = new THREE.AnimationMixer(root)root 通常取 SkinnedMesh 或包含骨架的 Group。
  2. const clip = THREE.AnimationClip.findByName(animations, 'Run') 取剪辑;action = mixer.clipAction(clip)
  3. 每帧:mixer.update(delta),且 delta 必须用真实帧间隔clock.getDelta()),不要用固定 1/60 糊弄。
javascript 复制代码
const clock = new THREE.Clock();
function animate() {
  requestAnimationFrame(animate);
  const dt = clock.getDelta();
  mixer.update(dt);
  renderer.render(scene, camera);
}

二、多动作混合与优先级

  • fadeIn / fadeOut:切换站立↔跑步时用淡入淡出,避免瞬时跳变。
  • setEffectiveWeight:上层逻辑(如受伤、瞄准)叠加时,用权重而不是开多个 Mixer。
  • stop / reset :切场景前对 action.stop(),并从 Map 里移除引用,防止闭包持有旧 SkinnedMesh

三、工程坑点

现象 常见原因 处理
动画「抽搐」 同一骨骼被多个 Action 强混合 降低冲突轨权重或使用掩码
CPU 飙高 每帧全量 mixer.update 且剪辑极多 只更新可见角色;远处降采样
内存涨 Clip 未复用、重复 clipAction 缓存 Map<name, AnimationClip>

四、结语

骨骼动画的稳定性来自 单一 Mixer 时钟成对的 play/stop。把更新与资源释放写进路由/关卡生命周期,线上才不会「切场景后越跑越卡」。

相关推荐
RPGMZ21 小时前
RPGMZ游戏引擎 一个窗口 文本居中显示
开发语言·javascript·游戏引擎·rpgmz
爱滑雪的码农1 天前
详细说说React大型项目结构以及日常开发核心语法
前端·javascript·react.js
@大迁世界1 天前
43.HTML 事件处理和 React 事件处理有什么区别?
前端·javascript·react.js·html·ecmascript
代钦塔拉1 天前
Qt4 vs Qt5 带参数信号槽的连接方式详解
开发语言·数据库·qt
ZC跨境爬虫1 天前
跟着 MDN 学 HTML day_38:(DocumentFragment 文档片段接口详解)
前端·javascript·ui·html·音视频
@大迁世界1 天前
41.ShadCN 是什么?它如何和 Tailwind CSS 集成,从而更容易构建可访问且可自定义的 React 组件?
前端·javascript·css·react.js·前端框架
InfinteJustice1 天前
踩坑分享C 语言文件操作全攻略:从基础读写到随机访问与缓冲区原理
c语言·开发语言·microsoft
码云数智-大飞1 天前
滥用Lombok的@EqualsAndHashCode导致线上事故复盘
开发语言
yong99901 天前
C# 实时查看硬件使用率(CPU 内存 硬盘 网络)
开发语言·网络·c#
不午休の野猫1 天前
vs + qt环境编译.sln项目时报无法解析的外部符号metaObject && qt_metacast
开发语言·qt