From c1d9376934182201f45db2bf6941ae4f766a2918 Mon Sep 17 00:00:00 2001 From: ManoloFLTK <41016272+ManoloFLTK@users.noreply.github.com> Date: Thu, 19 Oct 2023 08:27:46 +0200 Subject: [PATCH] Fix for "Keyboard sometimes stops working after Ctrl/+ or Ctrl/-" (#794) --- src/Fl_Screen_Driver.cxx | 14 +++++++++++--- 1 file changed, 11 insertions(+), 3 deletions(-) diff --git a/src/Fl_Screen_Driver.cxx b/src/Fl_Screen_Driver.cxx index ad3143e17..a98577e19 100644 --- a/src/Fl_Screen_Driver.cxx +++ b/src/Fl_Screen_Driver.cxx @@ -447,6 +447,9 @@ void Fl_Screen_Driver::transient_scale_display(float f, int nscreen) data->tracker = (widget ? new Fl_Widget_Tracker(widget) : NULL); win->show(); Fl::add_timeout(1, (Fl_Timeout_Handler)del_transient_window, data); // delete after 1 sec + win->wait_for_expose(); + Fl::flush(); + Fl::check(); } // respond to Ctrl-'+' and Ctrl-'-' and Ctrl-'0' (Ctrl-'=' is same as Ctrl-'+') by rescaling all windows @@ -496,9 +499,14 @@ int Fl_Screen_Driver::scale_handler(int event) f = scaling_values[i]; } if (f == old_f) return 1; - screen_dr->rescale_all_windows_from_screen(screen, f*initial_scale); - Fl_Screen_Driver::transient_scale_display(f, screen); - Fl::handle(FL_ZOOM_EVENT, NULL); + static bool in_use = false; + if (!in_use) { // avoid recursive use (see issue #794) + in_use = true; + screen_dr->rescale_all_windows_from_screen(screen, f * initial_scale); + Fl_Screen_Driver::transient_scale_display(f, screen); + Fl::handle(FL_ZOOM_EVENT, NULL); + in_use = false; + } return 1; } return 0;