Add Control to preferred types
This commit is contained in:
parent
4599381fad
commit
ec86d32684
|
@ -350,17 +350,22 @@ void SceneTreeDock::_tool_selected(int p_tool, bool p_confirm_override) {
|
||||||
if (!profile_allow_editing) {
|
if (!profile_allow_editing) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
String preferred = "";
|
|
||||||
Node *current_edited_scene_root = EditorNode::get_singleton()->get_edited_scene();
|
|
||||||
|
|
||||||
|
// Prefer nodes that inherit from the current scene root.
|
||||||
|
Node *current_edited_scene_root = EditorNode::get_singleton()->get_edited_scene();
|
||||||
if (current_edited_scene_root) {
|
if (current_edited_scene_root) {
|
||||||
if (ClassDB::is_parent_class(current_edited_scene_root->get_class_name(), "Node2D")) {
|
static const String preferred_types[] = { "Node2D", "Node3D", "Control" };
|
||||||
preferred = "Node2D";
|
|
||||||
} else if (ClassDB::is_parent_class(current_edited_scene_root->get_class_name(), "Node3D")) {
|
StringName root_class = current_edited_scene_root->get_class_name();
|
||||||
preferred = "Node3D";
|
|
||||||
|
for (int i = 0; i < preferred_types->size(); i++) {
|
||||||
|
if (ClassDB::is_parent_class(root_class, preferred_types[i])) {
|
||||||
|
create_dialog->set_preferred_search_result_type(preferred_types[i]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
create_dialog->set_preferred_search_result_type(preferred);
|
|
||||||
create_dialog->popup_create(true);
|
create_dialog->popup_create(true);
|
||||||
} break;
|
} break;
|
||||||
case TOOL_INSTANCE: {
|
case TOOL_INSTANCE: {
|
||||||
|
|
Loading…
Reference in New Issue