rasterizer_scene_gles3.h 32 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884
  1. /**************************************************************************/
  2. /* rasterizer_scene_gles3.h */
  3. /**************************************************************************/
  4. /* This file is part of: */
  5. /* GODOT ENGINE */
  6. /* https://godotengine.org */
  7. /**************************************************************************/
  8. /* Copyright (c) 2014-present Godot Engine contributors (see AUTHORS.md). */
  9. /* Copyright (c) 2007-2014 Juan Linietsky, Ariel Manzur. */
  10. /* */
  11. /* Permission is hereby granted, free of charge, to any person obtaining */
  12. /* a copy of this software and associated documentation files (the */
  13. /* "Software"), to deal in the Software without restriction, including */
  14. /* without limitation the rights to use, copy, modify, merge, publish, */
  15. /* distribute, sublicense, and/or sell copies of the Software, and to */
  16. /* permit persons to whom the Software is furnished to do so, subject to */
  17. /* the following conditions: */
  18. /* */
  19. /* The above copyright notice and this permission notice shall be */
  20. /* included in all copies or substantial portions of the Software. */
  21. /* */
  22. /* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
  23. /* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
  24. /* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. */
  25. /* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
  26. /* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
  27. /* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
  28. /* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
  29. /**************************************************************************/
  30. #ifndef RASTERIZER_SCENE_GLES3_H
  31. #define RASTERIZER_SCENE_GLES3_H
  32. #ifdef GLES3_ENABLED
  33. #include "core/math/projection.h"
  34. #include "core/templates/paged_allocator.h"
  35. #include "core/templates/rid_owner.h"
  36. #include "core/templates/self_list.h"
  37. #include "drivers/gles3/shaders/effects/cubemap_filter.glsl.gen.h"
  38. #include "drivers/gles3/shaders/sky.glsl.gen.h"
  39. #include "scene/resources/mesh.h"
  40. #include "servers/rendering/renderer_compositor.h"
  41. #include "servers/rendering/renderer_scene_render.h"
  42. #include "servers/rendering_server.h"
  43. #include "shader_gles3.h"
  44. #include "storage/light_storage.h"
  45. #include "storage/material_storage.h"
  46. #include "storage/render_scene_buffers_gles3.h"
  47. #include "storage/utilities.h"
  48. enum RenderListType {
  49. RENDER_LIST_OPAQUE, //used for opaque objects
  50. RENDER_LIST_ALPHA, //used for transparent objects
  51. RENDER_LIST_SECONDARY, //used for shadows and other objects
  52. RENDER_LIST_MAX
  53. };
  54. enum PassMode {
  55. PASS_MODE_COLOR,
  56. PASS_MODE_COLOR_TRANSPARENT,
  57. PASS_MODE_SHADOW,
  58. PASS_MODE_DEPTH,
  59. PASS_MODE_MATERIAL,
  60. };
  61. // These should share as much as possible with SkyUniform Location
  62. enum SceneUniformLocation {
  63. SCENE_TONEMAP_UNIFORM_LOCATION,
  64. SCENE_GLOBALS_UNIFORM_LOCATION,
  65. SCENE_DATA_UNIFORM_LOCATION,
  66. SCENE_MATERIAL_UNIFORM_LOCATION,
  67. SCENE_EMPTY1, // Unused, put here to avoid conflicts with SKY_DIRECTIONAL_LIGHT_UNIFORM_LOCATION.
  68. SCENE_OMNILIGHT_UNIFORM_LOCATION,
  69. SCENE_SPOTLIGHT_UNIFORM_LOCATION,
  70. SCENE_DIRECTIONAL_LIGHT_UNIFORM_LOCATION,
  71. SCENE_MULTIVIEW_UNIFORM_LOCATION,
  72. SCENE_POSITIONAL_SHADOW_UNIFORM_LOCATION,
  73. SCENE_DIRECTIONAL_SHADOW_UNIFORM_LOCATION,
  74. SCENE_EMPTY2, // Unused, put here to avoid conflicts with SKY_MULTIVIEW_UNIFORM_LOCATION.
  75. };
  76. enum SkyUniformLocation {
  77. SKY_TONEMAP_UNIFORM_LOCATION,
  78. SKY_GLOBALS_UNIFORM_LOCATION,
  79. SKY_EMPTY1, // Unused, put here to avoid conflicts with SCENE_DATA_UNIFORM_LOCATION.
  80. SKY_MATERIAL_UNIFORM_LOCATION,
  81. SKY_DIRECTIONAL_LIGHT_UNIFORM_LOCATION,
  82. SKY_EMPTY2, // Unused, put here to avoid conflicts with SCENE_OMNILIGHT_UNIFORM_LOCATION.
  83. SKY_EMPTY3, // Unused, put here to avoid conflicts with SCENE_SPOTLIGHT_UNIFORM_LOCATION.
  84. SKY_EMPTY4, // Unused, put here to avoid conflicts with SCENE_DIRECTIONAL_LIGHT_UNIFORM_LOCATION.
  85. SKY_EMPTY5, // Unused, put here to avoid conflicts with SCENE_MULTIVIEW_UNIFORM_LOCATION.
  86. SKY_EMPTY6, // Unused, put here to avoid conflicts with SCENE_POSITIONAL_SHADOW_UNIFORM_LOCATION.
  87. SKY_EMPTY7, // Unused, put here to avoid conflicts with SCENE_DIRECTIONAL_SHADOW_UNIFORM_LOCATION.
  88. SKY_MULTIVIEW_UNIFORM_LOCATION,
  89. };
  90. struct RenderDataGLES3 {
  91. Ref<RenderSceneBuffersGLES3> render_buffers;
  92. bool transparent_bg = false;
  93. Rect2i render_region;
  94. Transform3D cam_transform;
  95. Transform3D inv_cam_transform;
  96. Projection cam_projection;
  97. bool cam_orthogonal = false;
  98. bool cam_frustum = false;
  99. uint32_t camera_visible_layers = 0xFFFFFFFF;
  100. // For billboards to cast correct shadows.
  101. Transform3D main_cam_transform;
  102. // For stereo rendering
  103. uint32_t view_count = 1;
  104. Vector3 view_eye_offset[RendererSceneRender::MAX_RENDER_VIEWS];
  105. Projection view_projection[RendererSceneRender::MAX_RENDER_VIEWS];
  106. float z_near = 0.0;
  107. float z_far = 0.0;
  108. const PagedArray<RenderGeometryInstance *> *instances = nullptr;
  109. const PagedArray<RID> *lights = nullptr;
  110. const PagedArray<RID> *reflection_probes = nullptr;
  111. RID environment;
  112. RID camera_attributes;
  113. RID shadow_atlas;
  114. RID reflection_probe;
  115. int reflection_probe_pass = 0;
  116. float lod_distance_multiplier = 0.0;
  117. float screen_mesh_lod_threshold = 0.0;
  118. uint32_t directional_light_count = 0;
  119. uint32_t directional_shadow_count = 0;
  120. uint32_t spot_light_count = 0;
  121. uint32_t omni_light_count = 0;
  122. float luminance_multiplier = 1.0;
  123. RenderingMethod::RenderInfo *render_info = nullptr;
  124. /* Shadow data */
  125. const RendererSceneRender::RenderShadowData *render_shadows = nullptr;
  126. int render_shadow_count = 0;
  127. };
  128. class RasterizerCanvasGLES3;
  129. class RasterizerSceneGLES3 : public RendererSceneRender {
  130. private:
  131. static RasterizerSceneGLES3 *singleton;
  132. RS::ViewportDebugDraw debug_draw = RS::VIEWPORT_DEBUG_DRAW_DISABLED;
  133. uint64_t scene_pass = 0;
  134. template <typename T>
  135. struct InstanceSort {
  136. float depth;
  137. T *instance = nullptr;
  138. bool operator<(const InstanceSort &p_sort) const {
  139. return depth < p_sort.depth;
  140. }
  141. };
  142. struct SceneGlobals {
  143. RID shader_default_version;
  144. RID default_material;
  145. RID default_shader;
  146. RID overdraw_material;
  147. RID overdraw_shader;
  148. } scene_globals;
  149. GLES3::SceneMaterialData *default_material_data_ptr = nullptr;
  150. GLES3::SceneMaterialData *overdraw_material_data_ptr = nullptr;
  151. /* LIGHT INSTANCE */
  152. struct LightData {
  153. float position[3];
  154. float inv_radius;
  155. float direction[3]; // Only used by SpotLight
  156. float size;
  157. float color[3];
  158. float attenuation;
  159. float inv_spot_attenuation;
  160. float cos_spot_angle;
  161. float specular_amount;
  162. float shadow_opacity;
  163. float pad[3];
  164. uint32_t bake_mode;
  165. };
  166. static_assert(sizeof(LightData) % 16 == 0, "LightData size must be a multiple of 16 bytes");
  167. struct DirectionalLightData {
  168. float direction[3];
  169. float energy;
  170. float color[3];
  171. float size;
  172. uint32_t enabled; // For use by SkyShaders
  173. uint32_t bake_mode;
  174. float shadow_opacity;
  175. float specular;
  176. };
  177. static_assert(sizeof(DirectionalLightData) % 16 == 0, "DirectionalLightData size must be a multiple of 16 bytes");
  178. struct ShadowData {
  179. float shadow_matrix[16];
  180. float light_position[3];
  181. float shadow_normal_bias;
  182. float pad[3];
  183. float shadow_atlas_pixel_size;
  184. };
  185. static_assert(sizeof(ShadowData) % 16 == 0, "ShadowData size must be a multiple of 16 bytes");
  186. struct DirectionalShadowData {
  187. float direction[3];
  188. float shadow_atlas_pixel_size;
  189. float shadow_normal_bias[4];
  190. float shadow_split_offsets[4];
  191. float shadow_matrices[4][16];
  192. float fade_from;
  193. float fade_to;
  194. uint32_t blend_splits; // Not exposed to the shader.
  195. uint32_t pad;
  196. };
  197. static_assert(sizeof(DirectionalShadowData) % 16 == 0, "DirectionalShadowData size must be a multiple of 16 bytes");
  198. class GeometryInstanceGLES3;
  199. // Cached data for drawing surfaces
  200. struct GeometryInstanceSurface {
  201. enum {
  202. FLAG_PASS_DEPTH = 1,
  203. FLAG_PASS_OPAQUE = 2,
  204. FLAG_PASS_ALPHA = 4,
  205. FLAG_PASS_SHADOW = 8,
  206. FLAG_USES_SHARED_SHADOW_MATERIAL = 128,
  207. FLAG_USES_SCREEN_TEXTURE = 2048,
  208. FLAG_USES_DEPTH_TEXTURE = 4096,
  209. FLAG_USES_NORMAL_TEXTURE = 8192,
  210. FLAG_USES_DOUBLE_SIDED_SHADOWS = 16384,
  211. };
  212. union {
  213. struct {
  214. uint64_t sort_key1;
  215. uint64_t sort_key2;
  216. };
  217. struct {
  218. uint64_t lod_index : 8;
  219. uint64_t surface_index : 8;
  220. uint64_t geometry_id : 32;
  221. uint64_t material_id_low : 16;
  222. uint64_t material_id_hi : 16;
  223. uint64_t shader_id : 32;
  224. uint64_t uses_softshadow : 1;
  225. uint64_t uses_projector : 1;
  226. uint64_t uses_forward_gi : 1;
  227. uint64_t uses_lightmap : 1;
  228. uint64_t depth_layer : 4;
  229. uint64_t priority : 8;
  230. };
  231. } sort;
  232. RS::PrimitiveType primitive = RS::PRIMITIVE_MAX;
  233. uint32_t flags = 0;
  234. uint32_t surface_index = 0;
  235. uint32_t lod_index = 0;
  236. uint32_t index_count = 0;
  237. int32_t light_pass_index = -1;
  238. bool finished_base_pass = false;
  239. void *surface = nullptr;
  240. GLES3::SceneShaderData *shader = nullptr;
  241. GLES3::SceneMaterialData *material = nullptr;
  242. void *surface_shadow = nullptr;
  243. GLES3::SceneShaderData *shader_shadow = nullptr;
  244. GLES3::SceneMaterialData *material_shadow = nullptr;
  245. GeometryInstanceSurface *next = nullptr;
  246. GeometryInstanceGLES3 *owner = nullptr;
  247. };
  248. struct GeometryInstanceLightmapSH {
  249. Color sh[9];
  250. };
  251. class GeometryInstanceGLES3 : public RenderGeometryInstanceBase {
  252. public:
  253. //used during rendering
  254. bool store_transform_cache = true;
  255. int32_t instance_count = 0;
  256. bool can_sdfgi = false;
  257. bool using_projectors = false;
  258. bool using_softshadows = false;
  259. struct LightPass {
  260. int32_t light_id = -1; // Position in the light uniform buffer.
  261. int32_t shadow_id = -1; // Position in the shadow uniform buffer.
  262. RID light_instance_rid;
  263. bool is_omni = false;
  264. };
  265. LocalVector<LightPass> light_passes;
  266. uint32_t paired_omni_light_count = 0;
  267. uint32_t paired_spot_light_count = 0;
  268. LocalVector<RID> paired_omni_lights;
  269. LocalVector<RID> paired_spot_lights;
  270. LocalVector<uint32_t> omni_light_gl_cache;
  271. LocalVector<uint32_t> spot_light_gl_cache;
  272. LocalVector<RID> paired_reflection_probes;
  273. LocalVector<RID> reflection_probe_rid_cache;
  274. LocalVector<Transform3D> reflection_probes_local_transform_cache;
  275. RID lightmap_instance;
  276. Rect2 lightmap_uv_scale;
  277. uint32_t lightmap_slice_index;
  278. GeometryInstanceLightmapSH *lightmap_sh = nullptr;
  279. // Used during setup.
  280. GeometryInstanceSurface *surface_caches = nullptr;
  281. SelfList<GeometryInstanceGLES3> dirty_list_element;
  282. GeometryInstanceGLES3() :
  283. dirty_list_element(this) {}
  284. virtual void _mark_dirty() override;
  285. virtual void set_use_lightmap(RID p_lightmap_instance, const Rect2 &p_lightmap_uv_scale, int p_lightmap_slice_index) override;
  286. virtual void set_lightmap_capture(const Color *p_sh9) override;
  287. virtual void pair_light_instances(const RID *p_light_instances, uint32_t p_light_instance_count) override;
  288. virtual void pair_reflection_probe_instances(const RID *p_reflection_probe_instances, uint32_t p_reflection_probe_instance_count) override;
  289. virtual void pair_decal_instances(const RID *p_decal_instances, uint32_t p_decal_instance_count) override {}
  290. virtual void pair_voxel_gi_instances(const RID *p_voxel_gi_instances, uint32_t p_voxel_gi_instance_count) override {}
  291. virtual void set_softshadow_projector_pairing(bool p_softshadow, bool p_projector) override {}
  292. };
  293. enum {
  294. INSTANCE_DATA_FLAGS_DYNAMIC = 1 << 3,
  295. INSTANCE_DATA_FLAGS_NON_UNIFORM_SCALE = 1 << 4,
  296. INSTANCE_DATA_FLAG_USE_GI_BUFFERS = 1 << 5,
  297. INSTANCE_DATA_FLAG_USE_LIGHTMAP_CAPTURE = 1 << 7,
  298. INSTANCE_DATA_FLAG_USE_LIGHTMAP = 1 << 8,
  299. INSTANCE_DATA_FLAG_USE_SH_LIGHTMAP = 1 << 9,
  300. INSTANCE_DATA_FLAG_USE_VOXEL_GI = 1 << 10,
  301. INSTANCE_DATA_FLAG_PARTICLES = 1 << 11,
  302. INSTANCE_DATA_FLAG_MULTIMESH = 1 << 12,
  303. INSTANCE_DATA_FLAG_MULTIMESH_FORMAT_2D = 1 << 13,
  304. INSTANCE_DATA_FLAG_MULTIMESH_HAS_COLOR = 1 << 14,
  305. INSTANCE_DATA_FLAG_MULTIMESH_HAS_CUSTOM_DATA = 1 << 15,
  306. };
  307. static void _geometry_instance_dependency_changed(Dependency::DependencyChangedNotification p_notification, DependencyTracker *p_tracker);
  308. static void _geometry_instance_dependency_deleted(const RID &p_dependency, DependencyTracker *p_tracker);
  309. SelfList<GeometryInstanceGLES3>::List geometry_instance_dirty_list;
  310. // Use PagedAllocator instead of RID to maximize performance
  311. PagedAllocator<GeometryInstanceGLES3> geometry_instance_alloc;
  312. PagedAllocator<GeometryInstanceSurface> geometry_instance_surface_alloc;
  313. void _geometry_instance_add_surface_with_material(GeometryInstanceGLES3 *ginstance, uint32_t p_surface, GLES3::SceneMaterialData *p_material, uint32_t p_material_id, uint32_t p_shader_id, RID p_mesh);
  314. void _geometry_instance_add_surface_with_material_chain(GeometryInstanceGLES3 *ginstance, uint32_t p_surface, GLES3::SceneMaterialData *p_material, RID p_mat_src, RID p_mesh);
  315. void _geometry_instance_add_surface(GeometryInstanceGLES3 *ginstance, uint32_t p_surface, RID p_material, RID p_mesh);
  316. void _geometry_instance_update(RenderGeometryInstance *p_geometry_instance);
  317. void _update_dirty_geometry_instances();
  318. struct SceneState {
  319. struct UBO {
  320. float projection_matrix[16];
  321. float inv_projection_matrix[16];
  322. float inv_view_matrix[16];
  323. float view_matrix[16];
  324. float main_cam_inv_view_matrix[16];
  325. float viewport_size[2];
  326. float screen_pixel_size[2];
  327. float ambient_light_color_energy[4];
  328. float ambient_color_sky_mix;
  329. uint32_t pad2;
  330. float emissive_exposure_normalization;
  331. uint32_t use_ambient_light = 0;
  332. uint32_t use_ambient_cubemap = 0;
  333. uint32_t use_reflection_cubemap = 0;
  334. float fog_aerial_perspective;
  335. float time;
  336. float radiance_inverse_xform[12];
  337. uint32_t directional_light_count;
  338. float z_far;
  339. float z_near;
  340. float IBL_exposure_normalization;
  341. uint32_t fog_enabled;
  342. uint32_t fog_mode;
  343. float fog_density;
  344. float fog_height;
  345. float fog_height_density;
  346. float fog_depth_curve;
  347. float fog_sun_scatter;
  348. float fog_depth_begin;
  349. float fog_light_color[3];
  350. float fog_depth_end;
  351. float shadow_bias;
  352. float luminance_multiplier;
  353. uint32_t camera_visible_layers;
  354. bool pancake_shadows;
  355. };
  356. static_assert(sizeof(UBO) % 16 == 0, "Scene UBO size must be a multiple of 16 bytes");
  357. static_assert(sizeof(UBO) < 16384, "Scene UBO size must be 16384 bytes or smaller");
  358. struct MultiviewUBO {
  359. float projection_matrix_view[RendererSceneRender::MAX_RENDER_VIEWS][16];
  360. float inv_projection_matrix_view[RendererSceneRender::MAX_RENDER_VIEWS][16];
  361. float eye_offset[RendererSceneRender::MAX_RENDER_VIEWS][4];
  362. };
  363. static_assert(sizeof(MultiviewUBO) % 16 == 0, "Multiview UBO size must be a multiple of 16 bytes");
  364. static_assert(sizeof(MultiviewUBO) < 16384, "MultiviewUBO size must be 16384 bytes or smaller");
  365. struct TonemapUBO {
  366. float exposure = 1.0;
  367. float white = 1.0;
  368. int32_t tonemapper = 0;
  369. int32_t pad = 0;
  370. int32_t pad2 = 0;
  371. float brightness = 1.0;
  372. float contrast = 1.0;
  373. float saturation = 1.0;
  374. };
  375. static_assert(sizeof(TonemapUBO) % 16 == 0, "Tonemap UBO size must be a multiple of 16 bytes");
  376. UBO ubo;
  377. GLuint ubo_buffer = 0;
  378. MultiviewUBO multiview_ubo;
  379. GLuint multiview_buffer = 0;
  380. GLuint tonemap_buffer = 0;
  381. bool used_depth_prepass = false;
  382. GLES3::SceneShaderData::BlendMode current_blend_mode = GLES3::SceneShaderData::BLEND_MODE_MIX;
  383. RS::CullMode cull_mode = RS::CULL_MODE_BACK;
  384. bool current_blend_enabled = false;
  385. bool current_depth_draw_enabled = false;
  386. bool current_depth_test_enabled = false;
  387. bool current_scissor_test_enabled = false;
  388. void reset_gl_state() {
  389. glDisable(GL_BLEND);
  390. current_blend_enabled = false;
  391. glDisable(GL_SCISSOR_TEST);
  392. current_scissor_test_enabled = false;
  393. glCullFace(GL_BACK);
  394. glEnable(GL_CULL_FACE);
  395. cull_mode = RS::CULL_MODE_BACK;
  396. glDepthMask(GL_FALSE);
  397. current_depth_draw_enabled = false;
  398. glDisable(GL_DEPTH_TEST);
  399. current_depth_test_enabled = false;
  400. }
  401. void set_gl_cull_mode(RS::CullMode p_mode) {
  402. if (cull_mode != p_mode) {
  403. if (p_mode == RS::CULL_MODE_DISABLED) {
  404. glDisable(GL_CULL_FACE);
  405. } else {
  406. if (cull_mode == RS::CULL_MODE_DISABLED) {
  407. // Last time was disabled, so enable and set proper face.
  408. glEnable(GL_CULL_FACE);
  409. }
  410. glCullFace(p_mode == RS::CULL_MODE_FRONT ? GL_FRONT : GL_BACK);
  411. }
  412. cull_mode = p_mode;
  413. }
  414. }
  415. void enable_gl_blend(bool p_enabled) {
  416. if (current_blend_enabled != p_enabled) {
  417. if (p_enabled) {
  418. glEnable(GL_BLEND);
  419. } else {
  420. glDisable(GL_BLEND);
  421. }
  422. current_blend_enabled = p_enabled;
  423. }
  424. }
  425. void enable_gl_scissor_test(bool p_enabled) {
  426. if (current_scissor_test_enabled != p_enabled) {
  427. if (p_enabled) {
  428. glEnable(GL_SCISSOR_TEST);
  429. } else {
  430. glDisable(GL_SCISSOR_TEST);
  431. }
  432. current_scissor_test_enabled = p_enabled;
  433. }
  434. }
  435. void enable_gl_depth_draw(bool p_enabled) {
  436. if (current_depth_draw_enabled != p_enabled) {
  437. glDepthMask(p_enabled ? GL_TRUE : GL_FALSE);
  438. current_depth_draw_enabled = p_enabled;
  439. }
  440. }
  441. void enable_gl_depth_test(bool p_enabled) {
  442. if (current_depth_test_enabled != p_enabled) {
  443. if (p_enabled) {
  444. glEnable(GL_DEPTH_TEST);
  445. } else {
  446. glDisable(GL_DEPTH_TEST);
  447. }
  448. current_depth_test_enabled = p_enabled;
  449. }
  450. }
  451. bool texscreen_copied = false;
  452. bool used_screen_texture = false;
  453. bool used_normal_texture = false;
  454. bool used_depth_texture = false;
  455. LightData *omni_lights = nullptr;
  456. LightData *spot_lights = nullptr;
  457. ShadowData *positional_shadows = nullptr;
  458. InstanceSort<GLES3::LightInstance> *omni_light_sort;
  459. InstanceSort<GLES3::LightInstance> *spot_light_sort;
  460. GLuint omni_light_buffer = 0;
  461. GLuint spot_light_buffer = 0;
  462. GLuint positional_shadow_buffer = 0;
  463. uint32_t omni_light_count = 0;
  464. uint32_t spot_light_count = 0;
  465. RS::ShadowQuality positional_shadow_quality = RS::ShadowQuality::SHADOW_QUALITY_SOFT_LOW;
  466. DirectionalLightData *directional_lights = nullptr;
  467. GLuint directional_light_buffer = 0;
  468. DirectionalShadowData *directional_shadows = nullptr;
  469. GLuint directional_shadow_buffer = 0;
  470. RS::ShadowQuality directional_shadow_quality = RS::ShadowQuality::SHADOW_QUALITY_SOFT_LOW;
  471. } scene_state;
  472. struct RenderListParameters {
  473. GeometryInstanceSurface **elements = nullptr;
  474. int element_count = 0;
  475. bool reverse_cull = false;
  476. uint64_t spec_constant_base_flags = 0;
  477. bool force_wireframe = false;
  478. Vector2 uv_offset = Vector2(0, 0);
  479. RenderListParameters(GeometryInstanceSurface **p_elements, int p_element_count, bool p_reverse_cull, uint64_t p_spec_constant_base_flags, bool p_force_wireframe = false, Vector2 p_uv_offset = Vector2()) {
  480. elements = p_elements;
  481. element_count = p_element_count;
  482. reverse_cull = p_reverse_cull;
  483. spec_constant_base_flags = p_spec_constant_base_flags;
  484. force_wireframe = p_force_wireframe;
  485. uv_offset = p_uv_offset;
  486. }
  487. };
  488. struct RenderList {
  489. LocalVector<GeometryInstanceSurface *> elements;
  490. void clear() {
  491. elements.clear();
  492. }
  493. //should eventually be replaced by radix
  494. struct SortByKey {
  495. _FORCE_INLINE_ bool operator()(const GeometryInstanceSurface *A, const GeometryInstanceSurface *B) const {
  496. return (A->sort.sort_key2 == B->sort.sort_key2) ? (A->sort.sort_key1 < B->sort.sort_key1) : (A->sort.sort_key2 < B->sort.sort_key2);
  497. }
  498. };
  499. void sort_by_key() {
  500. SortArray<GeometryInstanceSurface *, SortByKey> sorter;
  501. sorter.sort(elements.ptr(), elements.size());
  502. }
  503. void sort_by_key_range(uint32_t p_from, uint32_t p_size) {
  504. SortArray<GeometryInstanceSurface *, SortByKey> sorter;
  505. sorter.sort(elements.ptr() + p_from, p_size);
  506. }
  507. struct SortByDepth {
  508. _FORCE_INLINE_ bool operator()(const GeometryInstanceSurface *A, const GeometryInstanceSurface *B) const {
  509. return (A->owner->depth < B->owner->depth);
  510. }
  511. };
  512. void sort_by_depth() { //used for shadows
  513. SortArray<GeometryInstanceSurface *, SortByDepth> sorter;
  514. sorter.sort(elements.ptr(), elements.size());
  515. }
  516. struct SortByReverseDepthAndPriority {
  517. _FORCE_INLINE_ bool operator()(const GeometryInstanceSurface *A, const GeometryInstanceSurface *B) const {
  518. return (A->sort.priority == B->sort.priority) ? (A->owner->depth > B->owner->depth) : (A->sort.priority < B->sort.priority);
  519. }
  520. };
  521. void sort_by_reverse_depth_and_priority() { //used for alpha
  522. SortArray<GeometryInstanceSurface *, SortByReverseDepthAndPriority> sorter;
  523. sorter.sort(elements.ptr(), elements.size());
  524. }
  525. _FORCE_INLINE_ void add_element(GeometryInstanceSurface *p_element) {
  526. elements.push_back(p_element);
  527. }
  528. };
  529. RenderList render_list[RENDER_LIST_MAX];
  530. void _setup_lights(const RenderDataGLES3 *p_render_data, bool p_using_shadows, uint32_t &r_directional_light_count, uint32_t &r_omni_light_count, uint32_t &r_spot_light_count, uint32_t &r_directional_shadow_count);
  531. void _setup_environment(const RenderDataGLES3 *p_render_data, bool p_no_fog, const Size2i &p_screen_size, bool p_flip_y, const Color &p_default_bg_color, bool p_pancake_shadows, float p_shadow_bias = 0.0);
  532. void _fill_render_list(RenderListType p_render_list, const RenderDataGLES3 *p_render_data, PassMode p_pass_mode, bool p_append = false);
  533. void _render_shadows(const RenderDataGLES3 *p_render_data, const Size2i &p_viewport_size = Size2i(1, 1));
  534. void _render_shadow_pass(RID p_light, RID p_shadow_atlas, int p_pass, const PagedArray<RenderGeometryInstance *> &p_instances, float p_lod_distance_multiplier = 0, float p_screen_mesh_lod_threshold = 0.0, RenderingMethod::RenderInfo *p_render_info = nullptr, const Size2i &p_viewport_size = Size2i(1, 1), const Transform3D &p_main_cam_transform = Transform3D());
  535. void _render_post_processing(const RenderDataGLES3 *p_render_data);
  536. template <PassMode p_pass_mode>
  537. _FORCE_INLINE_ void _render_list_template(RenderListParameters *p_params, const RenderDataGLES3 *p_render_data, uint32_t p_from_element, uint32_t p_to_element, bool p_alpha_pass = false);
  538. protected:
  539. double time;
  540. double time_step = 0;
  541. bool screen_space_roughness_limiter = false;
  542. float screen_space_roughness_limiter_amount = 0.25;
  543. float screen_space_roughness_limiter_limit = 0.18;
  544. void _render_buffers_debug_draw(Ref<RenderSceneBuffersGLES3> p_render_buffers, RID p_shadow_atlas, GLuint p_fbo);
  545. /* Camera Attributes */
  546. struct CameraAttributes {
  547. float exposure_multiplier = 1.0;
  548. float exposure_normalization = 1.0;
  549. };
  550. bool use_physical_light_units = false;
  551. mutable RID_Owner<CameraAttributes, true> camera_attributes_owner;
  552. /* Environment */
  553. RS::EnvironmentSSAOQuality ssao_quality = RS::ENV_SSAO_QUALITY_MEDIUM;
  554. bool ssao_half_size = false;
  555. float ssao_adaptive_target = 0.5;
  556. int ssao_blur_passes = 2;
  557. float ssao_fadeout_from = 50.0;
  558. float ssao_fadeout_to = 300.0;
  559. bool glow_bicubic_upscale = false;
  560. RS::EnvironmentSSRRoughnessQuality ssr_roughness_quality = RS::ENV_SSR_ROUGHNESS_QUALITY_LOW;
  561. bool lightmap_bicubic_upscale = false;
  562. /* Sky */
  563. struct SkyGlobals {
  564. float fog_aerial_perspective = 0.0;
  565. Color fog_light_color;
  566. float fog_sun_scatter = 0.0;
  567. bool fog_enabled = false;
  568. float fog_density = 0.0;
  569. float z_far = 0.0;
  570. uint32_t directional_light_count = 0;
  571. DirectionalLightData *directional_lights = nullptr;
  572. DirectionalLightData *last_frame_directional_lights = nullptr;
  573. uint32_t last_frame_directional_light_count = 0;
  574. GLuint directional_light_buffer = 0;
  575. RID shader_default_version;
  576. RID default_material;
  577. RID default_shader;
  578. RID fog_material;
  579. RID fog_shader;
  580. GLuint screen_triangle = 0;
  581. GLuint screen_triangle_array = 0;
  582. uint32_t max_directional_lights = 4;
  583. uint32_t roughness_layers = 8;
  584. } sky_globals;
  585. struct Sky {
  586. // Screen Buffers
  587. GLuint half_res_pass = 0;
  588. GLuint half_res_framebuffer = 0;
  589. GLuint quarter_res_pass = 0;
  590. GLuint quarter_res_framebuffer = 0;
  591. Size2i screen_size = Size2i(0, 0);
  592. // Radiance Cubemap
  593. GLuint radiance = 0;
  594. GLuint radiance_framebuffer = 0;
  595. GLuint raw_radiance = 0;
  596. RID material;
  597. GLuint uniform_buffer;
  598. int radiance_size = 256;
  599. int mipmap_count = 1;
  600. RS::SkyMode mode = RS::SKY_MODE_AUTOMATIC;
  601. //ReflectionData reflection;
  602. bool reflection_dirty = false;
  603. bool dirty = false;
  604. int processing_layer = 0;
  605. Sky *dirty_list = nullptr;
  606. float baked_exposure = 1.0;
  607. //State to track when radiance cubemap needs updating
  608. GLES3::SkyMaterialData *prev_material;
  609. Vector3 prev_position = Vector3(0.0, 0.0, 0.0);
  610. float prev_time = 0.0f;
  611. };
  612. Sky *dirty_sky_list = nullptr;
  613. mutable RID_Owner<Sky, true> sky_owner;
  614. void _setup_sky(const RenderDataGLES3 *p_render_data, const PagedArray<RID> &p_lights, const Projection &p_projection, const Transform3D &p_transform, const Size2i p_screen_size);
  615. void _invalidate_sky(Sky *p_sky);
  616. void _update_dirty_skys();
  617. void _update_sky_radiance(RID p_env, const Projection &p_projection, const Transform3D &p_transform, float p_sky_energy_multiplier);
  618. void _draw_sky(RID p_env, const Projection &p_projection, const Transform3D &p_transform, float p_sky_energy_multiplier, float p_luminance_multiplier, bool p_use_multiview, bool p_flip_y, bool p_apply_color_adjustments_in_post);
  619. void _free_sky_data(Sky *p_sky);
  620. // Needed for a single argument calls (material and uv2).
  621. PagedArrayPool<RenderGeometryInstance *> cull_argument_pool;
  622. PagedArray<RenderGeometryInstance *> cull_argument;
  623. public:
  624. static RasterizerSceneGLES3 *get_singleton() { return singleton; }
  625. RasterizerCanvasGLES3 *canvas = nullptr;
  626. RenderGeometryInstance *geometry_instance_create(RID p_base) override;
  627. void geometry_instance_free(RenderGeometryInstance *p_geometry_instance) override;
  628. uint32_t geometry_instance_get_pair_mask() override;
  629. /* PIPELINES */
  630. virtual void mesh_generate_pipelines(RID p_mesh, bool p_background_compilation) override {}
  631. virtual uint32_t get_pipeline_compilations(RS::PipelineSource p_source) override { return 0; }
  632. /* SDFGI UPDATE */
  633. void sdfgi_update(const Ref<RenderSceneBuffers> &p_render_buffers, RID p_environment, const Vector3 &p_world_position) override {}
  634. int sdfgi_get_pending_region_count(const Ref<RenderSceneBuffers> &p_render_buffers) const override {
  635. return 0;
  636. }
  637. AABB sdfgi_get_pending_region_bounds(const Ref<RenderSceneBuffers> &p_render_buffers, int p_region) const override {
  638. return AABB();
  639. }
  640. uint32_t sdfgi_get_pending_region_cascade(const Ref<RenderSceneBuffers> &p_render_buffers, int p_region) const override {
  641. return 0;
  642. }
  643. /* SKY API */
  644. RID sky_allocate() override;
  645. void sky_initialize(RID p_rid) override;
  646. void sky_set_radiance_size(RID p_sky, int p_radiance_size) override;
  647. void sky_set_mode(RID p_sky, RS::SkyMode p_mode) override;
  648. void sky_set_material(RID p_sky, RID p_material) override;
  649. Ref<Image> sky_bake_panorama(RID p_sky, float p_energy, bool p_bake_irradiance, const Size2i &p_size) override;
  650. float sky_get_baked_exposure(RID p_sky) const;
  651. /* ENVIRONMENT API */
  652. void environment_glow_set_use_bicubic_upscale(bool p_enable) override;
  653. void environment_set_ssr_roughness_quality(RS::EnvironmentSSRRoughnessQuality p_quality) override;
  654. void environment_set_ssao_quality(RS::EnvironmentSSAOQuality p_quality, bool p_half_size, float p_adaptive_target, int p_blur_passes, float p_fadeout_from, float p_fadeout_to) override;
  655. void environment_set_ssil_quality(RS::EnvironmentSSILQuality p_quality, bool p_half_size, float p_adaptive_target, int p_blur_passes, float p_fadeout_from, float p_fadeout_to) override;
  656. void environment_set_sdfgi_ray_count(RS::EnvironmentSDFGIRayCount p_ray_count) override;
  657. void environment_set_sdfgi_frames_to_converge(RS::EnvironmentSDFGIFramesToConverge p_frames) override;
  658. void environment_set_sdfgi_frames_to_update_light(RS::EnvironmentSDFGIFramesToUpdateLight p_update) override;
  659. void environment_set_volumetric_fog_volume_size(int p_size, int p_depth) override;
  660. void environment_set_volumetric_fog_filter_active(bool p_enable) override;
  661. Ref<Image> environment_bake_panorama(RID p_env, bool p_bake_irradiance, const Size2i &p_size) override;
  662. _FORCE_INLINE_ bool is_using_physical_light_units() {
  663. return use_physical_light_units;
  664. }
  665. void positional_soft_shadow_filter_set_quality(RS::ShadowQuality p_quality) override;
  666. void directional_soft_shadow_filter_set_quality(RS::ShadowQuality p_quality) override;
  667. RID fog_volume_instance_create(RID p_fog_volume) override;
  668. void fog_volume_instance_set_transform(RID p_fog_volume_instance, const Transform3D &p_transform) override;
  669. void fog_volume_instance_set_active(RID p_fog_volume_instance, bool p_active) override;
  670. RID fog_volume_instance_get_volume(RID p_fog_volume_instance) const override;
  671. Vector3 fog_volume_instance_get_position(RID p_fog_volume_instance) const override;
  672. RID voxel_gi_instance_create(RID p_voxel_gi) override;
  673. void voxel_gi_instance_set_transform_to_data(RID p_probe, const Transform3D &p_xform) override;
  674. bool voxel_gi_needs_update(RID p_probe) const override;
  675. void voxel_gi_update(RID p_probe, bool p_update_light_instances, const Vector<RID> &p_light_instances, const PagedArray<RenderGeometryInstance *> &p_dynamic_objects) override;
  676. void voxel_gi_set_quality(RS::VoxelGIQuality) override;
  677. void render_scene(const Ref<RenderSceneBuffers> &p_render_buffers, const CameraData *p_camera_data, const CameraData *p_prev_camera_data, const PagedArray<RenderGeometryInstance *> &p_instances, const PagedArray<RID> &p_lights, const PagedArray<RID> &p_reflection_probes, const PagedArray<RID> &p_voxel_gi_instances, const PagedArray<RID> &p_decals, const PagedArray<RID> &p_lightmaps, const PagedArray<RID> &p_fog_volumes, RID p_environment, RID p_camera_attributes, RID p_compositor, RID p_shadow_atlas, RID p_occluder_debug_tex, RID p_reflection_atlas, RID p_reflection_probe, int p_reflection_probe_pass, float p_screen_mesh_lod_threshold, const RenderShadowData *p_render_shadows, int p_render_shadow_count, const RenderSDFGIData *p_render_sdfgi_regions, int p_render_sdfgi_region_count, const RenderSDFGIUpdateData *p_sdfgi_update_data = nullptr, RenderingMethod::RenderInfo *r_render_info = nullptr) override;
  678. void render_material(const Transform3D &p_cam_transform, const Projection &p_cam_projection, bool p_cam_orthogonal, const PagedArray<RenderGeometryInstance *> &p_instances, RID p_framebuffer, const Rect2i &p_region) override;
  679. void render_particle_collider_heightfield(RID p_collider, const Transform3D &p_transform, const PagedArray<RenderGeometryInstance *> &p_instances) override;
  680. void set_scene_pass(uint64_t p_pass) override {
  681. scene_pass = p_pass;
  682. }
  683. _FORCE_INLINE_ uint64_t get_scene_pass() {
  684. return scene_pass;
  685. }
  686. void set_time(double p_time, double p_step) override;
  687. void set_debug_draw_mode(RS::ViewportDebugDraw p_debug_draw) override;
  688. _FORCE_INLINE_ RS::ViewportDebugDraw get_debug_draw_mode() const {
  689. return debug_draw;
  690. }
  691. Ref<RenderSceneBuffers> render_buffers_create() override;
  692. void gi_set_use_half_resolution(bool p_enable) override;
  693. void screen_space_roughness_limiter_set_active(bool p_enable, float p_amount, float p_curve) override;
  694. bool screen_space_roughness_limiter_is_active() const override;
  695. void sub_surface_scattering_set_quality(RS::SubSurfaceScatteringQuality p_quality) override;
  696. void sub_surface_scattering_set_scale(float p_scale, float p_depth_scale) override;
  697. TypedArray<Image> bake_render_uv2(RID p_base, const TypedArray<RID> &p_material_overrides, const Size2i &p_image_size) override;
  698. void _render_uv2(const PagedArray<RenderGeometryInstance *> &p_instances, GLuint p_framebuffer, const Rect2i &p_region);
  699. bool free(RID p_rid) override;
  700. void update() override;
  701. void sdfgi_set_debug_probe_select(const Vector3 &p_position, const Vector3 &p_dir) override;
  702. void decals_set_filter(RS::DecalFilter p_filter) override;
  703. void light_projectors_set_filter(RS::LightProjectorFilter p_filter) override;
  704. virtual void lightmaps_set_bicubic_filter(bool p_enable) override;
  705. RasterizerSceneGLES3();
  706. ~RasterizerSceneGLES3();
  707. };
  708. #endif // GLES3_ENABLED
  709. #endif // RASTERIZER_SCENE_GLES3_H