ForwardShading.cpp 3.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485
  1. // Copyright (C) 2009-2021, 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/ForwardShading.h>
  6. #include <AnKi/Renderer/Renderer.h>
  7. #include <AnKi/Renderer/RenderQueue.h>
  8. #include <AnKi/Renderer/GBuffer.h>
  9. #include <AnKi/Renderer/LightShading.h>
  10. #include <AnKi/Renderer/ShadowMapping.h>
  11. #include <AnKi/Renderer/DepthDownscale.h>
  12. #include <AnKi/Renderer/LensFlare.h>
  13. #include <AnKi/Renderer/VolumetricLightingAccumulation.h>
  14. namespace anki
  15. {
  16. ForwardShading::~ForwardShading()
  17. {
  18. }
  19. Error ForwardShading::init(const ConfigSet& cfg)
  20. {
  21. ANKI_R_LOGI("Initializing forward shading");
  22. return Error::NONE;
  23. }
  24. void ForwardShading::run(const RenderingContext& ctx, RenderPassWorkContext& rgraphCtx)
  25. {
  26. CommandBufferPtr& cmdb = rgraphCtx.m_commandBuffer;
  27. const U32 threadId = rgraphCtx.m_currentSecondLevelCommandBufferIndex;
  28. const U32 threadCount = rgraphCtx.m_secondLevelCommandBufferCount;
  29. const U32 problemSize = ctx.m_renderQueue->m_forwardShadingRenderables.getSize();
  30. U32 start, end;
  31. splitThreadedProblem(threadId, threadCount, problemSize, start, end);
  32. if(start != end)
  33. {
  34. cmdb->setDepthWrite(false);
  35. cmdb->setBlendFactors(0, BlendFactor::SRC_ALPHA, BlendFactor::ONE_MINUS_SRC_ALPHA);
  36. const ClusteredShadingContext& rsrc = ctx.m_clusteredShading;
  37. cmdb->bindSampler(0, 0, m_r->getSamplers().m_trilinearClamp);
  38. rgraphCtx.bindTexture(0, 1, m_r->getDepthDownscale().getHiZRt(), HIZ_HALF_DEPTH);
  39. rgraphCtx.bindColorTexture(0, 2, m_r->getVolumetricLightingAccumulation().getRt());
  40. bindUniforms(cmdb, 0, 3, rsrc.m_clusteredShadingUniformsToken);
  41. bindUniforms(cmdb, 0, 4, rsrc.m_pointLightsToken);
  42. bindUniforms(cmdb, 0, 5, rsrc.m_spotLightsToken);
  43. rgraphCtx.bindColorTexture(0, 6, m_r->getShadowMapping().getShadowmapRt());
  44. bindStorage(cmdb, 0, 7, rsrc.m_clustersToken);
  45. // Start drawing
  46. m_r->getSceneDrawer().drawRange(Pass::FS, ctx.m_matrices.m_view, ctx.m_matrices.m_viewProjectionJitter,
  47. ctx.m_prevMatrices.m_viewProjectionJitter, cmdb,
  48. m_r->getSamplers().m_trilinearRepeatAniso,
  49. ctx.m_renderQueue->m_forwardShadingRenderables.getBegin() + start,
  50. ctx.m_renderQueue->m_forwardShadingRenderables.getBegin() + end);
  51. // Restore state
  52. cmdb->setDepthWrite(true);
  53. cmdb->setBlendFactors(0, BlendFactor::ONE, BlendFactor::ZERO);
  54. }
  55. if(threadId == threadCount - 1 && ctx.m_renderQueue->m_lensFlares.getSize())
  56. {
  57. m_r->getLensFlare().runDrawFlares(ctx, cmdb);
  58. }
  59. }
  60. void ForwardShading::setDependencies(const RenderingContext& ctx, GraphicsRenderPassDescription& pass)
  61. {
  62. pass.newDependency({m_r->getDepthDownscale().getHiZRt(), TextureUsageBit::SAMPLED_FRAGMENT, HIZ_HALF_DEPTH});
  63. pass.newDependency({m_r->getDepthDownscale().getHiZRt(), TextureUsageBit::SAMPLED_FRAGMENT, HIZ_QUARTER_DEPTH});
  64. pass.newDependency({m_r->getVolumetricLightingAccumulation().getRt(), TextureUsageBit::SAMPLED_FRAGMENT});
  65. if(ctx.m_renderQueue->m_lensFlares.getSize())
  66. {
  67. pass.newDependency({m_r->getLensFlare().getIndirectDrawBuffer(), BufferUsageBit::INDIRECT_DRAW});
  68. }
  69. }
  70. } // end namespace anki