Mark Ku's Blog
首頁 關於我
React three fiber 實作3D 產品展示筆記
Frontend
React three fiber 實作3D 產品展示筆記
Mark Ku
Mark Ku
October 26, 2023
1 min

時空背景

競爭對手maingear推出 3D Configurator,因此我花了些時間研究了一下3D 技術。

首先,要解決 3D 圖檔格式的問題

從產品設計師要了公司的機殼模型 3D 檔,STEP 拿到的是,因此就開始從網頁常用的格式開始學習起。

說到 3D 產品展示,我們就必須要了解 GLB 和 GLTF 這兩個主流格式的差異 (From ChatGpt)

GLB 和 GLTF 是兩種用於表示 3D 模型的格式,它們主要用於 3D 圖形和虛擬現實。這兩種格式都基於 GL Transmission Format,但它們之間還是存在一些差異:

檔案結構: GLB:這是二進制格式的檔案,所有的資料(包括紋理、網格等)都被儲存在單一的二進制檔案中。這使得檔案較小,載入速度更快。 GLTF:這是 JSON 格式的檔案,可選擇將紋理、網格等儲存在單獨的二進制檔案或是直接嵌入 JSON 中。相對於 GLB,GLTF 檔案結構可能更加靈活但複雜。 可讀性:

GLB:由於是二進制格式,GLB 檔案不容易人工閱讀或編輯。 GLTF:由於是基於 JSON 的,GLTF 檔案較易於閱讀和編輯。開發人員可以用普通的文字編輯器打開和修改。 使用情境:

GLB:適合需要快速載入和高效運行的場景,例如實時 3D 應用。 GLTF:由於其可讀性和靈活性,適合用於開發和調試。 檔案大小:

GLB:通常會比 GLTF 更小,因為它將所有資料打包在一個二進制檔案中。 GLTF:可能會相對較大,特別是當紋理和其他資源被嵌入 JSON 時。 總的來說,GLB 和 GLTF 都具有各自的優點和適用場景。GLB 更適合性能敏感的應用,而 GLTF 則更適合需要可讀性和可編輯性的情境。如果你在開發階段,可能會選擇使用 GLTF 進行迭代和調試,然後在產品階段轉換為 GLB 以提高效能。

因為公司 Soliwork 只有兩套,設計師也很忙,常常麻煩設計師很不好意思,找了幾個工具進行3D 模型的轉換

vectary Oline tool 轉檔需付費,但可以試用幾天

為什麼選擇vectary? 有許多3D轉換工具可以選擇,但我選擇了vectary,因為它具有直觀的界面,並提供了簡單的導入和導出功能。此外,vectary還有豐富的教學資源,幫助我快速上手。透過這個工具,我可以輕鬆將soliwork檔案轉換為網頁支持的格式

blender ( 開源 ) + stepper plugin (付費)

接著,將3D 模型轉換成 react 元件

npm i gltfjsx -g
npx gltfjsx <glTF model source file>

GLB

前面得知產品階段 gltfjsx 會比較好調整,但GLB 會比較小,最終上線 glb 會比較適合,

npm i gltf-pipeline -g
gltf-pipeline -i scene.gltf -o scene.glb 

因為 3D 模型都很大,使用者體驗會很不好,透過 gltf-pipeline 在輸出 Glb 可以設定壓縮等級

gltf-pipeline -i <source file> -o <output file> --draco.compressionLevel=10
gltf-pipeline -i scene.gltf -o mother-board.glb

此時,我們己經拿到製作3D 產品展示所需要的檔案,依據此篇 blog ,我們就可以做出我們的 3d 產品展示

1

進階應用

  • 加入其他電腦組件
  • 風扇轉動
  • 貼圖
  • 變色功能
  • 模型加載時的加載動畫 ( component loading anmiation )
  • 產品特點提示 ( part’s hint )
  • 材質發光 ( bloom 、 emissive )
  • 場景 ( Scene )

除錯小技巧-在 group 挷定點擊事件,可以log 點擊到什麼物件

  <group            
      https://hackmd.io/onPointerMissed={() => (state.current = null)}
      onPointerDown={(e) => (
        e.stopPropagation(), (state.current = e.object.material.name)
      )}
    >

手機加載崩潰

本身手機效能比較不好,從原廠拿來的主機板模型太多細節,太複雜的圖型,很容易加載就崩饋了,每個圓型都是很多三角型組成,都需要3D設計師拓樸,來減少三角形面積,如果未來要做 3D 產品選配,每塊主機板或其他零件,甚至要手動要減少一些細節方面,都需要3D 設計師協助,如果未來要做3D 產品選配,則需要一位獨立或外包的3D 設計師。

3 4

如果你們是 Next js 在本地端除錯是正常,推到生產環境出現這個訊息”next js application error a client-side exception has occurred”,請修改 NEXT.JS config

swcMinify: false,

最後

2 Demo
隨著技術的發展,3D網頁模型線上展示和3D產品選配應用將會越來越廣泛,了解並掌握這些技術於開發者是至關重要的,畢竟,只有跟上時代的腳步,我們才能為客戶提供最好的使用體驗。

僅管目前 Web 3D 仍有些限制,像網路速度跟不上,3D模型太肥大,手機在iOS 某些特效及材質顯示支援度還不夠及手機效能及記憶體較要求,但隨著技術及基礎建設的進步,未來 3D一定可以期待實作更多的應用。

參考資料

幫我將下面連結依據填入

參考資料
參考資料
參考資料
參考資料
參考資料
參考資料
參考資料
參考資料
參考資料
參考資料
參考資料
參考資料
參考資料
參考資料
參考資料
參考資料
參考資料
參考資料
參考資料
參考資料
參考資料
參考資料
參考資料
參考資料
參考資料
參考資料
參考資料
參考資料
參考資料
參考資料


Tags

Mark Ku

Mark Ku

Software Developer

8年以上豐富網站開發經驗,直播系統、POS系統、電子商務、平台網站、SEO、金流串接、DevOps、Infra 出身,帶過幾次團隊,目前專注於北美及德國市場電商網站開發團隊。

Expertise

前端(React)
後端(C#)
網路管理
DevOps
溝通
領導

Social Media

facebook github website

Related Posts

Fixing Three.js Video Texture Issue on iOS 16
Fixing Three.js Video Texture Issue on iOS 16
October 27, 2023
1 min

Quick Links

關於我

Social Media