一文詳解如何用Three.js和Vue?3實現(xiàn)3D商品展示
一、前言
在現(xiàn)代電商和產(chǎn)品展示中,3D 可視化技術(shù)正變得越來越流行。例如,在購物網(wǎng)站上,用戶可以 360° 旋轉(zhuǎn)商品,查看細節(jié),甚至模擬不同的光照和材質(zhì)效果。這種交互體驗可以極大提升用戶對商品的感知和購買欲望。
本篇文章將帶你使用 Vue 3 + Three.js 構(gòu)建一個 3D 商品展示組件,并支持 縮放、旋轉(zhuǎn)、光照調(diào)整 等功能。
二、Three.js 簡介
Three.js 是一個流行的 WebGL 庫,提供了豐富的 3D 渲染 API,使前端開發(fā)者可以更輕松地在網(wǎng)頁中創(chuàng)建 3D 場景。它的核心概念包括:
- 場景(Scene):3D 物體的容器
- 相機(Camera):決定觀察角度
- 光源(Lights):控制光照效果
- 渲染器(Renderer):渲染 3D 畫面
- 模型(Mesh):3D 物體
三、搭建 Vue 3 + Three.js 項目
3.1 創(chuàng)建 Vue 3 項目并安裝依賴
# 創(chuàng)建 Vue 3 項目 npm create vite@latest vue-3d-viewer --template vue cd vue-3d-viewer # 安裝 Three.js ···l three
3.2 創(chuàng)建ThreeDViewer.vue組件
在 components 目錄下創(chuàng)建 ThreeDViewer.vue,并初始化 Three.js 場景。
// ThreeDViewer.vue
<template>
<div ref="threeContainer" class="three-container"></div>
</template>
<script setup>
import { ref, onMounted } from "vue";
import * as THREE from "three";
const threeContainer = ref(null);
onMounted(() => {
// 創(chuàng)建場景
const scene = new THREE.Scene();
// 創(chuàng)建相機(透視相機)
const camera = new THREE.PerspectiveCamera(75, window.innerWidth / window.innerHeight, 0.1, 1000);
camera.position.set(0, 0, 5); // 設(shè)置相機位置
// 創(chuàng)建渲染器
const renderer = new THREE.WebGLRenderer();
renderer.setSize(window.innerWidth, window.innerHeight);
threeContainer.value.appendChild(renderer.domElement);
// 創(chuàng)建一個立方體
const geometry = new THREE.BoxGeometry();
const material = new THREE.MeshStandardMaterial({ color: 0x0077ff });
const cube = new THREE.Mesh(geometry, material);
scene.add(cube);
// 添加光源
const light = new THREE.AmbientLight(0xffffff, 1);
scene.add(light);
// 渲染循環(huán)
function animate() {
requestAnimationFrame(animate);
cube.rotation.x += 0.01;
cube.rotation.y += 0.01;
renderer.render(scene, camera);
}
animate();
});
</script>
<style>
.three-container {
width: 100%;
height: 100vh;
overflow: hidden;
}
</style>
四、加載 3D 商品模型
4.1 安裝GLTFLoader
Three.js 使用 GLTFLoader 加載 .gltf 或 .glb 格式的 3D 模型。
npm install three/examples/jsm
4.2 加載 GLTF 模型
修改 ThreeDViewer.vue,使用 GLTFLoader 加載 3D 商品模型。
import { GLTFLoader } from "three/examples/jsm/loaders/GLTFLoader.js";
// 加載 3D 商品模型
const loader = new GLTFLoader();
loader.load("/models/product.glb", (gltf) => {
const model = gltf.scene;
model.scale.set(1, 1, 1); // 調(diào)整模型大小
scene.add(model);
});
五、增加交互功能
5.1 旋轉(zhuǎn)和縮放
使用 OrbitControls 實現(xiàn) 鼠標拖拽旋轉(zhuǎn)和縮放。
npm install three-orbitcontrols
5.2 添加OrbitControls
import { OrbitControls } from "three/examples/jsm/controls/OrbitControls.js";
const controls = new OrbitControls(camera, renderer.domElement);
controls.enableDamping = true; // 使旋轉(zhuǎn)更流暢
controls.dampingFactor = 0.05;
controls.screenSpacePanning = false;
controls.minDistance = 1; // 最小縮放距離
controls.maxDistance = 10; // 最大縮放距離
六、添加燈光和陰影
3D 商品的視覺效果很大程度上依賴于 光照,我們可以添加 環(huán)境光 + 聚光燈,增強立體感。
// 添加環(huán)境光
const ambientLight = new THREE.AmbientLight(0xffffff, 0.5);
scene.add(ambientLight);
// 添加聚光燈
const spotLight = new THREE.SpotLight(0xffffff, 1);
spotLight.position.set(5, 5, 5);
scene.add(spotLight);
{javascript}
并開啟陰影:
{javascript}
renderer.shadowMap.enabled = true;
cube.castShadow = true;
cube.receiveShadow = true;
spotLight.castShadow = true;
七、最終效果
至此,我們的 3D 商品展示組件已經(jīng)具備:
? 加載 3D 模型(支持 .glb/.gltf)
? 鼠標旋轉(zhuǎn)縮放(OrbitControls)
? 光照和陰影(環(huán)境光 + 聚光燈)
? 動畫(自動旋轉(zhuǎn))
你可以在 App.vue 中引入并使用:
// App.vue <template> <ThreeDViewer /> </template> <script setup> import ThreeDViewer from "./components/ThreeDViewer.vue"; </script>
八、總結(jié)
本篇文章介紹了如何使用 Vue 3 + Three.js 構(gòu)建一個 3D 商品展示 組件,包括:
- Three.js 基礎(chǔ)(場景、相機、渲染器)
- 加載 3D 商品模型(GLTFLoader)
- 添加交互控制(OrbitControls)
- 優(yōu)化燈光和陰影(增強立體感)
你可以在此基礎(chǔ)上進一步擴展:
- 支持多角度切換(多個攝像機)
- 支持模型變色、換材質(zhì)
- 加入 WebAR 進行增強現(xiàn)實展示
到此這篇關(guān)于如何用Three.js和Vue 3實現(xiàn)3D商品展示的文章就介紹到這了,更多相關(guān)Three.js和Vue3實現(xiàn)3D商品展示內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue 如何添加全局函數(shù)或全局變量以及單頁面的title設(shè)置總結(jié)
本篇文章主要介紹了vue 如何添加全局函數(shù)或全局變量以及單頁面的title設(shè)置總結(jié),非常具有實用價值,需要的朋友可以參考下2017-06-06
vue項目之webpack打包靜態(tài)資源路徑不準確的問題
這篇文章主要介紹了vue項目之webpack打包靜態(tài)資源路徑不準確的問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04
Vue數(shù)據(jù)雙向綁定原理及簡單實現(xiàn)方法
vue數(shù)據(jù)雙向綁定是通過數(shù)據(jù)劫持結(jié)合發(fā)布者-訂閱者模式的方式來實現(xiàn)的.本文重點給大家介紹Vue數(shù)據(jù)雙向綁定原理及簡單實現(xiàn)方法,感興趣的朋友跟隨腳本之家小編一起學習吧2018-05-05

