diff options
| author | Yuri Sizov <yuris@humnom.net> | 2023-12-14 17:38:43 +0100 |
|---|---|---|
| committer | Yuri Sizov <yuris@humnom.net> | 2023-12-14 17:38:43 +0100 |
| commit | 4269a57b0cafd2fc4724de758002c68928f4586b (patch) | |
| tree | 36c7917f51d8aeeb810614781b7d4dda30156c5e /editor | |
| parent | a3024d0395915ad0f511db86a4397780d975872d (diff) | |
| parent | 453c2246b6bce66bf0320839095529943fe17e09 (diff) | |
| download | redot-engine-4269a57b0cafd2fc4724de758002c68928f4586b.tar.gz | |
Merge pull request #85387 from jsjtxietian/fix-forward-plus-crash
Use render method from OS instead of project settings in compositor RD
Diffstat (limited to 'editor')
| -rw-r--r-- | editor/editor_node.cpp | 71 | ||||
| -rw-r--r-- | editor/editor_node.h | 1 |
2 files changed, 43 insertions, 29 deletions
diff --git a/editor/editor_node.cpp b/editor/editor_node.cpp index 6e30980852..52ca1cf25c 100644 --- a/editor/editor_node.cpp +++ b/editor/editor_node.cpp @@ -6572,6 +6572,23 @@ void EditorNode::_renderer_selected(int p_which) { _update_renderer_color(); } +void EditorNode::_add_renderer_entry(const String &p_renderer_name, bool p_mark_overridden) { + String item_text; + if (p_renderer_name == "forward_plus") { + item_text = TTR("Forward+"); + } + if (p_renderer_name == "mobile") { + item_text = TTR("Mobile"); + } + if (p_renderer_name == "gl_compatibility") { + item_text = TTR("Compatibility"); + } + if (p_mark_overridden) { + item_text += " " + TTR("(Overridden)"); + } + renderer->add_item(item_text); +} + void EditorNode::_resource_saved(Ref<Resource> p_resource, const String &p_path) { if (singleton->saving_resources_in_path.has(p_resource)) { // This is going to be handled by save_resource_in_path when the time is right. @@ -7496,7 +7513,6 @@ EditorNode::EditorNode() { renderer->set_flat(true); renderer->set_fit_to_longest_item(false); renderer->set_focus_mode(Control::FOCUS_NONE); - renderer->connect("item_selected", callable_mp(this, &EditorNode::_renderer_selected)); renderer->add_theme_font_override("font", theme->get_font(SNAME("bold"), EditorStringName(EditorFonts))); renderer->add_theme_font_size_override("font_size", theme->get_font_size(SNAME("bold_size"), EditorStringName(EditorFonts))); renderer->set_tooltip_text(TTR("Choose a renderer.")); @@ -7510,36 +7526,33 @@ EditorNode::EditorNode() { title_bar->add_child(right_menu_spacer); } - String current_renderer = GLOBAL_GET("rendering/renderer/rendering_method"); - - PackedStringArray renderers = ProjectSettings::get_singleton()->get_custom_property_info().get(StringName("rendering/renderer/rendering_method")).hint_string.split(",", false); - - // As we are doing string comparisons, keep in standard case to prevent problems with capitals - // "vulkan" in particular uses lowercase "v" in the code, and uppercase in the UI. - current_renderer = current_renderer.to_lower(); + String current_renderer_ps = GLOBAL_GET("rendering/renderer/rendering_method"); + current_renderer_ps = current_renderer_ps.to_lower(); + String current_renderer_os = OS::get_singleton()->get_current_rendering_method().to_lower(); - for (int i = 0; i < renderers.size(); i++) { - String rendering_method = renderers[i]; - - // Add the renderers name to the UI. - if (rendering_method == "forward_plus") { - renderer->add_item(TTR("Forward+")); - } - if (rendering_method == "mobile") { - renderer->add_item(TTR("Mobile")); - } - if (rendering_method == "gl_compatibility") { - renderer->add_item(TTR("Compatibility")); - } - renderer->set_item_metadata(i, rendering_method); - - // Lowercase for standard comparison. - rendering_method = rendering_method.to_lower(); - - if (current_renderer == rendering_method) { - renderer->select(i); - renderer_current = i; + // Add the renderers name to the UI. + if (current_renderer_ps == current_renderer_os) { + renderer->connect("item_selected", callable_mp(this, &EditorNode::_renderer_selected)); + // As we are doing string comparisons, keep in standard case to prevent problems with capitals + // "vulkan" in particular uses lowercase "v" in the code, and uppercase in the UI. + PackedStringArray renderers = ProjectSettings::get_singleton()->get_custom_property_info().get(StringName("rendering/renderer/rendering_method")).hint_string.split(",", false); + for (int i = 0; i < renderers.size(); i++) { + String rendering_method = renderers[i]; + _add_renderer_entry(rendering_method, false); + renderer->set_item_metadata(i, rendering_method); + // Lowercase for standard comparison. + rendering_method = rendering_method.to_lower(); + if (current_renderer_ps == rendering_method) { + renderer->select(i); + renderer_current = i; + } } + } else { + // It's an CLI-overridden rendering method. + _add_renderer_entry(current_renderer_os, true); + renderer->set_item_metadata(0, current_renderer_os); + renderer->select(0); + renderer_current = 0; } _update_renderer_color(); diff --git a/editor/editor_node.h b/editor/editor_node.h index 2b6e89ac5a..8b440b798c 100644 --- a/editor/editor_node.h +++ b/editor/editor_node.h @@ -613,6 +613,7 @@ private: void _renderer_selected(int); void _update_renderer_color(); + void _add_renderer_entry(const String &p_renderer_name, bool p_mark_overridden); void _exit_editor(int p_exit_code); |
