当前位置: 首页 > news >正文

【URP】Unity[置换贴图]原理与实践

技术原理与解决的问题

‌功能差异‌:

置换贴图通过灰度值控制顶点位移(白色凸起,黑色凹陷),相比法线贴图能产生真实的轮廓阴影和遮挡效果,解决了低模表现高精度几何细节的难题。

‌性能权衡‌:

需要细分曲面(Tessellation)支持,计算开销大于法线贴图,但视觉效果更真实。

曲面细分参看

历史发展节点

‌早期阶段‌:

传统Shader Model 5.0引入硬件细分曲面,Unity通过自定义Shader实现置换效果。

‌URP集成‌:

URP 7.0+原生支持Decal Projector组件,简化了贴花(含置换效果)的投影流程。

Decal Projector 参看

‌优化演进‌:

结合SRP Batcher减少Draw Call,提升实例化渲染效率。

原理示意图:

置换流程:贴图采样 → 顶点偏移 → 细分曲面 → 像素着色

优化链路:SRP Batcher合并材质 → GPU Instancing处理动态实例

URP实现步骤

‌材质配置‌:

创建URP Lit Shader Graph,添加Tessellation和Displacement节点。

连接置换贴图(R通道)到顶点偏移量,调整细分级。

‌组件绑定‌:

创建Decal Projector GameObject

分配置换材质

设置投影范围(Size/Depth)和剔除层级

‌脚本控制‌(可选):

csharp

// 动态修改置换强度

void Update() {

decalProjector.material.SetFloat("_DisplacementScale", intensity);

}

弹孔效果实现

血迹/弹痕‌:通过Decal Projector动态投射到场景物体,结合碰撞检测确定UV坐标。

‌贴图生成‌:

使用Substance Designer或Photoshop绘制灰度图,白色区域表示弹孔凹陷深度。

‌Shader Graph配置‌:

添加Parallax Occlusion Mapping节点模拟深度偏移。

混合置换与法线贴图增强细节。

‌性能优化‌:

启用GPU Instancing减少相同材质的Draw Call。

使用MaterialPropertyBlock动态修改实例属性。

优化参看

置换贴图生成裂缝、岩石凸起

‌地形细节‌:与Terrain系统配合,在运行时置换顶点生成裂缝或岩石凸起。

通过置换贴图动态修改地形顶点生成裂缝/岩石凸起的完整实现方案,结合Terrain系统与Shader Graph。

核心原理

‌置换贴图作用‌:灰度图控制顶点位移(白色凸起,黑色凹陷),需配合曲面细分(Tessellation)增加几何精度

‌URP适配‌:通过Shader Graph的Tessellation节点和Height节点实现硬件细分与顶点偏移

‌地形融合‌:将置换Shader作为Terrain Layer材质,动态影响局部顶点

完整实现步骤

置换贴图生成

‌工具选择‌:使用Substance Designer或Photoshop绘制灰度图(岩石凸起区域为白色,裂缝为黑色)

‌规范要求‌:

分辨率:2048x2048(匹配地形尺寸)

格式:PNG无损压缩

色彩空间:Linear

Shader Graph配置

[Height Map] → [Sample Texture 2D] → [Remap(0-1 to -1-1)]

[Tessellation]节点设置细分级别(Edge:16, Inside:8)

[Parallax Occlusion]节点增强深度感知

混合法线贴图与置换效果

Terrain系统集成

csharp

// C#脚本动态加载置换材质

void ApplyDisplacementToTerrain() {

TerrainLayer layer = new TerrainLayer();

layer.diffuseTexture = rockAlbedo;

layer.normalMapTexture = rockNormal;

layer.maskMapTexture = displacementMap;// 置换贴图

Terrain.activeTerrain.terrainData.terrainLayers = new TerrainLayer[]{ layer };

}

性能优化

‌动态细分‌:根据摄像机距离调整细分因子(UnityDistanceBasedTess)

‌LOD控制‌:超过50米后禁用置换效果

‌批次合并‌:启用SRP Batcher减少Draw Call

动态裂缝生成

‌运行时修改贴图‌:

csharp

// 通过RenderTexture实时绘制裂缝

void UpdateCrackTexture(Vector3 hitPoint) {

Graphics.Blit(crackBrush, displacementRT, displacementMat);

Shader.SetGlobalTexture("_DynamicDisplacement", displacementRT);

}

‌Shader动态采样‌:

hlsl

float height = tex2Dlod(_DynamicDisplacement, float4(uv,0,0)).r;

v.vertex.y += height * _DisplacementScale;

技术对比

方案 优点 缺点 适用场景

法线贴图 性能开销低 无真实几何变形 小范围表面细节

视差遮蔽映射 中等精度遮挡效果 高频细节失真 砖墙/地板接缝

‌置换贴图‌ 真实几何变形 需硬件细分支持 地形/大规模结构变形

调试建议

‌可视化模式‌:启用URP的Depth Normals Pass检查细分效果

‌参数调优‌:

_TessellationEdgeLength:控制细分密度(建议值8-20)

_DisplacementScale:位移强度(建议值0.1-2.0)

http://www.cnnetsun.cn/news/175281.html

相关文章:

  • K3s + Sysbox:让容器拥有“虚拟机的灵魂”
  • 8 个降AI率工具推荐,继续教育学生必备
  • 从开发一个AI美女聊天群组开始
  • 12.2K Star 爆火!开源免费的 FileConverter:右键一键搞定音视频 / 图片 / 文档转换,告别多工具切换
  • Java毕设项目:基于springboot的养宠物指南服务平台系统的设计与实现(源码+文档,讲解、调试运行,定制等)
  • 10 个降AI率工具,继续教育学生高效避坑指南
  • Java毕设项目推荐-基于SpringBoot的演唱会门票在线预定系统的设计与实现基于springboot的演唱会购票系统的设计与实现【附源码+文档,调试定制服务】
  • 升压芯片很简单(一),快速选择升压芯片+利用升压芯片设计LED电源
  • 基于web的人才招聘网站设计 nodejs vue
  • 测试20个降AI率工具后,我找到了2个去ai痕迹效果好的网站,还有免费降AI额度。
  • Thinkphp和Laravel在线点餐系统的设计与实现vue
  • 现代cpp在传统内存分配上的改进
  • Java毕设项目:基于springboot的物业报修系统的设计与实现(源码+文档,讲解、调试运行,定制等)
  • 【计算机毕业设计案例】基于springboot的物业报修系统的设计与实现线上化的报修管理平台(程序+文档+讲解+定制)
  • Java毕设选题推荐:基于springboot的社区团购系统的设计与实现、拼团下单、配送调度、资金结算【附源码、mysql、文档、调试+代码讲解+全bao等】
  • Java计算机毕设之基于springboot的幼儿园管理系统的设计与实现为幼儿园(含普惠园、民办园、连锁园)设计的 “家园共育 + 日常运营 + 安全监管(完整前后端代码+说明文档+LW,调试定制等)
  • I/O多路复用
  • 视频播放器PotPlayer下载安装教程:超详细图文步骤(PC+安卓)
  • Semantic Kernel 实战系列(六) - Memory与向量存储
  • 一个基于 .NET MAUI 的开箱即用的 UI 组件库,可快速搭建面向业务的应用程序界面!
  • Semantic Kernel 实战系列(七) - 高级主题 - Agents 与多代理系统
  • LeetCode每日一题——K个一组翻转链表
  • 大模型后训练:中美路径与商业闭环|附56页PDF文件下载
  • 震惊!选对云服务器代理商,这5个关键指标必须知道!
  • 2025年度复盘与总结
  • ESA正式授予Sivers波束成形技术开发合同
  • 基于UKF-IMM无迹卡尔曼滤波与交互式多模型的轨迹跟踪算法matlab仿真,对比EKF-IMM和UKF
  • Java毕设项目:基于springboot的高校校园一卡通管理系统的设计与实现(源码+文档,讲解、调试运行,定制等)
  • 2025年最实用的3个免费降ai率工具和免费ai查重工具,不用焦虑ai率过高!
  • 计算机Java毕设实战-基于springboot村委办公管理系统 基于SpringBoot的乡村事务综合服务平台的设计与实现【完整源码+LW+部署说明+演示视频,全bao一条龙等】