diff options
Diffstat (limited to 'servers/rendering_server.cpp')
| -rw-r--r-- | servers/rendering_server.cpp | 63 | 
1 files changed, 45 insertions, 18 deletions
| diff --git a/servers/rendering_server.cpp b/servers/rendering_server.cpp index 3eff92d916..9ac66cd4bf 100644 --- a/servers/rendering_server.cpp +++ b/servers/rendering_server.cpp @@ -5,8 +5,8 @@  /*                           GODOT ENGINE                                */  /*                      https://godotengine.org                          */  /*************************************************************************/ -/* Copyright (c) 2007-2020 Juan Linietsky, Ariel Manzur.                 */ -/* Copyright (c) 2014-2020 Godot Engine contributors (cf. AUTHORS.md).   */ +/* Copyright (c) 2007-2021 Juan Linietsky, Ariel Manzur.                 */ +/* Copyright (c) 2014-2021 Godot Engine contributors (cf. AUTHORS.md).   */  /*                                                                       */  /* Permission is hereby granted, free of charge, to any person obtaining */  /* a copy of this software and associated documentation files (the       */ @@ -865,8 +865,22 @@ Error RenderingServer::mesh_create_surface_data_from_arrays(SurfaceData *r_surfa  					ERR_FAIL_V(ERR_INVALID_DATA);  				} break;  			} -  			ERR_FAIL_COND_V(array_len == 0, ERR_INVALID_DATA); +		} else if (i == RS::ARRAY_BONES) { +			switch (p_arrays[i].get_type()) { +				case Variant::PACKED_INT32_ARRAY: { +					Vector<Vector3> vertexes = p_arrays[RS::ARRAY_VERTEX]; +					Vector<int32_t> bones = p_arrays[i]; +					int32_t bone_8_group_count = bones.size() / (ARRAY_WEIGHTS_SIZE * 2); +					int32_t vertex_count = vertexes.size(); +					if (vertex_count == bone_8_group_count) { +						format |= RS::ARRAY_FLAG_USE_8_BONE_WEIGHTS; +					} +				} break; +				default: { +					ERR_FAIL_V(ERR_INVALID_DATA); +				} break; +			}  		} else if (i == RS::ARRAY_INDEX) {  			index_array_len = PackedInt32Array(p_arrays[i]).size();  		} @@ -1647,7 +1661,7 @@ void RenderingServer::_bind_methods() {  	ClassDB::bind_method(D_METHOD("viewport_set_transparent_background", "viewport", "enabled"), &RenderingServer::viewport_set_transparent_background);  	ClassDB::bind_method(D_METHOD("viewport_set_global_canvas_transform", "viewport", "transform"), &RenderingServer::viewport_set_global_canvas_transform);  	ClassDB::bind_method(D_METHOD("viewport_set_canvas_stacking", "viewport", "canvas", "layer", "sublayer"), &RenderingServer::viewport_set_canvas_stacking); -	ClassDB::bind_method(D_METHOD("viewport_set_shadow_atlas_size", "viewport", "size"), &RenderingServer::viewport_set_shadow_atlas_size); +	ClassDB::bind_method(D_METHOD("viewport_set_shadow_atlas_size", "viewport", "size", "use_16_bits"), &RenderingServer::viewport_set_shadow_atlas_size, DEFVAL(false));  	ClassDB::bind_method(D_METHOD("viewport_set_shadow_atlas_quadrant_subdivision", "viewport", "quadrant", "subdivision"), &RenderingServer::viewport_set_shadow_atlas_quadrant_subdivision);  	ClassDB::bind_method(D_METHOD("viewport_set_msaa", "viewport", "msaa"), &RenderingServer::viewport_set_msaa);  	ClassDB::bind_method(D_METHOD("viewport_set_use_debanding", "viewport", "enable"), &RenderingServer::viewport_set_use_debanding); @@ -1655,6 +1669,10 @@ void RenderingServer::_bind_methods() {  	ClassDB::bind_method(D_METHOD("viewport_get_render_info", "viewport", "info"), &RenderingServer::viewport_get_render_info);  	ClassDB::bind_method(D_METHOD("viewport_set_debug_draw", "viewport", "draw"), &RenderingServer::viewport_set_debug_draw); +	ClassDB::bind_method(D_METHOD("viewport_set_measure_render_time", "viewport", "enable"), &RenderingServer::viewport_set_measure_render_time); +	ClassDB::bind_method(D_METHOD("viewport_get_measured_render_time_cpu", "viewport"), &RenderingServer::viewport_get_measured_render_time_cpu); +	ClassDB::bind_method(D_METHOD("viewport_get_measured_render_time_gpu", "viewport"), &RenderingServer::viewport_get_measured_render_time_gpu); +  	ClassDB::bind_method(D_METHOD("environment_create"), &RenderingServer::environment_create);  	ClassDB::bind_method(D_METHOD("environment_set_background", "env", "bg"), &RenderingServer::environment_set_background);  	ClassDB::bind_method(D_METHOD("environment_set_sky", "env", "sky"), &RenderingServer::environment_set_sky); @@ -1813,6 +1831,9 @@ void RenderingServer::_bind_methods() {  	ClassDB::bind_method(D_METHOD("is_render_loop_enabled"), &RenderingServer::is_render_loop_enabled);  	ClassDB::bind_method(D_METHOD("set_render_loop_enabled", "enabled"), &RenderingServer::set_render_loop_enabled); + +	ClassDB::bind_method(D_METHOD("get_frame_setup_time_cpu"), &RenderingServer::get_frame_setup_time_cpu); +  	ADD_PROPERTY(PropertyInfo(Variant::BOOL, "render_loop_enabled"), "set_render_loop_enabled", "is_render_loop_enabled");  	BIND_CONSTANT(NO_INDEX_ARRAY); @@ -2232,6 +2253,8 @@ void RenderingServer::set_render_loop_enabled(bool p_enabled) {  RenderingServer::RenderingServer() {  	//ERR_FAIL_COND(singleton); + +	thread_pool = memnew(RendererThreadPool);  	singleton = this;  	GLOBAL_DEF_RST("rendering/vram_compression/import_bptc", false); @@ -2249,6 +2272,7 @@ RenderingServer::RenderingServer() {  	GLOBAL_DEF("rendering/quality/directional_shadow/soft_shadow_quality", 2);  	GLOBAL_DEF("rendering/quality/directional_shadow/soft_shadow_quality.mobile", 0);  	ProjectSettings::get_singleton()->set_custom_property_info("rendering/quality/directional_shadow/soft_shadow_quality", PropertyInfo(Variant::INT, "rendering/quality/directional_shadow/soft_shadow_quality", PROPERTY_HINT_ENUM, "Hard (Fastest),Soft Low (Fast),Soft Medium (Average),Soft High (Slow),Soft Ultra (Slowest)")); +	GLOBAL_DEF("rendering/quality/directional_shadow/16_bits", true);  	GLOBAL_DEF("rendering/quality/shadows/soft_shadow_quality", 2);  	GLOBAL_DEF("rendering/quality/shadows/soft_shadow_quality.mobile", 0); @@ -2259,18 +2283,6 @@ RenderingServer::RenderingServer() {  	GLOBAL_DEF("rendering/quality/rd_renderer/use_low_end_renderer", false);  	GLOBAL_DEF("rendering/quality/rd_renderer/use_low_end_renderer.mobile", true); -	GLOBAL_DEF("rendering/quality/shadow_atlas/size", 4096); -	GLOBAL_DEF("rendering/quality/shadow_atlas/size.mobile", 2048); -	ProjectSettings::get_singleton()->set_custom_property_info("rendering/quality/shadow_atlas/size", PropertyInfo(Variant::INT, "rendering/quality/shadow_atlas/size", PROPERTY_HINT_RANGE, "256,16384")); -	GLOBAL_DEF("rendering/quality/shadow_atlas/quadrant_0_subdiv", 1); -	GLOBAL_DEF("rendering/quality/shadow_atlas/quadrant_1_subdiv", 2); -	GLOBAL_DEF("rendering/quality/shadow_atlas/quadrant_2_subdiv", 3); -	GLOBAL_DEF("rendering/quality/shadow_atlas/quadrant_3_subdiv", 4); -	ProjectSettings::get_singleton()->set_custom_property_info("rendering/quality/shadow_atlas/quadrant_0_subdiv", PropertyInfo(Variant::INT, "rendering/quality/shadow_atlas/quadrant_0_subdiv", PROPERTY_HINT_ENUM, "Disabled,1 Shadow,4 Shadows,16 Shadows,64 Shadows,256 Shadows,1024 Shadows")); -	ProjectSettings::get_singleton()->set_custom_property_info("rendering/quality/shadow_atlas/quadrant_1_subdiv", PropertyInfo(Variant::INT, "rendering/quality/shadow_atlas/quadrant_1_subdiv", PROPERTY_HINT_ENUM, "Disabled,1 Shadow,4 Shadows,16 Shadows,64 Shadows,256 Shadows,1024 Shadows")); -	ProjectSettings::get_singleton()->set_custom_property_info("rendering/quality/shadow_atlas/quadrant_2_subdiv", PropertyInfo(Variant::INT, "rendering/quality/shadow_atlas/quadrant_2_subdiv", PROPERTY_HINT_ENUM, "Disabled,1 Shadow,4 Shadows,16 Shadows,64 Shadows,256 Shadows,1024 Shadows")); -	ProjectSettings::get_singleton()->set_custom_property_info("rendering/quality/shadow_atlas/quadrant_3_subdiv", PropertyInfo(Variant::INT, "rendering/quality/shadow_atlas/quadrant_3_subdiv", PROPERTY_HINT_ENUM, "Disabled,1 Shadow,4 Shadows,16 Shadows,64 Shadows,256 Shadows,1024 Shadows")); -  	GLOBAL_DEF("rendering/quality/reflections/roughness_layers", 8);  	GLOBAL_DEF("rendering/quality/reflections/texture_array_reflections", true);  	GLOBAL_DEF("rendering/quality/reflections/texture_array_reflections.mobile", false); @@ -2281,6 +2293,8 @@ RenderingServer::RenderingServer() {  	GLOBAL_DEF("rendering/quality/reflection_atlas/reflection_size.mobile", 128);  	GLOBAL_DEF("rendering/quality/reflection_atlas/reflection_count", 64); +	GLOBAL_DEF("rendering/quality/gi/use_half_resolution", false); +  	GLOBAL_DEF("rendering/quality/gi_probes/anisotropic", false);  	GLOBAL_DEF("rendering/quality/gi_probes/quality", 1);  	ProjectSettings::get_singleton()->set_custom_property_info("rendering/quality/gi_probes/quality", PropertyInfo(Variant::INT, "rendering/quality/gi_probes/quality", PROPERTY_HINT_ENUM, "Low (4 Cones - Fast),High (6 Cones - Slow)")); @@ -2344,10 +2358,12 @@ RenderingServer::RenderingServer() {  	GLOBAL_DEF("rendering/lightmapper/probe_capture_update_speed", 15);  	ProjectSettings::get_singleton()->set_custom_property_info("rendering/lightmapper/probe_capture_update_speed", PropertyInfo(Variant::FLOAT, "rendering/lightmapper/probe_capture_update_speed", PROPERTY_HINT_RANGE, "0.001,256,0.001")); -	GLOBAL_DEF("rendering/sdfgi/probe_ray_count", 2); +	GLOBAL_DEF("rendering/sdfgi/probe_ray_count", 1);  	ProjectSettings::get_singleton()->set_custom_property_info("rendering/sdfgi/probe_ray_count", PropertyInfo(Variant::INT, "rendering/sdfgi/probe_ray_count", PROPERTY_HINT_ENUM, "8 (Fastest),16,32,64,96,128 (Slowest)")); -	GLOBAL_DEF("rendering/sdfgi/frames_to_converge", 1); +	GLOBAL_DEF("rendering/sdfgi/frames_to_converge", 4);  	ProjectSettings::get_singleton()->set_custom_property_info("rendering/sdfgi/frames_to_converge", PropertyInfo(Variant::INT, "rendering/sdfgi/frames_to_converge", PROPERTY_HINT_ENUM, "5 (Less Latency but Lower Quality),10,15,20,25,30 (More Latency but Higher Quality)")); +	GLOBAL_DEF("rendering/sdfgi/frames_to_update_lights", 2); +	ProjectSettings::get_singleton()->set_custom_property_info("rendering/sdfgi/frames_to_update_lights", PropertyInfo(Variant::INT, "rendering/sdfgi/frames_to_update_lights", PROPERTY_HINT_ENUM, "1 (Slower),2,4,8,16 (Faster)"));  	GLOBAL_DEF("rendering/volumetric_fog/volume_size", 64);  	ProjectSettings::get_singleton()->set_custom_property_info("rendering/volumetric_fog/volume_size", PropertyInfo(Variant::INT, "rendering/volumetric_fog/volume_size", PROPERTY_HINT_RANGE, "16,512,1")); @@ -2359,8 +2375,19 @@ RenderingServer::RenderingServer() {  	ProjectSettings::get_singleton()->set_custom_property_info("rendering/volumetric_fog/directional_shadow_shrink", PropertyInfo(Variant::INT, "rendering/volumetric_fog/directional_shadow_shrink", PROPERTY_HINT_RANGE, "32,2048,1"));  	GLOBAL_DEF("rendering/volumetric_fog/positional_shadow_shrink", 512);  	ProjectSettings::get_singleton()->set_custom_property_info("rendering/volumetric_fog/positional_shadow_shrink", PropertyInfo(Variant::INT, "rendering/volumetric_fog/positional_shadow_shrink", PROPERTY_HINT_RANGE, "32,2048,1")); + +	GLOBAL_DEF("rendering/spatial_indexer/update_iterations_per_frame", 10); +	ProjectSettings::get_singleton()->set_custom_property_info("rendering/spatial_indexer/update_iterations_per_frame", PropertyInfo(Variant::INT, "rendering/spatial_indexer/update_iterations_per_frame", PROPERTY_HINT_RANGE, "0,1024,1")); +	GLOBAL_DEF("rendering/spatial_indexer/threaded_cull_minimum_instances", 1000); +	ProjectSettings::get_singleton()->set_custom_property_info("rendering/spatial_indexer/threaded_cull_minimum_instances", PropertyInfo(Variant::INT, "rendering/spatial_indexer/threaded_cull_minimum_instances", PROPERTY_HINT_RANGE, "32,65536,1")); +	GLOBAL_DEF("rendering/forward_renderer/threaded_render_minimum_instances", 500); +	ProjectSettings::get_singleton()->set_custom_property_info("rendering/forward_renderer/threaded_render_minimum_instances", PropertyInfo(Variant::INT, "rendering/forward_renderer/threaded_render_minimum_instances", PROPERTY_HINT_RANGE, "32,65536,1")); + +	GLOBAL_DEF("rendering/cluster_builder/max_clustered_elements", 512); +	ProjectSettings::get_singleton()->set_custom_property_info("rendering/cluster_builder/max_clustered_elements", PropertyInfo(Variant::FLOAT, "rendering/cluster_builder/max_clustered_elements", PROPERTY_HINT_RANGE, "32,8192,1"));  }  RenderingServer::~RenderingServer() { +	memdelete(thread_pool);  	singleton = nullptr;  } |