预过滤环境光贴图制作教程:第一步 - 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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈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年),论证…