Merge pull request #92664 from KoBeWi/ultimate_final_solution_for_containers
Add visibilty mode to `as_sortable_control()`
This commit is contained in:
commit
a6bb8b00d7
9 changed files with 35 additions and 23 deletions
|
@ -243,8 +243,8 @@ Size2 BoxContainer::get_minimum_size() const {
|
||||||
bool first = true;
|
bool first = true;
|
||||||
|
|
||||||
for (int i = 0; i < get_child_count(); i++) {
|
for (int i = 0; i < get_child_count(); i++) {
|
||||||
Control *c = Object::cast_to<Control>(get_child(i));
|
Control *c = as_sortable_control(get_child(i), SortableVisbilityMode::VISIBLE);
|
||||||
if (!c || !c->is_visible() || c->is_set_as_top_level()) {
|
if (!c) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -139,9 +139,15 @@ void Container::queue_sort() {
|
||||||
pending_sort = true;
|
pending_sort = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
Control *Container::as_sortable_control(Node *p_node) const {
|
Control *Container::as_sortable_control(Node *p_node, SortableVisbilityMode p_visibility_mode) const {
|
||||||
Control *c = Object::cast_to<Control>(p_node);
|
Control *c = Object::cast_to<Control>(p_node);
|
||||||
if (!c || !c->is_visible_in_tree() || c->is_set_as_top_level()) {
|
if (!c || c->is_set_as_top_level()) {
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
if (p_visibility_mode == SortableVisbilityMode::VISIBLE && !c->is_visible()) {
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
if (p_visibility_mode == SortableVisbilityMode::VISIBLE_IN_TREE && !c->is_visible_in_tree()) {
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
return c;
|
return c;
|
||||||
|
|
|
@ -41,8 +41,14 @@ class Container : public Control {
|
||||||
void _child_minsize_changed();
|
void _child_minsize_changed();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
enum class SortableVisbilityMode {
|
||||||
|
VISIBLE,
|
||||||
|
VISIBLE_IN_TREE,
|
||||||
|
IGNORE,
|
||||||
|
};
|
||||||
|
|
||||||
void queue_sort();
|
void queue_sort();
|
||||||
Control *as_sortable_control(Node *p_node) const;
|
Control *as_sortable_control(Node *p_node, SortableVisbilityMode p_visibility_mode = SortableVisbilityMode::VISIBLE_IN_TREE) const;
|
||||||
|
|
||||||
virtual void add_child_notify(Node *p_child) override;
|
virtual void add_child_notify(Node *p_child) override;
|
||||||
virtual void move_child_notify(Node *p_child) override;
|
virtual void move_child_notify(Node *p_child) override;
|
||||||
|
|
|
@ -60,8 +60,8 @@ void GraphElement::_resort() {
|
||||||
Size2 GraphElement::get_minimum_size() const {
|
Size2 GraphElement::get_minimum_size() const {
|
||||||
Size2 minsize;
|
Size2 minsize;
|
||||||
for (int i = 0; i < get_child_count(); i++) {
|
for (int i = 0; i < get_child_count(); i++) {
|
||||||
Control *child = Object::cast_to<Control>(get_child(i));
|
Control *child = as_sortable_control(get_child(i), SortableVisbilityMode::IGNORE);
|
||||||
if (!child || child->is_set_as_top_level()) {
|
if (!child) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -130,8 +130,8 @@ bool GraphNode::_get(const StringName &p_name, Variant &r_ret) const {
|
||||||
void GraphNode::_get_property_list(List<PropertyInfo> *p_list) const {
|
void GraphNode::_get_property_list(List<PropertyInfo> *p_list) const {
|
||||||
int idx = 0;
|
int idx = 0;
|
||||||
for (int i = 0; i < get_child_count(false); i++) {
|
for (int i = 0; i < get_child_count(false); i++) {
|
||||||
Control *child = Object::cast_to<Control>(get_child(i, false));
|
Control *child = as_sortable_control(get_child(i, false), SortableVisbilityMode::IGNORE);
|
||||||
if (!child || child->is_set_as_top_level()) {
|
if (!child) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -658,8 +658,8 @@ void GraphNode::_port_pos_update() {
|
||||||
int slot_index = 0;
|
int slot_index = 0;
|
||||||
|
|
||||||
for (int i = 0; i < get_child_count(false); i++) {
|
for (int i = 0; i < get_child_count(false); i++) {
|
||||||
Control *child = Object::cast_to<Control>(get_child(i, false));
|
Control *child = as_sortable_control(get_child(i, false), SortableVisbilityMode::IGNORE);
|
||||||
if (!child || child->is_set_as_top_level()) {
|
if (!child) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -36,8 +36,8 @@ Size2 MarginContainer::get_minimum_size() const {
|
||||||
Size2 max;
|
Size2 max;
|
||||||
|
|
||||||
for (int i = 0; i < get_child_count(); i++) {
|
for (int i = 0; i < get_child_count(); i++) {
|
||||||
Control *c = Object::cast_to<Control>(get_child(i));
|
Control *c = as_sortable_control(get_child(i), SortableVisbilityMode::VISIBLE);
|
||||||
if (!c || !c->is_visible() || c->is_set_as_top_level()) {
|
if (!c) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -35,7 +35,7 @@
|
||||||
Size2 PanelContainer::get_minimum_size() const {
|
Size2 PanelContainer::get_minimum_size() const {
|
||||||
Size2 ms;
|
Size2 ms;
|
||||||
for (int i = 0; i < get_child_count(); i++) {
|
for (int i = 0; i < get_child_count(); i++) {
|
||||||
Control *c = as_sortable_control(get_child(i));
|
Control *c = as_sortable_control(get_child(i), SortableVisbilityMode::VISIBLE);
|
||||||
if (!c) {
|
if (!c) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
|
@ -42,7 +42,7 @@ Size2 ScrollContainer::get_minimum_size() const {
|
||||||
largest_child_min_size = Size2();
|
largest_child_min_size = Size2();
|
||||||
|
|
||||||
for (int i = 0; i < get_child_count(); i++) {
|
for (int i = 0; i < get_child_count(); i++) {
|
||||||
Control *c = as_sortable_control(get_child(i));
|
Control *c = as_sortable_control(get_child(i), SortableVisbilityMode::VISIBLE);
|
||||||
if (!c) {
|
if (!c) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
|
@ -362,8 +362,8 @@ void TabContainer::_on_mouse_exited() {
|
||||||
Vector<Control *> TabContainer::_get_tab_controls() const {
|
Vector<Control *> TabContainer::_get_tab_controls() const {
|
||||||
Vector<Control *> controls;
|
Vector<Control *> controls;
|
||||||
for (int i = 0; i < get_child_count(); i++) {
|
for (int i = 0; i < get_child_count(); i++) {
|
||||||
Control *control = Object::cast_to<Control>(get_child(i));
|
Control *control = as_sortable_control(get_child(i), SortableVisbilityMode::IGNORE);
|
||||||
if (!control || control->is_set_as_top_level() || control == tab_bar || children_removing.has(control)) {
|
if (!control || control == tab_bar || children_removing.has(control)) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -539,8 +539,8 @@ void TabContainer::add_child_notify(Node *p_child) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Control *c = Object::cast_to<Control>(p_child);
|
Control *c = as_sortable_control(p_child, SortableVisbilityMode::IGNORE);
|
||||||
if (!c || c->is_set_as_top_level()) {
|
if (!c) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
c->hide();
|
c->hide();
|
||||||
|
@ -569,8 +569,8 @@ void TabContainer::move_child_notify(Node *p_child) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Control *c = Object::cast_to<Control>(p_child);
|
Control *c = as_sortable_control(p_child, SortableVisbilityMode::IGNORE);
|
||||||
if (c && !c->is_set_as_top_level()) {
|
if (c) {
|
||||||
tab_bar->move_tab(c->get_meta("_tab_index"), get_tab_idx_from_control(c));
|
tab_bar->move_tab(c->get_meta("_tab_index"), get_tab_idx_from_control(c));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -584,8 +584,8 @@ void TabContainer::remove_child_notify(Node *p_child) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
Control *c = Object::cast_to<Control>(p_child);
|
Control *c = as_sortable_control(p_child, SortableVisbilityMode::IGNORE);
|
||||||
if (!c || c->is_set_as_top_level()) {
|
if (!c) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue