小程序three.jsobj的簡單介紹

本文目錄一覽:

如何使用Three.js加載obj和mtl文件

使用Three.js加載obj和mtl文件方法:

var onProgress = function(xhr) {

    if (xhr.lengthComputable) {

        var percentComplete = xhr.loaded / xhr.total * 100;

        console.log(Math.round(percentComplete, 2) + ‘% downloaded’);

    }

};

 

var onError = function(xhr) {};

 

THREE.Loader.Handlers.add(/\.dds$/i, new THREE.DDSLoader());

 

var mtlLoader = new THREE.MTLLoader();

mtlLoader.setPath(‘/uploads/160601/obj/’);

mtlLoader.load(‘egg.mtl’, function(materials) {

 

    materials.preload();

 

    var objLoader = new THREE.OBJLoader();

    objLoader.setMaterials(materials);

    objLoader.setPath(‘/uploads/160601/obj/’);

    objLoader.load(‘egg.obj’, function(object) {

 

        object.position.y = -0.5;

        scene.add(object);

 

    }, onProgress, onError);

 

});

ThreeJS渲染一個.obj三維模型文件(Vue)

先來看一個效果:

最近有個項目需要實現三維模型的web端渲染,以前雖然也做過類似的項目,單是兩個項目一個是java Application,一個是安卓結合,兩個我都只參與到的建模環節,所以知道三維模型文件的大概結構,要想在web端實現渲染,首先要做的就是讀取這些模型文件,對裏面的點、面、法線、材質進行逐行解析。

各種對比後,發現了ThreeJS。它不僅可以解析obj模型文件,還可以解析大部分市場上有的模型格式文件。

npm 安裝後,在node_modules/three/examples/jsm/loaders/目錄下可以看到它支持的模型格式。

PS:demo中使用了最流行vue語法。

組件註銷前,解綁全局事件、停止刷新。beforeDestroy()

效果如下:

PS:鼠標移入時,先暫存材質的顏色,移除後再恢復。實現過程有bug,getHex()未得到有效的顏色,所以恢復不到原有的材質顏色,正在查找原因。如有有哪位大神發現問題,請賜教。

優化內容:

2.頁面組件銷毀時,解綁鼠標事件

3.組件銷毀時,清除緩存數據

關於three.js導入obj模型後進行移動的問題

我之前用three.js寫過demo不是很熟,但思路應該是,new 一個 Object3D

然後add(加載的對象)

移動這個整體的對象就行了

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/292031.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-25 14:07
下一篇 2024-12-25 14:07

相關推薦

  • python強行終止程序快捷鍵

    本文將從多個方面對python強行終止程序快捷鍵進行詳細闡述,並提供相應代碼示例。 一、Ctrl+C快捷鍵 Ctrl+C快捷鍵是在終端中經常用來強行終止運行的程序。當你在終端中運行…

    編程 2025-04-29
  • Python程序需要編譯才能執行

    Python 被廣泛應用於數據分析、人工智能、科學計算等領域,它的靈活性和簡單易學的性質使得越來越多的人喜歡使用 Python 進行編程。然而,在 Python 中程序執行的方式不…

    編程 2025-04-29
  • Python程序文件的拓展

    Python是一門功能豐富、易於學習、可讀性高的編程語言。Python程序文件通常以.py為文件拓展名,被廣泛應用於各種領域,包括Web開發、機器學習、科學計算等。為了更好地發揮P…

    編程 2025-04-29
  • Python簡單數學計算

    本文將從多個方面介紹Python的簡單數學計算,包括基礎運算符、函數、庫以及實際應用場景。 一、基礎運算符 Python提供了基礎的算術運算符,包括加(+)、減(-)、乘(*)、除…

    編程 2025-04-29
  • Python滿天星代碼:讓編程變得更加簡單

    本文將從多個方面詳細闡述Python滿天星代碼,為大家介紹它的優點以及如何在編程中使用。無論是剛剛接觸編程還是資深程序員,都能從中獲得一定的收穫。 一、簡介 Python滿天星代碼…

    編程 2025-04-29
  • Python購物車程序

    Python購物車程序是一款基於Python編程語言開發的程序,可以實現購物車的相關功能,包括商品的添加、購買、刪除、統計等。 一、添加商品 添加商品是購物車程序的基礎功能之一,用…

    編程 2025-04-29
  • 爬蟲是一種程序

    爬蟲是一種程序,用於自動獲取互聯網上的信息。本文將從如下多個方面對爬蟲的意義、運行方式、應用場景和技術要點等進行詳細的闡述。 一、爬蟲的意義 1、獲取信息:爬蟲可以自動獲取互聯網上…

    編程 2025-04-29
  • Vb運行程序的三種方法

    VB是一種非常實用的編程工具,它可以被用於開發各種不同的應用程序,從簡單的計算器到更複雜的商業軟件。在VB中,有許多不同的方法可以運行程序,包括編譯器、發佈程序以及命令行。在本文中…

    編程 2025-04-29
  • Python海龜代碼簡單畫圖

    本文將介紹如何使用Python的海龜庫進行簡單畫圖,並提供相關示例代碼。 一、基礎用法 使用Python的海龜庫,我們可以控制一個小海龜在窗口中移動,並利用它的「畫筆」在窗口中繪製…

    編程 2025-04-29
  • Python一元二次方程求解程序

    本文將詳細闡述Python一元二次方程求解程序的相關知識,為讀者提供全面的程序設計思路和操作方法。 一、方程求解 首先,我們需要了解一元二次方程的求解方法。一元二次方程可以寫作: …

    編程 2025-04-29

發表回復

登錄後才能評論