Create 'rendering/misc' project settings section
To prevent the project settings `rendering` section getting out of hand, this PR moves some of the smaller new settings into a `misc` category.
This commit is contained in:
parent
db0370cab5
commit
192ec963ae
6 changed files with 14 additions and 14 deletions
|
@ -1240,13 +1240,13 @@
|
||||||
<member name="rendering/limits/time/time_rollover_secs" type="float" setter="" getter="" default="3600">
|
<member name="rendering/limits/time/time_rollover_secs" type="float" setter="" getter="" default="3600">
|
||||||
Shaders have a time variable that constantly increases. At some point, it needs to be rolled back to zero to avoid precision errors on shader animations. This setting specifies when (in seconds).
|
Shaders have a time variable that constantly increases. At some point, it needs to be rolled back to zero to avoid precision errors on shader animations. This setting specifies when (in seconds).
|
||||||
</member>
|
</member>
|
||||||
<member name="rendering/lossless_compression/force_png" type="bool" setter="" getter="" default="false">
|
<member name="rendering/misc/lossless_compression/force_png" type="bool" setter="" getter="" default="false">
|
||||||
If [code]true[/code], the texture importer will import lossless textures using the PNG format. Otherwise, it will default to using WebP.
|
If [code]true[/code], the texture importer will import lossless textures using the PNG format. Otherwise, it will default to using WebP.
|
||||||
</member>
|
</member>
|
||||||
<member name="rendering/lossless_compression/webp_compression_level" type="int" setter="" getter="" default="2">
|
<member name="rendering/misc/lossless_compression/webp_compression_level" type="int" setter="" getter="" default="2">
|
||||||
The default compression level for lossless WebP. Higher levels result in smaller files at the cost of compression speed. Decompression speed is mostly unaffected by the compression level. Supported values are 0 to 9. Note that compression levels above 6 are very slow and offer very little savings.
|
The default compression level for lossless WebP. Higher levels result in smaller files at the cost of compression speed. Decompression speed is mostly unaffected by the compression level. Supported values are 0 to 9. Note that compression levels above 6 are very slow and offer very little savings.
|
||||||
</member>
|
</member>
|
||||||
<member name="rendering/mesh_storage/split_stream" type="bool" setter="" getter="" default="false">
|
<member name="rendering/misc/mesh_storage/split_stream" type="bool" setter="" getter="" default="false">
|
||||||
On import, mesh vertex data will be split into two streams within a single vertex buffer, one for position data and the other for interleaved attributes data. Recommended to be enabled if targeting mobile devices. Requires manual reimport of meshes after toggling.
|
On import, mesh vertex data will be split into two streams within a single vertex buffer, one for position data and the other for interleaved attributes data. Recommended to be enabled if targeting mobile devices. Requires manual reimport of meshes after toggling.
|
||||||
</member>
|
</member>
|
||||||
<member name="rendering/misc/occlusion_culling/max_active_spheres" type="int" setter="" getter="" default="8">
|
<member name="rendering/misc/occlusion_culling/max_active_spheres" type="int" setter="" getter="" default="8">
|
||||||
|
|
|
@ -2254,7 +2254,7 @@ void RasterizerStorageGLES2::mesh_add_surface(RID p_mesh, uint32_t p_format, VS:
|
||||||
}
|
}
|
||||||
|
|
||||||
//bool has_morph = p_blend_shapes.size();
|
//bool has_morph = p_blend_shapes.size();
|
||||||
bool use_split_stream = GLOBAL_GET("rendering/mesh_storage/split_stream") && !(p_format & VS::ARRAY_FLAG_USE_DYNAMIC_UPDATE);
|
bool use_split_stream = GLOBAL_GET("rendering/misc/mesh_storage/split_stream") && !(p_format & VS::ARRAY_FLAG_USE_DYNAMIC_UPDATE);
|
||||||
|
|
||||||
Surface::Attrib attribs[VS::ARRAY_MAX];
|
Surface::Attrib attribs[VS::ARRAY_MAX];
|
||||||
|
|
||||||
|
|
|
@ -3350,7 +3350,7 @@ void RasterizerStorageGLES3::mesh_add_surface(RID p_mesh, uint32_t p_format, VS:
|
||||||
}
|
}
|
||||||
|
|
||||||
//bool has_morph = p_blend_shapes.size();
|
//bool has_morph = p_blend_shapes.size();
|
||||||
bool use_split_stream = GLOBAL_GET("rendering/mesh_storage/split_stream") && !(p_format & VS::ARRAY_FLAG_USE_DYNAMIC_UPDATE);
|
bool use_split_stream = GLOBAL_GET("rendering/misc/mesh_storage/split_stream") && !(p_format & VS::ARRAY_FLAG_USE_DYNAMIC_UPDATE);
|
||||||
|
|
||||||
Surface::Attrib attribs[VS::ARRAY_MAX];
|
Surface::Attrib attribs[VS::ARRAY_MAX];
|
||||||
|
|
||||||
|
|
|
@ -256,7 +256,7 @@ void ResourceImporterTexture::_save_stex(const Ref<Image> &p_image, const String
|
||||||
|
|
||||||
switch (p_compress_mode) {
|
switch (p_compress_mode) {
|
||||||
case COMPRESS_LOSSLESS: {
|
case COMPRESS_LOSSLESS: {
|
||||||
bool lossless_force_png = ProjectSettings::get_singleton()->get("rendering/lossless_compression/force_png");
|
bool lossless_force_png = ProjectSettings::get_singleton()->get("rendering/misc/lossless_compression/force_png");
|
||||||
bool use_webp = !lossless_force_png && p_image->get_width() <= 16383 && p_image->get_height() <= 16383; // WebP has a size limit
|
bool use_webp = !lossless_force_png && p_image->get_width() <= 16383 && p_image->get_height() <= 16383; // WebP has a size limit
|
||||||
Ref<Image> image = p_image->duplicate();
|
Ref<Image> image = p_image->duplicate();
|
||||||
if (p_mipmaps) {
|
if (p_mipmaps) {
|
||||||
|
|
|
@ -78,7 +78,7 @@ static PoolVector<uint8_t> _webp_lossy_pack(const Ref<Image> &p_image, float p_q
|
||||||
static PoolVector<uint8_t> _webp_lossless_pack(const Ref<Image> &p_image) {
|
static PoolVector<uint8_t> _webp_lossless_pack(const Ref<Image> &p_image) {
|
||||||
ERR_FAIL_COND_V(p_image.is_null() || p_image->empty(), PoolVector<uint8_t>());
|
ERR_FAIL_COND_V(p_image.is_null() || p_image->empty(), PoolVector<uint8_t>());
|
||||||
|
|
||||||
int compression_level = ProjectSettings::get_singleton()->get("rendering/lossless_compression/webp_compression_level");
|
int compression_level = ProjectSettings::get_singleton()->get("rendering/misc/lossless_compression/webp_compression_level");
|
||||||
compression_level = CLAMP(compression_level, 0, 9);
|
compression_level = CLAMP(compression_level, 0, 9);
|
||||||
|
|
||||||
Ref<Image> img = p_image->duplicate();
|
Ref<Image> img = p_image->duplicate();
|
||||||
|
|
|
@ -857,7 +857,7 @@ uint32_t VisualServer::mesh_surface_get_format_stride(uint32_t p_format, int p_v
|
||||||
}
|
}
|
||||||
|
|
||||||
void VisualServer::mesh_surface_make_offsets_from_format(uint32_t p_format, int p_vertex_len, int p_index_len, uint32_t *r_offsets, uint32_t *r_strides) const {
|
void VisualServer::mesh_surface_make_offsets_from_format(uint32_t p_format, int p_vertex_len, int p_index_len, uint32_t *r_offsets, uint32_t *r_strides) const {
|
||||||
bool use_split_stream = GLOBAL_GET("rendering/mesh_storage/split_stream") && !(p_format & VS::ARRAY_FLAG_USE_DYNAMIC_UPDATE);
|
bool use_split_stream = GLOBAL_GET("rendering/misc/mesh_storage/split_stream") && !(p_format & VS::ARRAY_FLAG_USE_DYNAMIC_UPDATE);
|
||||||
|
|
||||||
int attributes_base_offset = 0;
|
int attributes_base_offset = 0;
|
||||||
int attributes_stride = 0;
|
int attributes_stride = 0;
|
||||||
|
@ -1027,7 +1027,7 @@ void VisualServer::mesh_add_surface_from_arrays(RID p_mesh, PrimitiveType p_prim
|
||||||
ERR_FAIL_INDEX(p_primitive, VS::PRIMITIVE_MAX);
|
ERR_FAIL_INDEX(p_primitive, VS::PRIMITIVE_MAX);
|
||||||
ERR_FAIL_COND(p_arrays.size() != VS::ARRAY_MAX);
|
ERR_FAIL_COND(p_arrays.size() != VS::ARRAY_MAX);
|
||||||
|
|
||||||
bool use_split_stream = GLOBAL_GET("rendering/mesh_storage/split_stream") && !(p_compress_format & VS::ARRAY_FLAG_USE_DYNAMIC_UPDATE);
|
bool use_split_stream = GLOBAL_GET("rendering/misc/mesh_storage/split_stream") && !(p_compress_format & VS::ARRAY_FLAG_USE_DYNAMIC_UPDATE);
|
||||||
|
|
||||||
uint32_t format = 0;
|
uint32_t format = 0;
|
||||||
|
|
||||||
|
@ -1303,7 +1303,7 @@ void VisualServer::mesh_add_surface_from_arrays(RID p_mesh, PrimitiveType p_prim
|
||||||
}
|
}
|
||||||
|
|
||||||
Array VisualServer::_get_array_from_surface(uint32_t p_format, PoolVector<uint8_t> p_vertex_data, int p_vertex_len, PoolVector<uint8_t> p_index_data, int p_index_len) const {
|
Array VisualServer::_get_array_from_surface(uint32_t p_format, PoolVector<uint8_t> p_vertex_data, int p_vertex_len, PoolVector<uint8_t> p_index_data, int p_index_len) const {
|
||||||
bool use_split_stream = GLOBAL_GET("rendering/mesh_storage/split_stream") && !(p_format & VS::ARRAY_FLAG_USE_DYNAMIC_UPDATE);
|
bool use_split_stream = GLOBAL_GET("rendering/misc/mesh_storage/split_stream") && !(p_format & VS::ARRAY_FLAG_USE_DYNAMIC_UPDATE);
|
||||||
|
|
||||||
uint32_t offsets[ARRAY_MAX];
|
uint32_t offsets[ARRAY_MAX];
|
||||||
uint32_t strides[VS::ARRAY_MAX];
|
uint32_t strides[VS::ARRAY_MAX];
|
||||||
|
@ -2592,9 +2592,9 @@ VisualServer::VisualServer() {
|
||||||
GLOBAL_DEF_RST("rendering/vram_compression/import_etc2", true);
|
GLOBAL_DEF_RST("rendering/vram_compression/import_etc2", true);
|
||||||
GLOBAL_DEF_RST("rendering/vram_compression/import_pvrtc", false);
|
GLOBAL_DEF_RST("rendering/vram_compression/import_pvrtc", false);
|
||||||
|
|
||||||
GLOBAL_DEF("rendering/lossless_compression/force_png", false);
|
GLOBAL_DEF("rendering/misc/lossless_compression/force_png", false);
|
||||||
GLOBAL_DEF("rendering/lossless_compression/webp_compression_level", 2);
|
GLOBAL_DEF("rendering/misc/lossless_compression/webp_compression_level", 2);
|
||||||
ProjectSettings::get_singleton()->set_custom_property_info("rendering/lossless_compression/webp_compression_level", PropertyInfo(Variant::INT, "rendering/lossless_compression/webp_compression_level", PROPERTY_HINT_RANGE, "0,9,1"));
|
ProjectSettings::get_singleton()->set_custom_property_info("rendering/misc/lossless_compression/webp_compression_level", PropertyInfo(Variant::INT, "rendering/misc/lossless_compression/webp_compression_level", PROPERTY_HINT_RANGE, "0,9,1"));
|
||||||
|
|
||||||
GLOBAL_DEF("rendering/limits/time/time_rollover_secs", 3600);
|
GLOBAL_DEF("rendering/limits/time/time_rollover_secs", 3600);
|
||||||
ProjectSettings::get_singleton()->set_custom_property_info("rendering/limits/time/time_rollover_secs", PropertyInfo(Variant::REAL, "rendering/limits/time/time_rollover_secs", PROPERTY_HINT_RANGE, "0,10000,1,or_greater"));
|
ProjectSettings::get_singleton()->set_custom_property_info("rendering/limits/time/time_rollover_secs", PropertyInfo(Variant::REAL, "rendering/limits/time/time_rollover_secs", PROPERTY_HINT_RANGE, "0,10000,1,or_greater"));
|
||||||
|
@ -2634,7 +2634,7 @@ VisualServer::VisualServer() {
|
||||||
GLOBAL_DEF("rendering/quality/shading/force_blinn_over_ggx", false);
|
GLOBAL_DEF("rendering/quality/shading/force_blinn_over_ggx", false);
|
||||||
GLOBAL_DEF("rendering/quality/shading/force_blinn_over_ggx.mobile", true);
|
GLOBAL_DEF("rendering/quality/shading/force_blinn_over_ggx.mobile", true);
|
||||||
|
|
||||||
GLOBAL_DEF_RST("rendering/mesh_storage/split_stream", false);
|
GLOBAL_DEF_RST("rendering/misc/mesh_storage/split_stream", false);
|
||||||
|
|
||||||
GLOBAL_DEF("rendering/quality/depth_prepass/enable", true);
|
GLOBAL_DEF("rendering/quality/depth_prepass/enable", true);
|
||||||
GLOBAL_DEF("rendering/quality/depth_prepass/disable_for_vendors", "PowerVR,Mali,Adreno,Apple");
|
GLOBAL_DEF("rendering/quality/depth_prepass/disable_for_vendors", "PowerVR,Mali,Adreno,Apple");
|
||||||
|
|
Loading…
Reference in a new issue