X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fardour_dialog.cc;h=89b9914120147b4586ca137ad0d73df5ad17c3b7;hb=a2c0b10d8a6cf4ab5a0fdcdfe157c35c0ed9a709;hp=6775a70953e97928fc3e524392547a10eca3e379;hpb=ebb1271b6f666dadcaf6a73a6cb81231a70d8ad7;p=ardour.git diff --git a/gtk2_ardour/ardour_dialog.cc b/gtk2_ardour/ardour_dialog.cc index 6775a70953..89b9914120 100644 --- a/gtk2_ardour/ardour_dialog.cc +++ b/gtk2_ardour/ardour_dialog.cc @@ -23,20 +23,24 @@ #include #include "ardour_dialog.h" +#include "ardour_ui.h" #include "keyboard.h" #include "splash.h" +#include "utils.h" +#include "window_manager.h" using namespace std; using namespace Gtk; using namespace Gtkmm2ext; - -sigc::signal ArdourDialog::CloseAllDialogs; +using namespace ARDOUR_UI_UTILS; ArdourDialog::ArdourDialog (string title, bool modal, bool use_seperator) : Dialog (title, modal, use_seperator) + , proxy (0) , _splash_pushed (false) { init (); + set_position (Gtk::WIN_POS_MOUSE); } ArdourDialog::ArdourDialog (Gtk::Window& parent, string title, bool modal, bool use_seperator) @@ -51,25 +55,29 @@ ArdourDialog::~ArdourDialog () { if (_splash_pushed) { Splash* spl = Splash::instance(); - + if (spl) { spl->pop_front(); } } + 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 @@ -94,12 +102,28 @@ ArdourDialog::on_show () } } +bool +ArdourDialog::on_delete_event (GdkEventAny*) +{ + hide (); + return false; +} + void ArdourDialog::init () { - set_type_hint(Gdk::WINDOW_TYPE_HINT_DIALOG); set_border_width (10); - CloseAllDialogs.connect ( - sigc::bind (sigc::mem_fun (*this, &ArdourDialog::response), - RESPONSE_CANCEL)); + add_events (Gdk::FOCUS_CHANGE_MASK); + set_type_hint (Gdk::WINDOW_TYPE_HINT_DIALOG); + + Gtk::Window* parent = WM::Manager::instance().transient_parent(); + + if (parent) { + set_transient_for (*parent); + } + + ARDOUR_UI::CloseAllDialogs.connect (sigc::bind (sigc::mem_fun (*this, &ArdourDialog::response), RESPONSE_CANCEL)); + + proxy = new WM::ProxyTemporary (get_title(), this); + WM::Manager::instance().register_window (proxy); }