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、效果图

相关推荐
发现一只大呆瓜6 小时前
虚拟列表:从定高到动态高度的 Vue 3 & React 满分实现
前端·vue.js·react.js
css趣多多7 小时前
add组件增删改的表单处理
java·服务器·前端
证榜样呀7 小时前
2026 大专计算机专业必考证书推荐什么
大数据·前端
蓝帆傲亦7 小时前
前端性能极速优化完全指南:从加载秒开体验到丝滑交互
前端·交互
鱼毓屿御7 小时前
如何给用户添加权限
前端·javascript·vue.js
JustHappy7 小时前
「web extensions🛠️」有关浏览器扩展,开发前你需要知道一些......
前端·javascript·开源
何中应7 小时前
nvm安装使用
前端·node.js·开发工具
xixixin_7 小时前
【JavaScript 】从 || 到??:JavaScript 空值处理的最佳实践升级
开发语言·javascript·ecmascript
Java新手村7 小时前
基于 Vue 3 + Spring Boot 3 的 AI 面试辅助系统:实时语音识别 + 大模型智能回答
vue.js·人工智能·spring boot
雯0609~7 小时前
hiprint:实现项目部署与打印3-vue版本-独立出模板设计与模板打印页面
前端·vue.js·arcgis