vue2.x引入threejs的實例代碼
vue2.x引入threejs
npm安裝
npm install three
使用指定版本:
npm install three@<版本號>
其他插件
因為本次開發(fā)需要引入3D模型,所以需要使用 MTLLoader, OBJLoader兩種加載器,因為開發(fā)需求和
版本問題, 最新版本自帶的加載器不能實現(xiàn)需求,所以需要額外引入three-obj-mtl-loader插件,并且threejs版本需要退到122版本;
npm安裝three-obj-mtl-loader
npm install three-obj-mtl-loader --save
實例
//-- html部分 -- 開始 --
<div class="three_box" id="container">
</div>
//-- html部分 -- 結(jié)束 --
import * as THREE from 'three';
import { OrbitControls } from "three/examples/jsm/controls/OrbitControls"; // 控制器-控制相機運行軌道
import { MTLLoader, OBJLoader } from 'three-obj-mtl-loader' //項目中使用到.obj文件和.mtl文件,故引入
mounted() {
let width = 1053 // dom寬度
let height = 473 // dom高度
this.scene = new THREE.Scene()// 運行創(chuàng)建場景函數(shù)
let mtlLoader = new MTLLoader() //創(chuàng)建MTLLoader實例
let objLoader = new OBJLoader() //創(chuàng)建OBJLoader實例
let k = width / height // 寬高比
let camera = new THREE.PerspectiveCamera( 60, k, 1, 2000) //創(chuàng)建相機,這個相機模擬人眼所看到的景象,近大遠(yuǎn)小沒參數(shù)分別為:
//fov — 攝像機視錐體垂直視野角度
//aspect — 攝像機視錐體長寬比
//near — 攝像機視錐體近端面
//far — 攝像機視錐體遠(yuǎn)端面
camera.position.set( -500, 300, 300 )//設(shè)置相機位置
this.initDoor()//調(diào)用引入3D模型方法
this.initcao() //調(diào)用幾何圖形方法
//點光源
let point = new THREE.PointLight(0xffffff)
point.position.set(800, 800, 2000); //光源位置
this.scene.add(point); //光源添加進(jìn)場景
//環(huán)境光
let ambient = new THREE.AmbientLight(0xffffff); //設(shè)置環(huán)境光
this.scene.add(ambient) //講環(huán)境光加入場景
this.renderer = new THREE.WebGL1Renderer(); // 實例渲染器
this.renderer.setSize( width, height) //渲染器寬高
this.renderer.setClearColor(new THREE.Color('#07224e'), 1) //設(shè)置背景顏色
setTimeout(() => {
document.getElementById('container').appendChild(this.renderer.domElement)//將渲染器添加進(jìn)dom
}, 500)
this.animate()//調(diào)用動畫效果
this.controls = new OrbitControls(this.camera, this.renderer.domElement) //添加相機和渲染器到控制器,實現(xiàn)滑動
},
methods: {
initcao() {
let geometry = new THREE.BoxGeometry(3200, 1600, 8); //矩形平面
let material = new THREE.MeshLambertMaterial({ // 配置樣式,包括顏色 透明度等
color: new THREE.Color('#bcbfc6'),
transparent: true,
opacity: 0.3,
side: THREE.DoubleSide
});
let mesh = new THREE.Mesh(geometry, material); //網(wǎng)格模型對象Mesh
mesh.rotateX(-Math.PI / 2);
this.scene.add(mesh); //網(wǎng)格模型添加到場景中
},
initDoor() {
let that = this //后面回調(diào)會影響this指向
let mtlLoader = new MTLLoader()
let objLoader = new OBJLoader();
mtlLoader.load('static/door.mtl', function( material) { //引入模型.mtl文件,是3D模型的貼圖,如果不需要貼圖可以不使用,模型會只有一個框架
material.preload();
objLoader.setMaterials(material)
objLoader.load('static/door.obj', //引入模型.obj文件
function( obj) {
obj.position.z = -188 //調(diào)整模型位置
obj.position.x = -265 //調(diào)整模型位置
obj.position.y = 10 //調(diào)整模型位置
obj.rotateY(Math.PI / 2) //調(diào)整模型角度
obj.scale.set( 20, 20, 20 ) //調(diào)整模型放大縮小倍數(shù)
that.scene.add(obj) //模型添加進(jìn)場景
},
)
})
},
animate() {
//這里自己寫點要對模型進(jìn)行的操作
this.renderer.render(this.scene, this.camera);
requestAnimationFrame(this.animate) //這里按幀更新畫面,大概一秒60次左右
},
}
強調(diào)
如果在開發(fā)中需要引入3D模型,模型文件應(yīng)放在與src文件同級的static下,引入方式應(yīng)該是 'static/door.mtl'
如果在開發(fā)過程中出現(xiàn)threejs生成的canvas出現(xiàn)外邊框,只需要用css樣式修改,代碼如下:
.three_box {
width: 1053px;
height: 473px;
>>> canvas:focus-visible {
outline: 0px
}
}到此這篇關(guān)于vue2.x引入threejs的文章就介紹到這了,更多相關(guān)vue2.x引入threejs內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
用Axios Element實現(xiàn)全局的請求loading的方法
本篇文章主要介紹了用Axios Element實現(xiàn)全局的請求loading的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-03-03
vue3+vite項目配置ESlint、pritter插件過程
這篇文章主要介紹了vue3+vite項目配置ESlint、pritter插件過程,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08
Vue2.0 http請求以及l(fā)oading展示實例
下面小編就為大家分享一篇Vue2.0 http請求以及l(fā)oading展示實例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-03-03
Vue3+Element?Plus實現(xiàn)動態(tài)標(biāo)簽頁以及右鍵菜單功能
這篇文章主要給大家介紹了關(guān)于Vue3+Element?Plus實現(xiàn)動態(tài)標(biāo)簽頁以及右鍵菜單功能的相關(guān)資料,Vue?3和Element?Plus提供了一種簡單的方法來實現(xiàn)側(cè)邊菜單欄與標(biāo)簽頁之間的聯(lián)動,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-09-09
defineProps宏函數(shù)不需要從vue中import導(dǎo)入的原因解析
這篇文章主要介紹了defineProps宏函數(shù)不需要從vue中import導(dǎo)入的原因解析,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2024-07-07
vite+ts vite.config.ts使用path報錯問題及解決
這篇文章主要介紹了vite+ts vite.config.ts使用path報錯問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10

