ForwardShading.cpp 3.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. // Copyright (C) 2009-2020, 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 ClusterBinOut& rsrc = ctx.m_clusterBinOut;
  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, ctx.m_lightShadingUniformsToken);
  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. bindStorage(cmdb, 0, 8, rsrc.m_indicesToken);
  46. // Start drawing
  47. m_r->getSceneDrawer().drawRange(Pass::FS, ctx.m_matrices.m_view, ctx.m_matrices.m_viewProjectionJitter,
  48. ctx.m_prevMatrices.m_viewProjectionJitter, cmdb,
  49. m_r->getSamplers().m_trilinearRepeatAniso,
  50. ctx.m_renderQueue->m_forwardShadingRenderables.getBegin() + start,
  51. ctx.m_renderQueue->m_forwardShadingRenderables.getBegin() + end);
  52. // Restore state
  53. cmdb->setDepthWrite(true);
  54. cmdb->setBlendFactors(0, BlendFactor::ONE, BlendFactor::ZERO);
  55. }
  56. if(threadId == threadCount - 1 && ctx.m_renderQueue->m_lensFlares.getSize())
  57. {
  58. m_r->getLensFlare().runDrawFlares(ctx, cmdb);
  59. }
  60. }
  61. void ForwardShading::setDependencies(const RenderingContext& ctx, GraphicsRenderPassDescription& pass)
  62. {
  63. pass.newDependency({m_r->getDepthDownscale().getHiZRt(), TextureUsageBit::SAMPLED_FRAGMENT, HIZ_HALF_DEPTH});
  64. pass.newDependency({m_r->getDepthDownscale().getHiZRt(), TextureUsageBit::SAMPLED_FRAGMENT, HIZ_QUARTER_DEPTH});
  65. pass.newDependency({m_r->getVolumetricLightingAccumulation().getRt(), TextureUsageBit::SAMPLED_FRAGMENT});
  66. if(ctx.m_renderQueue->m_lensFlares.getSize())
  67. {
  68. pass.newDependency({m_r->getLensFlare().getIndirectDrawBuffer(), BufferUsageBit::INDIRECT_DRAW});
  69. }
  70. }
  71. } // end namespace anki