summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorkobewi <kobewi4e@gmail.com>2024-08-15 13:43:47 +0200
committerkobewi <kobewi4e@gmail.com>2024-08-15 17:32:57 +0200
commit0dea6ef251cd0f7c0768ea099d3a372820f63d3b (patch)
tree3a57cec13365116dcc181a6b46e8286f33edbd00
parentc2a4942850404d97d0e5d5b99e03361cebf2a54c (diff)
downloadredot-engine-0dea6ef251cd0f7c0768ea099d3a372820f63d3b.tar.gz
Allow picking partial properties in PropertySelector
-rw-r--r--editor/property_selector.cpp133
-rw-r--r--editor/property_selector.h4
2 files changed, 135 insertions, 2 deletions
diff --git a/editor/property_selector.cpp b/editor/property_selector.cpp
index 0394c9e249..66cd6dbec7 100644
--- a/editor/property_selector.cpp
+++ b/editor/property_selector.cpp
@@ -194,7 +194,7 @@ void PropertySelector::_update_search() {
continue;
}
- if (type_filter.size() && !type_filter.has(E.type)) {
+ if (!type_filter.is_empty() && !type_filter.has(E.type)) {
continue;
}
@@ -209,6 +209,9 @@ void PropertySelector::_update_search() {
}
item->set_selectable(0, true);
+
+ _create_subproperties(item, E.type);
+ item->set_collapsed(true);
}
if (category && category->get_first_child() == nullptr) {
@@ -407,6 +410,133 @@ void PropertySelector::_hide_requested() {
_cancel_pressed(); // From AcceptDialog.
}
+void PropertySelector::_create_subproperties(TreeItem *p_parent_item, Variant::Type p_type) {
+ switch (p_type) {
+ case Variant::VECTOR2: {
+ _create_subproperty(p_parent_item, "x", Variant::FLOAT);
+ _create_subproperty(p_parent_item, "y", Variant::FLOAT);
+ } break;
+
+ case Variant::VECTOR2I: {
+ _create_subproperty(p_parent_item, "x", Variant::INT);
+ _create_subproperty(p_parent_item, "y", Variant::INT);
+ } break;
+
+ case Variant::RECT2: {
+ _create_subproperty(p_parent_item, "position", Variant::VECTOR2);
+ _create_subproperty(p_parent_item, "size", Variant::VECTOR2);
+ _create_subproperty(p_parent_item, "end", Variant::VECTOR2);
+ } break;
+
+ case Variant::RECT2I: {
+ _create_subproperty(p_parent_item, "position", Variant::VECTOR2I);
+ _create_subproperty(p_parent_item, "size", Variant::VECTOR2I);
+ _create_subproperty(p_parent_item, "end", Variant::VECTOR2I);
+ } break;
+
+ case Variant::VECTOR3: {
+ _create_subproperty(p_parent_item, "x", Variant::FLOAT);
+ _create_subproperty(p_parent_item, "y", Variant::FLOAT);
+ _create_subproperty(p_parent_item, "z", Variant::FLOAT);
+ } break;
+
+ case Variant::VECTOR3I: {
+ _create_subproperty(p_parent_item, "x", Variant::INT);
+ _create_subproperty(p_parent_item, "y", Variant::INT);
+ _create_subproperty(p_parent_item, "z", Variant::INT);
+ } break;
+
+ case Variant::TRANSFORM2D: {
+ _create_subproperty(p_parent_item, "origin", Variant::VECTOR2);
+ _create_subproperty(p_parent_item, "x", Variant::VECTOR2);
+ _create_subproperty(p_parent_item, "y", Variant::VECTOR2);
+ } break;
+
+ case Variant::VECTOR4: {
+ _create_subproperty(p_parent_item, "x", Variant::FLOAT);
+ _create_subproperty(p_parent_item, "y", Variant::FLOAT);
+ _create_subproperty(p_parent_item, "z", Variant::FLOAT);
+ _create_subproperty(p_parent_item, "w", Variant::FLOAT);
+ } break;
+
+ case Variant::VECTOR4I: {
+ _create_subproperty(p_parent_item, "x", Variant::INT);
+ _create_subproperty(p_parent_item, "y", Variant::INT);
+ _create_subproperty(p_parent_item, "z", Variant::INT);
+ _create_subproperty(p_parent_item, "w", Variant::INT);
+ } break;
+
+ case Variant::PLANE: {
+ _create_subproperty(p_parent_item, "x", Variant::FLOAT);
+ _create_subproperty(p_parent_item, "y", Variant::FLOAT);
+ _create_subproperty(p_parent_item, "z", Variant::FLOAT);
+ _create_subproperty(p_parent_item, "normal", Variant::VECTOR3);
+ _create_subproperty(p_parent_item, "d", Variant::FLOAT);
+ } break;
+
+ case Variant::QUATERNION: {
+ _create_subproperty(p_parent_item, "x", Variant::FLOAT);
+ _create_subproperty(p_parent_item, "y", Variant::FLOAT);
+ _create_subproperty(p_parent_item, "z", Variant::FLOAT);
+ _create_subproperty(p_parent_item, "w", Variant::FLOAT);
+ } break;
+
+ case Variant::AABB: {
+ _create_subproperty(p_parent_item, "position", Variant::VECTOR3);
+ _create_subproperty(p_parent_item, "size", Variant::VECTOR3);
+ _create_subproperty(p_parent_item, "end", Variant::VECTOR3);
+ } break;
+
+ case Variant::BASIS: {
+ _create_subproperty(p_parent_item, "x", Variant::VECTOR3);
+ _create_subproperty(p_parent_item, "y", Variant::VECTOR3);
+ _create_subproperty(p_parent_item, "z", Variant::VECTOR3);
+ } break;
+
+ case Variant::TRANSFORM3D: {
+ _create_subproperty(p_parent_item, "basis", Variant::BASIS);
+ _create_subproperty(p_parent_item, "origin", Variant::VECTOR3);
+ } break;
+
+ case Variant::PROJECTION: {
+ _create_subproperty(p_parent_item, "x", Variant::VECTOR4);
+ _create_subproperty(p_parent_item, "y", Variant::VECTOR4);
+ _create_subproperty(p_parent_item, "z", Variant::VECTOR4);
+ _create_subproperty(p_parent_item, "w", Variant::VECTOR4);
+ } break;
+
+ case Variant::COLOR: {
+ _create_subproperty(p_parent_item, "r", Variant::FLOAT);
+ _create_subproperty(p_parent_item, "g", Variant::FLOAT);
+ _create_subproperty(p_parent_item, "b", Variant::FLOAT);
+ _create_subproperty(p_parent_item, "a", Variant::FLOAT);
+ _create_subproperty(p_parent_item, "r8", Variant::INT);
+ _create_subproperty(p_parent_item, "g8", Variant::INT);
+ _create_subproperty(p_parent_item, "b8", Variant::INT);
+ _create_subproperty(p_parent_item, "a8", Variant::INT);
+ _create_subproperty(p_parent_item, "h", Variant::FLOAT);
+ _create_subproperty(p_parent_item, "s", Variant::FLOAT);
+ _create_subproperty(p_parent_item, "v", Variant::FLOAT);
+ } break;
+
+ default: {
+ }
+ }
+}
+
+void PropertySelector::_create_subproperty(TreeItem *p_parent_item, const String &p_name, Variant::Type p_type) {
+ if (!type_filter.is_empty() && !type_filter.has(p_type)) {
+ return;
+ }
+
+ TreeItem *item = search_options->create_item(p_parent_item);
+ item->set_text(0, p_name);
+ item->set_metadata(0, String(p_parent_item->get_metadata(0)) + ":" + p_name);
+ item->set_icon(0, search_options->get_editor_theme_icon(Variant::get_type_name(p_type)));
+
+ _create_subproperties(item, p_type);
+}
+
void PropertySelector::_notification(int p_what) {
switch (p_what) {
case NOTIFICATION_ENTER_TREE: {
@@ -576,7 +706,6 @@ PropertySelector::PropertySelector() {
search_options->connect("item_activated", callable_mp(this, &PropertySelector::_confirmed));
search_options->connect("cell_selected", callable_mp(this, &PropertySelector::_item_selected));
search_options->set_hide_root(true);
- search_options->set_hide_folding(true);
help_bit = memnew(EditorHelpBit);
help_bit->set_content_height_limits(80 * EDSCALE, 80 * EDSCALE);
diff --git a/editor/property_selector.h b/editor/property_selector.h
index b162ee6cfd..34cade9267 100644
--- a/editor/property_selector.h
+++ b/editor/property_selector.h
@@ -36,6 +36,7 @@
class EditorHelpBit;
class LineEdit;
class Tree;
+class TreeItem;
class PropertySelector : public ConfirmationDialog {
GDCLASS(PropertySelector, ConfirmationDialog);
@@ -62,6 +63,9 @@ class PropertySelector : public ConfirmationDialog {
Vector<Variant::Type> type_filter;
+ void _create_subproperties(TreeItem *p_parent_item, Variant::Type p_type);
+ void _create_subproperty(TreeItem *p_parent_item, const String &p_name, Variant::Type p_type);
+
protected:
void _notification(int p_what);
static void _bind_methods();