ForwardShading.cpp 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. // Copyright (C) 2009-2022, 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. #include <AnKi/Shaders/Include/MaterialTypes.h>
  15. namespace anki {
  16. ForwardShading::~ForwardShading()
  17. {
  18. }
  19. void ForwardShading::run(const RenderingContext& ctx, RenderPassWorkContext& rgraphCtx)
  20. {
  21. CommandBufferPtr& cmdb = rgraphCtx.m_commandBuffer;
  22. const U32 threadId = rgraphCtx.m_currentSecondLevelCommandBufferIndex;
  23. const U32 threadCount = rgraphCtx.m_secondLevelCommandBufferCount;
  24. const U32 problemSize = ctx.m_renderQueue->m_forwardShadingRenderables.getSize();
  25. U32 start, end;
  26. splitThreadedProblem(threadId, threadCount, problemSize, start, end);
  27. if(start != end)
  28. {
  29. cmdb->setDepthWrite(false);
  30. cmdb->setBlendFactors(0, BlendFactor::SRC_ALPHA, BlendFactor::ONE_MINUS_SRC_ALPHA);
  31. const ClusteredShadingContext& rsrc = ctx.m_clusteredShading;
  32. const U32 set = MATERIAL_SET_GLOBAL;
  33. cmdb->bindSampler(set, MATERIAL_BINDING_LINEAR_CLAMP_SAMPLER, m_r->getSamplers().m_trilinearClamp);
  34. rgraphCtx.bindTexture(set, MATERIAL_BINDING_DEPTH_RT, m_r->getDepthDownscale().getHiZRt(), HIZ_HALF_DEPTH);
  35. rgraphCtx.bindColorTexture(set, MATERIAL_BINDING_LIGHT_VOLUME,
  36. m_r->getVolumetricLightingAccumulation().getRt());
  37. bindUniforms(cmdb, set, MATERIAL_BINDING_CLUSTER_SHADING_UNIFORMS, rsrc.m_clusteredShadingUniformsToken);
  38. bindUniforms(cmdb, set, MATERIAL_BINDING_CLUSTER_SHADING_LIGHTS, rsrc.m_pointLightsToken);
  39. bindUniforms(cmdb, set, MATERIAL_BINDING_CLUSTER_SHADING_LIGHTS + 1, rsrc.m_spotLightsToken);
  40. rgraphCtx.bindColorTexture(set, MATERIAL_BINDING_CLUSTER_SHADING_LIGHTS + 2,
  41. m_r->getShadowMapping().getShadowmapRt());
  42. bindStorage(cmdb, set, MATERIAL_BINDING_CLUSTERS, rsrc.m_clustersToken);
  43. // Start drawing
  44. m_r->getSceneDrawer().drawRange(RenderingTechnique::FORWARD, ctx.m_matrices.m_view,
  45. ctx.m_matrices.m_viewProjectionJitter,
  46. ctx.m_prevMatrices.m_viewProjectionJitter, cmdb,
  47. m_r->getSamplers().m_trilinearRepeatAnisoResolutionScalingBias,
  48. ctx.m_renderQueue->m_forwardShadingRenderables.getBegin() + start,
  49. ctx.m_renderQueue->m_forwardShadingRenderables.getBegin() + end);
  50. // Restore state
  51. cmdb->setDepthWrite(true);
  52. cmdb->setBlendFactors(0, BlendFactor::ONE, BlendFactor::ZERO);
  53. }
  54. if(threadId == threadCount - 1 && ctx.m_renderQueue->m_lensFlares.getSize())
  55. {
  56. m_r->getLensFlare().runDrawFlares(ctx, cmdb);
  57. }
  58. }
  59. void ForwardShading::setDependencies(const RenderingContext& ctx, GraphicsRenderPassDescription& pass)
  60. {
  61. pass.newDependency({m_r->getDepthDownscale().getHiZRt(), TextureUsageBit::SAMPLED_FRAGMENT, HIZ_HALF_DEPTH});
  62. pass.newDependency({m_r->getVolumetricLightingAccumulation().getRt(), TextureUsageBit::SAMPLED_FRAGMENT});
  63. if(ctx.m_renderQueue->m_lensFlares.getSize())
  64. {
  65. pass.newDependency({m_r->getLensFlare().getIndirectDrawBuffer(), BufferUsageBit::INDIRECT_DRAW});
  66. }
  67. }
  68. } // end namespace anki