溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

在vue中如何使用three.js

發(fā)布時間:2023-03-01 11:31:36 來源:億速云 閱讀:113 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要講解了“在vue中如何使用three.js”,文中的講解內(nèi)容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“在vue中如何使用three.js”吧!

1.首先安裝three.js、引入

npm install three

在你需要的頁面內(nèi)引入three.js

//import * as THREE from 'three' 
import * as Three from 'three'

前邊這個名字是自己定義的

2.在頁面內(nèi)寫入three.js

首先寫過three.js基礎(chǔ)的要分為幾部分:

01:創(chuàng)建場景

const scene = new THREE.Scene()

02.創(chuàng)建相機

代表著相機:角度、寬高比、近看、遠

const camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 1000)

這代表相機的位置:x y z

camera.position.set(0, 0, 10)

把相機添加到場景中

scene.add(camera)

03.創(chuàng)建一個幾何體

這是一個正方體

const Geometry = new THREE.BoxGeometry(1, 1, 1)

// 幾何體材質(zhì)
const texture = new THREE.MeshBasicMaterial({
  color: 0xffff
})

// 將幾何體和材質(zhì)創(chuàng)建成物體
const mesh = new THREE.Mesh(Geometry, texture)
// 將幾何體添加到場景中
scene.add(mesh)

04.創(chuàng)建渲染器

// 設(shè)置渲染器的大小
render.setSize(window.innerWidth, window.innerHeight)

// 將渲染器添加到頁面 將webgl渲染的canves添加到body
document.body.appendChild(render.domElement)

下邊是把three.js寫入vue2中:

上面介紹了three.js的基礎(chǔ)寫法,下邊是vue2的寫法

01.引入

軌道控制器為了讓模型顯示的更為自然

import * as Three from 'three'
// 導入軌道控制器
import {
  OrbitControls
} from 'three/examples/jsm/controls/OrbitControls'
// import {RGBELoader} from 'three/examples/jsm/loaders/RGBELoader'
let scene = null,
camera=null,
renderer=null,
mesh=null

02.頁面div的承載

<template>
  <div id="container">
   
  </div>
</template>

03.js中獲取div、創(chuàng)建相機場景

我用的是最原始js獲取的,在vue中可以使用ref

let container = document.getElementById('container');

      // 添加相機
      camera = new Three.PerspectiveCamera(70, container.clientWidth/container.clientHeight, 0.01, 1000);
      // 相機的位置
      camera.position.z = 0.1

      // 場景
      scene = new Three.Scene()

04.創(chuàng)建物體

我這里邊創(chuàng)建的是一個比較大的模型,用的貼圖紋理,也可以創(chuàng)建正方體之類的,上面有介紹到

let geometry=new Three.SphereBufferGeometry(5,32,32)
       let a=new Three.TextureLoader().load(`static/image/8.jpg`)
        
      let material = new Three.MeshBasicMaterial({map: a });
      mesh = new Three.Mesh(geometry, material);
  mesh.geometry.scale(1, 1, -1);
  scene.add(mesh);

05.初始化渲染器

 // 初始化渲染器
      renderer = new Three.WebGLRenderer({antialias:true});
      // 渲染器的大小
      renderer.setSize(container.clientWidth,container.clientHeight);
      // 將渲染器添加到頁面
      container.appendChild(renderer.domElement);

06.軌道控制器

 // 創(chuàng)建軌道控制器 相機圍繞模型看到的角度
      const OrbitControl = new OrbitControls(camera, renderer.domElement)
      // 設(shè)置軌道自然
      OrbitControl.enableDamping = true
      // 設(shè)置慣性
      OrbitControl.update()

07.瀏覽器自動渲染

animate(){
      // 瀏覽器自動渲染下一幀
      requestAnimationFrame(this.animate);
     
      // 渲染到頁面
      renderer.render(scene,camera); 
    }

以上是three.js在vue的寫法,是要放到事件里邊的,下面我會吧完整代碼拿出來

遇到的問題:要把圖片放到publice下面

在vue中如何使用three.js

<!--  -->
<template>
  <div id="container">
   
  </div>
</template>

<script>
import * as Three from 'three'
// 導入軌道控制器
import {
  OrbitControls
} from 'three/examples/jsm/controls/OrbitControls'
// import {RGBELoader} from 'three/examples/jsm/loaders/RGBELoader'
let scene = null,
camera=null,
renderer=null,
mesh=null
export default {
  data () {
    return {
        
    };
  },
  methods:{
    init(){
      let container = document.getElementById('container');

      // 添加相機
      camera = new Three.PerspectiveCamera(70, container.clientWidth/container.clientHeight, 0.01, 1000);
      // 相機的位置
      camera.position.z = 0.1

      // 場景
      scene = new Three.Scene()
      // 創(chuàng)建球
      let geometry=new Three.SphereBufferGeometry(5,32,32)
       let a=new Three.TextureLoader().load(`static/image/8.jpg`)
        
      let material = new Three.MeshBasicMaterial({map: a });
      mesh = new Three.Mesh(geometry, material);
  mesh.geometry.scale(1, 1, -1);
  scene.add(mesh);
      
      // 初始化渲染器
      renderer = new Three.WebGLRenderer({antialias:true});
      // 渲染器的大小
      renderer.setSize(container.clientWidth,container.clientHeight);
      // 將渲染器添加到頁面
      container.appendChild(renderer.domElement);



      // 創(chuàng)建軌道控制器 相機圍繞模型看到的角度
      const OrbitControl = new OrbitControls(camera, renderer.domElement)
      // 設(shè)置軌道自然
      OrbitControl.enableDamping = true
      // 設(shè)置慣性
      OrbitControl.update()


    },
    animate(){
      // 瀏覽器自動渲染下一幀
      requestAnimationFrame(this.animate);
     
      // 渲染到頁面
      renderer.render(scene,camera); 
    }
  },
  mounted(){
      this.init()
      this.animate()
  }

}

</script>
<style scoped>
#container{
    width: 100vw;
    height: 100vh;
}
</style>

感謝各位的閱讀,以上就是“在vue中如何使用three.js”的內(nèi)容了,經(jīng)過本文的學習后,相信大家對在vue中如何使用three.js這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關(guān)知識點的文章,歡迎關(guān)注!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI