中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

Three.js繪制基礎3D圖形的示例分析

發布時間:2021-05-19 13:45:24 來源:億速云 閱讀:319 作者:小新 欄目:web開發

小編給大家分享一下Three.js繪制基礎3D圖形的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

一、 前言

Three.js 是一款 webGL(3D繪圖標準,在此不贅述)引擎,可以運行于所有支持 webGL 的瀏覽器。Three.js 封裝了 webGL 底層的 API ,為我們提供了高級的開發接口,可以使用簡單的代碼去實現 3D 渲染。(官網:https://threejs.org/)

二、 為什么要選擇Three.js?

Three.js 作為原生 web3D 引擎,對插件式 web3D 引擎的優勢不言而喻:不需要安裝插件、在移動端支持好。

Three.js 與其他原生 web3D 引擎對比:

  • Babylon.js:一個強大的 3D 游戲引擎,由 Microsoft 的員工 David Cathue 主導開發。和 Three.js 相比,three.js 更傾向于動畫,而 Babylon.js 則更適合游戲開發。

  • PhiloGL:增加了額外的功能幫助你可以使用本地的 WebGL ,這個 WebGL 的接口不是百分之百的被封裝好了的,這使得 PhiloGL 上手難度較高。

  • SceneJS:一個開源的 JavaScript 3D 引擎,特別適合需要高精度細節的模型需求,比如工程學和醫學上常用的高精度模型。

  • CopperLicht:一個“商業級別的 WebGL 3D 引擎和編輯器”,你可以免費使用,但是要想獲得未壓縮的完整版帶支持文檔的源碼和其他服務,則需要購買授權。

相對這些 web3D 引擎,Three.js 的還有以下幾點優勢:

  • 開發和維護比較活躍;

  • 文檔齊全,案例豐富,易于學習;

  • 設計靈活、方便拓展以及增加新的特性;

我們可以根據自己的需要去選擇web3D引擎。

三、 開始Three.js

1、 引導

在開始我們的第一個 3D 程序之前,我們需要了解 Three.js 的一些基礎,以下是 Three.js 制作 3D 的五要素:

1、渲染器(render)

我們可以把渲染器想想成為一個畫布,我們需要在這個畫布上去畫出我們需要展示的東西。

2、場景(scene)

相當于一個空間,我們需要將展示的東西放在這個空間里,然后再在畫布上繪制出來。

3、照相機(camera)

相當于眼睛,我們想要看到物體,就需要眼睛去看。

4、光源(light)

物體需要光照才能看見,不然就是漆黑一片(但是在某些情況下展示物體不需要光源)。

5、物體(object)

我們想要表現的內容,會有形狀和材質屬性。

了解了五要素之后,就可以開始寫我們的代碼了。

2、 創建渲染器

首先,我們創建一個渲染器。創建渲染器有兩種方式:

a. 在 html 上寫出 canvas 元素

<canvas id="mainCanvas" width="600px" height="450px" ></canvas>
然后創建渲染器時綁定此元素
var renderer = new THREE.WebGLRenderer({
 canvas: document.getElementById('mainCanvas')
});
renderer.setClearColor(“#000”); // 設置渲染器背景為黑色

b. html 上不創建 canvas 元素,而是使用普通的元素作為容器

<div id="mainCanvas"  ></div>
然后創建渲染器,放入容器中
var canvasContainer = document.getElementById('mainCanvas');
var width = canvasContainer.clientWidth; //獲取畫布的寬
var height = canvasContainer.clientHeight; //獲取畫布的高
var renderer = new THREE.WebGLRenderer({
 antialias: true //抗鋸齒開
});
renderer.setSize(width, height); //設置渲染器的寬和高
renderer.setClearColor(0x000000); //設置渲染器的背景顏色為黑色
var canvas = renderer.domElement; //獲取渲染器的畫布元素
canvasContainer.appendChild(canvas); //將畫布寫入html元素中

這樣,我們的渲染器就創建成功了。創建渲染器時,還可以設置多個屬性,比如抗鋸齒、透明度等等,詳見 three.js 官方文檔。

3、 創建場景

渲染器創建之后,我們再創建場景,準備將我們需要繪制的東西放入場景。

var scene = new THREE.Scene();

4、 創建照相機

照相機常用的有兩種,一種叫正投影相機:

THREE.OrthographicCamera( left, right, top, bottom, near, far );

下圖為該照相機的視野:

Three.js繪制基礎3D圖形的示例分析

一種叫做透視照相機:

THREE.PerspectiveCamera( fov, aspect, near, far ) ;

下圖為該照相機的視野:

Three.js繪制基礎3D圖形的示例分析

下圖為兩個照相機展示效果的對比:

Three.js繪制基礎3D圖形的示例分析

**左邊為正投照相機,遠近大小都一樣;右邊為透視照相機,遠小近大,更接近于人眼觀察物體的感覺。**

在此以正投照相舉例:

var camera = new THREE.OrthographicCamera(-6, 6, 4.5, -4.5, 0, 50); //創建照相機
camera.position.set(35, 15, 25); //設置照相機的位置
camera.lookAt(new THREE.Vector3(0, 0, 0)); //設置照相機面向(0,0,0)坐標觀察

照相機默認坐標為(0,0,0);

默認面向為沿z軸向里觀察;

5、 創建光源

常用光源有:

1、平行光(DirectionalLight),效果類似太陽光

DirectionalLight ( color, intensity )

color — 光源顏色的RBG數值。

intensity — 光強的數值。

2、點光源(PointLight),效果類似燈泡

PointLight ( color, intensity, distance, decay )

color — 光源顏色的RBG數值。

intensity — 光強的數值。

distance -- 光強為0處到光源的距離,0表示無窮大。

decay -- 沿著光照距離的衰退量。

3、聚光光源(SpotLight),效果類似聚光燈

SpotLight ( color, intensity, distance, angle, penumbra, decay )

color — 光源顏色的RBG數值。

intensity — 光強的數值。

distance -- 光強為0處到光源的距離,0表示無窮大。

angle -- 光線散射角度,最大為Math.PI/2。

penumbra -- 聚光錐的半影衰減百分比。在0和1之間的值。默認為0。

decay -- 沿著光照距離的衰退量。

在此以點光源舉例:

var light = new THREE.PointLight(0xffffff, 1, 100); //創建光源
light.position.set(12, 15, 10); //設置光源的位置
scene.add(light); //在場景中添加光源

6、 創建物體

制作物體的方法是 Mesh:

new THREE.Mesh(Geometry, Material);

Geometry 為物體的形狀,Material 為物體的材質;

1、形狀(Geometry)

three.js 給出了很多方法去生成固定的形狀,比如長方體(BoxGeometry)、球體(SphereGeometry)、圓形(CircleGeometry)等等。還有根據坐標去生成具體形狀的方法,可以借助第三方建模軟件建模之后引入,轉換為坐標后再生成,就可以做比較復雜的形狀了,比如人臉、汽車等等。

在此以長方體為例生成形狀:

//設置正方體寬度,高度,深度分別為5,5,5
var geometry = new THREE.BoxGeometry (5, 5, 5);

2、材質(Material)

材質就像是物體的皮膚,決定物體外表的樣子,例如物體的顏色,看起來是否光滑,是否有貼圖等等。

常用材質有:

·網格基礎材質(MeshBasicMaterial)

該材質不受光照的影響,不需要光源即可顯示出來,設置顏色后,各個面都是同一個顏色。

·網格法向材質(MeshNormalMaterial)

該材質不受光照的影響,不需要光源即可顯示出來,并且每個方向的面的顏色都不同,同但一個方向的面顏色是相同的,

該材質一般用于調試。

·網格朗博材質(MeshLambertMaterial)

該材質會受到光照的影響,沒有光源時不會顯示出來,用于創建表面暗淡,不光亮的物體。

·網格 Phong 材質(MeshPhongMaterial)

該材質會受到光照的影響,沒有光源時不會顯示出來,用于創建光亮的物體。

在此以網格 Phong 材質為例創建材質:

var material = new THREE.MeshPhongMaterial({
  color: "yellow" //設置顏色為yellow
});

創建形狀和材質之后,就可以創建該物體了:

//創建物體
var cube = new THREE.Mesh(geometry, material);

7、 渲染畫布

通過以上步驟,我們已經有了渲染器(renderer)、場景(scene)、照相機(camera)、光源(light)和物體(cube),此時我們需要將光源和物體加入場景中:

scene.add(light);
scene.add(cube);

然后再使用渲染器將場景和照相機渲染出來:

renderer.render(scene, camera);

效果如下圖:

Three.js繪制基礎3D圖形的示例分析

四、 結束語

在以上內容中,只寫到了 Three.js 中提供的基礎功能,還有很多高級的功能需要大家去探索。希望大家看完這篇文章后能對 Three.js 有一個初步的了解,并能夠使用 Three.js 繪制出基礎的 3D 圖形。

大家可以去 Three.js 官網的 examples 中看看,這里面都是一些很優秀和典型的 examples,并且還有代碼可以下載,大家可以去研究探索一番。

在此附上幾個精彩的例子供大家欣賞:

Three.js繪制基礎3D圖形的示例分析

Three.js繪制基礎3D圖形的示例分析

Three.js繪制基礎3D圖形的示例分析

以上是“Three.js繪制基礎3D圖形的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

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

AI

章丘市| 龙里县| 修水县| 湟源县| 临汾市| 黑龙江省| 普陀区| 通州市| 阳原县| 锡林郭勒盟| 临汾市| 石林| 雷波县| 临清市| 专栏| 梁平县| 内丘县| 安多县| 诏安县| 仁布县| 昔阳县| 怀仁县| 林甸县| 溧阳市| 饶河县| 鄂温| 丰原市| 昌江| 房山区| 宜君县| 钦州市| 舟山市| 洛浦县| 九龙坡区| 分宜县| 松溪县| 呼图壁县| 简阳市| 漳浦县| 申扎县| 马公市|