summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorbruvzg <7645683+bruvzg@users.noreply.github.com>2024-06-07 09:26:12 +0300
committerbruvzg <7645683+bruvzg@users.noreply.github.com>2024-06-08 23:15:07 +0300
commit564ebd7ba401d1cfbad8adfcea7f89b6bc605c20 (patch)
treeed6ba9bc41b521b2d3cf04a3135dc425db254970
parent5833f597865c773fae3ee09fc4e31d4a243f812d (diff)
downloadredot-engine-564ebd7ba401d1cfbad8adfcea7f89b6bc605c20.tar.gz
Force editor progress dialog size update.
-rw-r--r--editor/progress_dialog.cpp24
-rw-r--r--editor/progress_dialog.h2
2 files changed, 21 insertions, 5 deletions
diff --git a/editor/progress_dialog.cpp b/editor/progress_dialog.cpp
index 406425e9fd..2623079cfe 100644
--- a/editor/progress_dialog.cpp
+++ b/editor/progress_dialog.cpp
@@ -126,6 +126,16 @@ void BackgroundProgress::end_task(const String &p_task) {
ProgressDialog *ProgressDialog::singleton = nullptr;
+void ProgressDialog::_update_ui() {
+ // Run main loop for two frames.
+ if (is_inside_tree()) {
+ DisplayServer::get_singleton()->process_events();
+#ifndef ANDROID_ENABLED
+ Main::iteration();
+#endif
+ }
+}
+
void ProgressDialog::_popup() {
Size2 ms = main->get_combined_minimum_size();
ms.width = MAX(500 * EDSCALE, ms.width);
@@ -138,7 +148,13 @@ void ProgressDialog::_popup() {
main->set_offset(SIDE_TOP, style->get_margin(SIDE_TOP));
main->set_offset(SIDE_BOTTOM, -style->get_margin(SIDE_BOTTOM));
- if (!is_inside_tree()) {
+ if (is_inside_tree()) {
+ Rect2i adjust = _popup_adjust_rect();
+ if (adjust != Rect2i()) {
+ set_position(adjust.position);
+ set_size(adjust.size);
+ }
+ } else {
for (Window *window : host_windows) {
if (window->has_focus()) {
popup_exclusive_centered(window, ms);
@@ -182,6 +198,7 @@ void ProgressDialog::add_task(const String &p_task, const String &p_label, int p
if (p_can_cancel) {
cancel->grab_focus();
}
+ _update_ui();
}
bool ProgressDialog::task_step(const String &p_task, const String &p_state, int p_step, bool p_force_redraw) {
@@ -203,11 +220,8 @@ bool ProgressDialog::task_step(const String &p_task, const String &p_state, int
t.state->set_text(p_state);
last_progress_tick = OS::get_singleton()->get_ticks_usec();
- DisplayServer::get_singleton()->process_events();
+ _update_ui();
-#ifndef ANDROID_ENABLED
- Main::iteration(); // this will not work on a lot of platforms, so it's only meant for the editor
-#endif
return canceled;
}
diff --git a/editor/progress_dialog.h b/editor/progress_dialog.h
index 74196a28df..82d59219da 100644
--- a/editor/progress_dialog.h
+++ b/editor/progress_dialog.h
@@ -85,6 +85,8 @@ class ProgressDialog : public PopupPanel {
void _popup();
void _cancel_pressed();
+
+ void _update_ui();
bool canceled = false;
public: