最近在手机上尝试了一下把SceneColor改成R11G11B10, 使用FrameBufferFetch来读取深度.

Android上可以使用framebuffer_fetch_depth_stencil, 但是iOS上不支持DepthFetch.
所以就尝试使用MRT输出一个R16F的Depth, 需要依赖FramebufferFetchMRT的实现.
4.26中UE4已经增加了延迟渲染, FramebufferFetchMRT已经实现了vk和metal的, 所以很方便地就合并了过来, 用法是这样的:
fetch color : SubpassFetchRGBA_0()/SubpassFetchRGBA_1()/…
fetch float : SubpassFetchR_0()/SubpassFetchR_1()/…
这些宏会在Shader编译时被转换成平台相关的Shader, 然后我感觉我就掉进了一个坑.

代码写完后发现iOS上SubpassFetchR_1()怎么也不起作用(DepthFade的物体没了), 使用XCode GPU Frame Capture看了一下Shader, 结果发现gl_LastFragDataR_1竟然是绑定到了[[color(0)]]上?

继续把HLSL和DXC的代码dump出来, 没有发现问题, [[vk::input_attachment_index(1)]]里面的index是1

本文讲述了在UE4中尝试在iOS上使用FrameBufferFetchMRT进行深度处理时遇到的问题,详细描述了从Android到iOS平台的差异,以及在iOS上SubpassFetchR_1()不起作用的调试过程。通过GPU Frame Capture和对比HLSL与Metal Shader,最终发现问题是由于spirv-cross导致的绑定错误,并通过修改宏定义解决了问题。
最低0.47元/天 解锁文章
944

被折叠的 条评论
为什么被折叠?



