預過濾環境光貼圖制作教程:第一步 - HDR 轉立方體貼圖

在基于物理的渲染(PBR)中,環境光貼圖是實現真實光照效果的核心組件之一。而將 HDR 全景圖轉換為立方體貼圖,是制作預過濾環境光貼圖的基礎步驟。本教程將詳細講解如何實現這一轉換過程。

什么是 HDR 轉立方體貼圖?

HDR(高動態范圍)全景圖通常以等矩形投影(Equirectangular Projection)的形式存在,看起來像一張橫向拉伸的長方形圖片。而立方體貼圖則由 6 個正方形面組成,分別對應空間中的 ±X、±Y、±Z 六個方向,更適合實時渲染中計算光線反射。

轉換的核心是將等矩形投影上的每個像素,正確映射到立方體貼圖的 6 個面上,同時保持 HDR 數據的完整性。

準備工作

在開始前,請確保你已具備:

  • 基本的 Three.js 知識
  • 一張 HDR 全景圖(.hdr 或.exr 格式)
  • 配置好的 Three.js 環境(包含渲染器、場景、相機)

實現步驟

步驟 1:創建立方體貼圖渲染目標

首先,我們需要創建一個立方體貼圖渲染目標(WebGLCubeRenderTarget),用于存儲轉換后的立方體貼圖數據:

const cubeTarget = new THREE.WebGLCubeRenderTarget(size, {format: THREE.RGBAFormat,  // 使用RGBA格式type: THREE.HalfFloatType,  // 半浮點數類型,平衡精度和性能generateMipmaps: true,      // 生成多級漸遠紋理minFilter: THREE.LinearMipmapLinearFilter,  // 縮小過濾方式magFilter: THREE.LinearFilter,  // 放大過濾方式wrapS: THREE.ClampToEdgeWrapping,  // S軸紋理包裹方式wrapT: THREE.ClampToEdgeWrapping,  // T軸紋理包裹方式flipY: false  // 不翻轉Y軸
});

參數說明:

  • size:立方體貼圖每個面的尺寸(如 256、512)
  • HalfFloatType:保留 HDR 的高動態范圍信息,避免精度損失
  • 過濾方式選擇線性過濾,確保采樣平滑

步驟 2:編寫頂點著色器

頂點著色器的主要作用是傳遞 UV 坐標,并進行適當調整:

varying vec2 vUv0;
uniform vec4 uvMod;
void main() {gl_Position = projectionMatrix * modelViewMatrix * vec4(position, 1.0);// 計算UV坐標,支持縮放和偏移vUv0 =  (position.xy * 0.5 + 0.5) * uvMod.xy + uvMod.zw;
}

  • vUv0: varying 變量,用于向片段著色器傳遞 UV 坐標
  • uvMod:用于調整 UV 的縮放和偏移,增加靈活性

步驟 3:編寫片段著色器(核心邏輯)

片段著色

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/91784.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/91784.shtml
英文地址,請注明出處:http://en.pswp.cn/web/91784.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

02 深度學習介紹【動手學深度學習v2】| 學習筆記

1、intro自然語言處理雖然我們過去取得了很大的進展,但是實際上還是停留在感知層面。計算機視覺領域,因為圖片里面都是像素,像素很難用符號學來解釋,所以計算機視覺大部分是用概率模型或機器學習來做。深度學習它是機器學習的一種…

智能學號抽取系統V5.6.4重磅發布

告別隨機數,擁抱智能點名!—— 全新升級的“智能學號抽取系統V5.6.4”重磅發布! 摘要: 還在為課堂隨機提問、活動抽獎而手動翻名單、查表格而煩惱嗎?還在忍受傳統點名工具的簡陋和不智能嗎?今天&#xff0…

Leetcode-141.環形鏈表

dict和set 1. 結構上的區別:類型鍵(Key)值(Value)示例dict有有{a: 1, b: 2}set有沒有{a, b} dict 是**鍵值對(key-value)**的集合。set 是只有鍵(key)沒有值的一組唯一元…

調節步進電機速度時調PSC和調ARR的區別

在步進電機控制中,調節速度通常是通過改變脈沖頻率實現的。代碼中選擇調節ARR(Auto-Reload Register)而非PSC(Prescaler)的原因如下: 1. ARR 與 PSC 的核心區別 ? ARR(自動重載寄存器&#xff…

在 AKS 中運行 Azure DevOps 私有代理-1

簡介 配置 Azure DevOps 私有代理的傳統方法是將其部署在虛擬機 (VM) 上。然而,一個有趣的替代方案是利用 Azure Kubernetes 服務 (AKS) 來實現此目的。 本文將指導您如何使用 Helm Chart 在 AKS 集群中設置 Azure DevOps 私有代理,并提供該過程的分步說明。 在 AKS 中部署…

C# _Json數據

目錄 1、添加Json庫 2、數據序列化(對象轉 JSON)和反序列化(JSON 轉對象)操作 3、序列化 創建和讀取Json數據 創建Json數據 定義一個CreateJson方法 讀取 解析 Json數據 定義一個ReadJson方法 4、程序運行結果 在 C# 中&…

JavaScript 原始值與引用值

JavaScript 原始值與引用值 ECMAScript變量可以包含兩種不同類型的數據:原始值和引用值。 原始值(primitive value)就是最簡單的數據,引用值(reference value)則是由多個值構成的對象。 保存原始值的變量是…

linux中掛載磁盤和卸載

查找磁盤 找到你想要掛載的磁盤。可以使用lsblk或fdisk -l命令來查看系統中所有的磁盤和分區信息。 lsblk 對數據盤進行分區 在fdisk交互界面里,按以下步驟操作 fdisk /dev/vdb- 輸入n來創建新分區。 - 按照提示設置分區的起始扇區、結束扇區等信息,…

java8學習筆記-Stream流

JDK1.8新增了Stream類,從而把函數式編程的風格引入到Java語言中,Stream類的API提供了強大的功能,使用Stream后,可以寫出更加強大,更加簡潔的代碼首先,Stream流有一些特性:Stream流不是一種數據結…

Flutter開發 dart語言基本語法

特點 Dart語言支持JIT與AOT。 Dart語言采用單線程模型。 Dart語言是強類型編程語言,但是允許弱類型語言式編程。 基本語法 1.變量和常量 變量 var、object、dynamic關鍵字或數據類型顯式聲明變量。 命名規則: 變量名稱必須由數字、字母、下劃線或$組成&a…

SpringBoot:基于 Redis 自定義注解實現后端接口防重復提交校驗(冪等操作)

SpringBoot:基于 Redis 自定義注解實現后端接口防重復提交校驗(冪等操作)可基于 時間間隔 和 用于冪等判斷的參數名稱 實現防重復提交校驗 客戶端發送請求 ↓ [Spring Boot 應用入口]↓ ┌─────────────────────────…

【語音技術】意圖與語料

目錄 1. 意圖 1.1. 意圖分類 1.1.1 入口意圖(Entry Intent) 1.1.2 對話意圖(Dialog Intent) 1.2. 意圖類型切換操作步驟 2. 語料 2.1 語料分類詳解 2.2 語料編寫規范詳解 2.3 標簽符號深度說明 3. 詞槽 3.1 符類型要求 …

【MySQL集群架構與實踐5】使用Docker實現水平分片

目錄 一. 在Docker中安裝ShardingSphere 二. 實踐:水平分片 2.1 應用場景 2.2 架構圖 2.3 服務器規劃 2.4 創建server-user容器 2.5 創建server-order0和server-order1容器 2.6.日志配置 2.7 數據節點配置 2.8.測試數據節點 2.8.1.測試server_order0.t_or…

視覺圖像處理中級篇 [1]—— 彩色照相機的效果與預處理

在工業檢測中,黑白相機雖應用廣泛,但在應對顏色差異檢測時往往力不從心。彩色照相機憑借其對色彩信息的精準捕捉,成為復雜場景下的理想選擇,而預處理技術則進一步釋放了其性能潛力。一、彩色照相機的效果檢查蓋子上的金色標簽可以…

使用 BERT 的 NSP 實現語義感知切片 —— 提升 RAG 系統的檢索質量

在構建 Retrieval-Augmented Generation(RAG)系統時,文檔的切片方式至關重要。我們需要將長文本切分成合適的段落(chunks),然后存入向量數據庫進行召回。如果切得太粗,會丟失上下文細節&#xf…

使用STM32CubeMX生成的STM32CubeIDE工程在更改工程名后編譯失敗問題解決

0 問題描述 使用STM32CubeMX生成STM32CubeIDE工程,然后使用STM32CubeIDE改名后編譯提示如下錯誤: 1 問題原因及解決辦法 1.1 問題原因 原因在于更名后STM32CubeIDE沒有自動更新引用關系,這是因為我們使用STM32CubeMX生成代碼時沒有勾選在根目錄下生成: 取消勾選在根目…

8月3日星期日今日早報簡報微語報早讀

8月3日星期日,農歷閏六月初十,早報#微語早讀。1、廣西防城港:奔馳女司機身份已查清,結果將統一對外發布;2、陳藝文、陳佳包攬游泳世錦賽女子跳水三米板金銀牌;3、九省份保險業已賠付暴雨災害損失5.2億元&am…

wxPython 實踐(六)對話框

wxPython 實踐(一)概述 wxPython 實踐(二)基礎控件 wxPython 實踐(三)頁面布局 wxPython 實踐(四)事件響應 wxPython 實踐(五)高級控件 wxPython 實踐&#x…

MATLAB科研數據可視化技術

互聯網的飛速發展伴隨著海量信息的產生,而海量信息的背后對應的則是海量數據。如何從這些海量數據中獲取有價值的信息來供人們學習和工作使用,這就不得不用到大數據挖掘和分析技術。數據可視化分析作為大數據技術的核心一環,其重要性不言而喻…

文明存續的時間博弈:論地球資源枯竭臨界期的技術突圍與行動緊迫性

摘要當地球資源消耗以指數級速度逼近生態承載力極限,人類文明正面臨“存續還是消亡”的終極抉擇。本文基于地球資源枯竭的實證數據與技術突破的可行性分析,揭示文明存續的時間窗口已進入不可逆臨界期(2040-2070年),論證…