GBufferPost.cpp 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. // Copyright (C) 2009-2023, Panagiotis Christopoulos Charitos and contributors.
  2. // All rights reserved.
  3. // Code licensed under the BSD License.
  4. // http://www.anki3d.org/LICENSE
  5. #include <AnKi/Renderer/GBufferPost.h>
  6. #include <AnKi/Renderer/Renderer.h>
  7. #include <AnKi/Renderer/GBuffer.h>
  8. #include <AnKi/Renderer/ClusterBinning.h>
  9. #include <AnKi/Util/Tracer.h>
  10. namespace anki {
  11. Error GBufferPost::init()
  12. {
  13. const Error err = initInternal();
  14. if(err)
  15. {
  16. ANKI_R_LOGE("Failed to initialize GBufferPost pass");
  17. }
  18. return err;
  19. }
  20. Error GBufferPost::initInternal()
  21. {
  22. ANKI_R_LOGV("Initializing GBufferPost pass");
  23. // Load shaders
  24. ANKI_CHECK(ResourceManager::getSingleton().loadResource("ShaderBinaries/GBufferPost.ankiprogbin", m_prog));
  25. ShaderProgramResourceVariantInitInfo variantInitInfo(m_prog);
  26. variantInitInfo.addConstant("kTileCount", getRenderer().getTileCounts());
  27. variantInitInfo.addConstant("kZSplitCount", getRenderer().getZSplitCount());
  28. const ShaderProgramResourceVariant* variant;
  29. m_prog->getOrCreateVariant(variantInitInfo, variant);
  30. m_grProg.reset(&variant->getProgram());
  31. // Create FB descr
  32. m_fbDescr.m_colorAttachmentCount = 2;
  33. m_fbDescr.m_colorAttachments[0].m_loadOperation = AttachmentLoadOperation::kLoad;
  34. m_fbDescr.m_colorAttachments[1].m_loadOperation = AttachmentLoadOperation::kLoad;
  35. m_fbDescr.bake();
  36. return Error::kNone;
  37. }
  38. void GBufferPost::populateRenderGraph(RenderingContext& ctx)
  39. {
  40. ANKI_TRACE_SCOPED_EVENT(GBufferPost);
  41. if(GpuSceneArrays::Decal::getSingleton().getElementCount() == 0)
  42. {
  43. // If there are no decals don't bother
  44. return;
  45. }
  46. RenderGraphDescription& rgraph = ctx.m_renderGraphDescr;
  47. // Create pass
  48. GraphicsRenderPassDescription& rpass = rgraph.newGraphicsRenderPass("GBuffPost");
  49. rpass.setWork([this](RenderPassWorkContext& rgraphCtx) {
  50. CommandBuffer& cmdb = *rgraphCtx.m_commandBuffer;
  51. cmdb.setViewport(0, 0, getRenderer().getInternalResolution().x(), getRenderer().getInternalResolution().y());
  52. cmdb.bindShaderProgram(m_grProg.get());
  53. cmdb.setBlendFactors(0, BlendFactor::kOne, BlendFactor::kSrcAlpha, BlendFactor::kZero, BlendFactor::kOne);
  54. cmdb.setBlendFactors(1, BlendFactor::kOne, BlendFactor::kSrcAlpha, BlendFactor::kZero, BlendFactor::kOne);
  55. // Bind all
  56. cmdb.bindSampler(0, 0, getRenderer().getSamplers().m_nearestNearestClamp.get());
  57. rgraphCtx.bindTexture(0, 1, getRenderer().getGBuffer().getDepthRt(), TextureSubresourceInfo(DepthStencilAspectBit::kDepth));
  58. cmdb.bindSampler(0, 2, getRenderer().getSamplers().m_trilinearRepeat.get());
  59. cmdb.bindConstantBuffer(0, 3, getRenderer().getClusterBinning().getClusteredShadingConstants());
  60. cmdb.bindUavBuffer(0, 4, getRenderer().getClusterBinning().getPackedObjectsBuffer(GpuSceneNonRenderableObjectType::kDecal));
  61. cmdb.bindUavBuffer(0, 5, getRenderer().getClusterBinning().getClustersBuffer());
  62. cmdb.bindAllBindless(1);
  63. // Draw
  64. cmdb.draw(PrimitiveTopology::kTriangles, 3);
  65. // Restore state
  66. cmdb.setBlendFactors(0, BlendFactor::kOne, BlendFactor::kZero);
  67. cmdb.setBlendFactors(1, BlendFactor::kOne, BlendFactor::kZero);
  68. });
  69. rpass.setFramebufferInfo(m_fbDescr, {getRenderer().getGBuffer().getColorRt(0), getRenderer().getGBuffer().getColorRt(1)});
  70. rpass.newTextureDependency(getRenderer().getGBuffer().getColorRt(0), TextureUsageBit::kAllFramebuffer);
  71. rpass.newTextureDependency(getRenderer().getGBuffer().getColorRt(1), TextureUsageBit::kAllFramebuffer);
  72. rpass.newTextureDependency(getRenderer().getGBuffer().getDepthRt(), TextureUsageBit::kSampledFragment,
  73. TextureSubresourceInfo(DepthStencilAspectBit::kDepth));
  74. rpass.newBufferDependency(getRenderer().getClusterBinning().getClustersBufferHandle(), BufferUsageBit::kUavFragmentRead);
  75. rpass.newBufferDependency(getRenderer().getClusterBinning().getPackedObjectsBufferHandle(GpuSceneNonRenderableObjectType::kDecal),
  76. BufferUsageBit::kUavFragmentRead);
  77. }
  78. } // end namespace anki