Threejs-06、利用lil-GUI调试3D效果

1、 引入lil.gui

javascript 复制代码
// 引入lil.gui
import { GUI } from "three/examples/jsm/libs/lil-gui.module.min.js";

2、创建GUI

javascript 复制代码
const gui =  new GUI();

3、添加按钮

javascript 复制代码
let eventObj = {
  // 全屏事件
  Fullscreen:function(){
    // 全屏
    document.body.requestFullscreen();
    console.log("全屏事件");
  },
  ExitFullscreen:function(){
    // 退出全屏
    document.exitFullscreen();
    console.log("退出全屏事件");
  }
}

// 添加按钮
gui.add(eventObj,"Fullscreen").name("全屏")
gui.add(eventObj,"ExitFullscreen").name("退出全屏");

4、控制立方体位置

javascript 复制代码
// 控制立方体位置   第一种写法
gui.add(parentCube.position,"x",-5,5).name("立方体x轴的位置");
// 第二种写法
gui.add(parentCube.position,'x').min(-10).max(10).step(1).name('立方体x轴的位置');
let foder = gui.addFolder("立方体位置")
foder.add(parentCube.position,'x').min(-10).max(10).step(1).name('立方体x轴的位置');
foder.add(parentCube.position,'y').min(-10).max(10).step(1).name('立方体x轴的位置');
foder.add(parentCube.position,'z').min(-10).max(10).step(1).name('立方体x轴的位置');

5、x轴改变触发事件

javascript 复制代码
// x轴改变触发事件
foder.add(parentCube.position,'z').min(-10).max(10).step(1).name('立方体x轴改变触发事件').onChange(
  (val)=>{
    console.log("立方体x轴位置",val);
  }
)
foder.add(parentCube.position,'z').min(-10).max(10).step(1).name('立方体x轴改变触发事件').onFinishChange(
  (val)=>{
    console.log("立方体x轴改变完成触发",val);
  }
)

6、设置元素是否有线框

javascript 复制代码
// 设置元素是否有线框
gui.add(parentCubematerial,"wireframe").name("父元素线框模式");

7、设计立方体颜色改变

javascript 复制代码
// 设计立方体颜色改变
let colorParams = {
  cubeColor:"#00ff00"
}
gui.addColor(colorParams,"cubeColor").name("立方体颜色").onChange(
  (val)=>{
    cube.material.color.set(val);
  }
);

8、效果图

相关推荐
存在的五月雨4 小时前
Nodejs的一些
前端
l14372332674 小时前
短剧出海翻译工具测评:同一段素材实测对比
大数据·前端·人工智能
Irene19914 小时前
Vue3 举例说明如何编写一个自定义组合式函数(与 Mixins 相比的优势)
vue.js
小马_xiaoen4 小时前
Vue 3 + TS 实战:手写 v-no-emoji 自定义指令,彻底禁止输入框表情符号!
前端·javascript·vue.js
文心快码BaiduComate4 小时前
有奖征集|解锁Comate超能力:一文玩转Comate Skills
前端·后端
小码哥_常4 小时前
Android 集合探秘:ArrayMap 与 SparseArray 的奇妙之旅
前端
林九生4 小时前
【Flutter】Flutter 拍照/相册选择后无法显示对话框问题解决方案
前端·javascript·flutter
程序员小寒4 小时前
JavaScript设计模式(四):发布-订阅模式实现与应用
开发语言·前端·javascript·设计模式
Highcharts.js4 小时前
Highcharts Gantt 实战:从框架集成到高级功能应用-打造现代化、交互式项目进度管理图表
前端·javascript·vue.js·信息可视化·免费
程序猿的程4 小时前
把股票数据能力接进 AI:stock-sdk-mcp 的实践整理
前端·javascript·node.js