X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fardour_dialog.cc;h=89b9914120147b4586ca137ad0d73df5ad17c3b7;hb=b90cfa7e3958d4e0c575aacc15ea3ca4e68de4a5;hp=d0d85c5cbe86056d274fd54ca94b8c03302920e5;hpb=e977b659af1bbba244df43d15fd1c02e7f82fe78;p=ardour.git diff --git a/gtk2_ardour/ardour_dialog.cc b/gtk2_ardour/ardour_dialog.cc index d0d85c5cbe..89b9914120 100644 --- a/gtk2_ardour/ardour_dialog.cc +++ b/gtk2_ardour/ardour_dialog.cc @@ -32,6 +32,7 @@ using namespace std; using namespace Gtk; using namespace Gtkmm2ext; +using namespace ARDOUR_UI_UTILS; ArdourDialog::ArdourDialog (string title, bool modal, bool use_seperator) : Dialog (title, modal, use_seperator) @@ -54,35 +55,29 @@ ArdourDialog::~ArdourDialog () { if (_splash_pushed) { Splash* spl = Splash::instance(); - + if (spl) { spl->pop_front(); } } - WM::Manager::instance().remove (proxy); -} - -bool -ArdourDialog::on_key_press_event (GdkEventKey* ev) -{ - if (!relay_key_press (ev, this)) { - return Gtk::Window::on_key_press_event(ev); - } - return true; + Keyboard::the_keyboard().focus_out_window (0, this); + WM::Manager::instance().remove (proxy); } bool -ArdourDialog::on_enter_notify_event (GdkEventCrossing *ev) +ArdourDialog::on_focus_in_event (GdkEventFocus *ev) { - Keyboard::the_keyboard().enter_window (ev, this); - return Dialog::on_enter_notify_event (ev); + Keyboard::the_keyboard().focus_in_window (ev, this); + return Dialog::on_focus_in_event (ev); } bool -ArdourDialog::on_leave_notify_event (GdkEventCrossing *ev) +ArdourDialog::on_focus_out_event (GdkEventFocus *ev) { - Keyboard::the_keyboard().leave_window (ev, this); - return Dialog::on_leave_notify_event (ev); + if (!get_modal()) { + Keyboard::the_keyboard().focus_out_window (ev, this); + } + return Dialog::on_focus_out_event (ev); } void @@ -118,7 +113,7 @@ void ArdourDialog::init () { set_border_width (10); - + add_events (Gdk::FOCUS_CHANGE_MASK); set_type_hint (Gdk::WINDOW_TYPE_HINT_DIALOG); Gtk::Window* parent = WM::Manager::instance().transient_parent();