Inversionor 后端成长日志

Three.js 之 5 debug UI

2022-05-22
HyG

本系列为 Three.js journey 教程学习笔记。

本节将学习 debug UI。用于实时方便调整动画或物体的各种参数。我们可以自己开发,也可以使用一个三方库,这里我们选择使用现成的库。

常见的库有

  • dat.GUI
  • control-panel
  • ControlKit
  • Guify
  • Oui

dat.GUI

我们将学习 dat.GUI,这个 debugUI 的 api 也非常简单可以直接参考 api文档

我们添加如下代码

/**
 * Debug
 */
const gui = new dat.GUI({
  // closed: true,
  width: 400,
})
// gui.hide() // press H to show

gui.add(cubeMesh.position, 'y').min(-3).max(3).step(0.01)
  .name('cubeMesh Y') // 别名
gui.add(cubeMesh.position, 'x').min(-3).max(3).step(0.01)
gui.add(cubeMesh.position, 'z').min(-3).max(3).step(0.01)

gui.add(cubeMesh, 'visible') // boolean
gui.add(cubeMesh.material, 'wireframe') // boolean

const debugObj = {
  color: defaultColor,
  spin() {
    gsap.to(cubeMesh.rotation, {
      duration: 1,
      y: cubeMesh.rotation.y + Math.PI * 2,
    })
  },
}

gui.addColor(debugObj, 'color').onChange((e) => {
  cubeMesh.material.color.set(e)
})

gui.add(debugObj, 'spin') // function

效果如下

动态演示

完整代码和 demo 如下

在线 demo 链接

demo 源码

小结

项目开发的过程中就可以添加 debug UI,开发过程可以不断调整,找到最佳值。


Similar Posts

Comments