three.js-結(jié)合dat.gui實(shí)現(xiàn)界面可視化修改及調(diào)試詳解
gitee 地址
gitee地址: gittee地址
本篇目標(biāo)
- 結(jié)合dat.gui實(shí)現(xiàn)界面可視化修改及調(diào)試
下載 dat.gui
pnpm i dat.gui
引入及創(chuàng)建
引入
import * as Dat from "dat.gui";
創(chuàng)建
/// 創(chuàng)建 dat const dat = new Dat.GUI();
使用
這里我是裝在一個(gè)函數(shù)里的,但不影響
/// 添加菜單
function addMenuItem () {
// x 軸坐標(biāo)
dat
.add(cube.position, 'x')
.max(10)
.min(0)
.step(0.01)
.name('移動(dòng)x軸')
.onChange(value => {
console.log('我是當(dāng)前正在移動(dòng)的x軸', value);
})
.onFinishChange(value => {
console.log('我是當(dāng)前移動(dòng)結(jié)束的x軸', value);
})
}
// 添加菜單
addMenuItem ()
效果圖

這樣我們?cè)O(shè)置和退出畫布全屏的這個(gè)功能就做好了。
完整代碼
import * as THREE from "three"
// 目標(biāo):使用 dat.gui 進(jìn)行 可視化調(diào)試
import * as Dat from "dat.gui";
/// 創(chuàng)建場(chǎng)景
const scene = new THREE.Scene()
/// 創(chuàng)建 dat
const dat = new Dat.GUI();
/// 創(chuàng)建相機(jī)
/*
PerspectiveCamera( fov : Number, aspect : Number, near : Number, far : Number )
fov — 攝像機(jī)視錐體垂直視野角度
aspect — 攝像機(jī)視錐體長寬比
near — 攝像機(jī)視錐體近端面
far — 攝像機(jī)視錐體遠(yuǎn)端面
*/
/// 透視相機(jī)
const camera = new THREE.PerspectiveCamera(
75, // 攝像機(jī)視錐體垂直視野角度,從視圖的底部到頂部,以角度來表示。默認(rèn)值是50。
window.innerWidth / window.innerHeight, // 攝像機(jī)視錐體的長寬比,通常是使用畫布的寬/畫布的高。默認(rèn)值是1(正方形畫布)。
0.1, // 攝像機(jī)的近端面,默認(rèn)值是0.1。
1000 // 攝像機(jī)的遠(yuǎn)端面,默認(rèn)值 2000
)
/// 創(chuàng)建渲染器
const renderer = new THREE.WebGLRenderer();
/// 設(shè)置大小
renderer.setSize(
1000, // 寬度
500 // 高度
);
/// 掛載到頁面
document.body.appendChild(renderer.domElement)
/// 添加物體
/*
width:立方體x軸的長度,
height:立方體y軸的長度,
depth:立方體z軸的長度也是深度
*/
let geometry = new THREE.BoxGeometry(10, 10, 10);
/// 添加材質(zhì)
// const material = new THREE.MeshBasicMaterial({ color: 0xffff0000 });
/// 添加材質(zhì)
const materials = []
for(let i = 0; i < 6; i++){
materials.push(new THREE.MeshBasicMaterial({ color: Math.random() * 0x00ff0000 }))
}
/// 添加網(wǎng)格
const cube = new THREE.Mesh( geometry, materials );
scene.add( cube );
// 設(shè)置相機(jī)位置
camera.position.z = 50;
// 修改場(chǎng)景背景顏色
scene.background = new THREE.Color(0xffffcc99)
/// 添加 三色坐標(biāo)軸
const axesHelper = new THREE.AxesHelper(20)
scene.add( axesHelper )
/// 渲染
function animate() {
// 使用 requestAnimationFrame 執(zhí)行動(dòng)畫
requestAnimationFrame(animate)
// 修改其旋轉(zhuǎn)的度數(shù),讓其每次渲染增加0.01的弧段進(jìn)行渲染
cube.rotation.x += 0.01;
cube.rotation.y += 0.01;
//scene:前面定義的場(chǎng)景,camera:前面定義的相機(jī)
//renderTarget:渲染的目標(biāo)默認(rèn)是是渲染到前面定義的render變量中
//forceClear:每次繪制之前都將畫布的內(nèi)容給清除,即使自動(dòng)清除標(biāo)志autoClear為false,也會(huì)清除
renderer.render(scene, camera)
}
/// 添加菜單
function addMenuItem () {
// x 軸坐標(biāo)
dat
.add(cube.position, 'x')
.max(10)
.min(0)
.step(0.01)
.name('移動(dòng)x軸')
.onChange(value => {
console.log('我是當(dāng)前正在移動(dòng)的x軸', value);
})
.onFinishChange(value => {
console.log('我是當(dāng)前移動(dòng)結(jié)束的x軸', value);
})
}
// 渲染
animate()
// 添加菜單
addMenuItem ()
以上就是three.js-結(jié)合dat.gui實(shí)現(xiàn)界面可視化修改及調(diào)試詳解的詳細(xì)內(nèi)容,后續(xù)會(huì)講解根據(jù) BufferGeometry 設(shè)置的頂點(diǎn)創(chuàng)建幾何矩形,更多關(guān)于three.js dat.gui界面可視化的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
JS構(gòu)造函數(shù)和實(shí)例化的關(guān)系及原型引入
這篇文章主要介紹了JS構(gòu)造函數(shù)和實(shí)例化的關(guān)系及原型引入,下文圍繞JS構(gòu)造函數(shù)和實(shí)例化的關(guān)系及原型引入的西安海關(guān)資料展開全文內(nèi)容,需要的朋友可以參考一下,希望對(duì)大家有所幫助2021-11-11
微信小程序之獲取當(dāng)前位置經(jīng)緯度以及地圖顯示詳解
最近剛開始接觸微信小程序,在弄懂其結(jié)構(gòu)以及相關(guān)接口之后,準(zhǔn)備著手實(shí)現(xiàn)一個(gè)小程序,功能包括--獲取用戶當(dāng)前位置的經(jīng)緯度,在地圖上查看位置,通過地圖獲取不同位置的經(jīng)緯度。2017-05-05
Web應(yīng)用開發(fā)TypeScript使用詳解
這篇文章主要為大家介紹了Web應(yīng)用開發(fā)TypeScript的使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-05-05
webpack5之output和devServer的publicPath區(qū)別示例詳解
這篇文章主要為大家介紹了webpack5之output和devServer的publicPath區(qū)別示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12

