X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fardour_dialog.cc;h=c7d78099ce1e3cae34354e03f7308c15d939ad25;hb=af2ee3c8564c7d60cadb130b8c7ad1f4cddd2216;hp=22f3f260483089ac93c917f023a0fd752218e7bd;hpb=1f16781c75205b43ac193596d1449de343693a6f;p=ardour.git diff --git a/gtk2_ardour/ardour_dialog.cc b/gtk2_ardour/ardour_dialog.cc index 22f3f26048..c7d78099ce 100644 --- a/gtk2_ardour/ardour_dialog.cc +++ b/gtk2_ardour/ardour_dialog.cc @@ -18,46 +18,128 @@ */ #include +#include #include #include "ardour_dialog.h" -#include "keyboard.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; +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 (string title, bool modal) - : Dialog (title, modal) +ArdourDialog::ArdourDialog (Gtk::Window& parent, string title, bool modal, bool use_seperator) + : Dialog (title, parent, modal, use_seperator) + , _splash_pushed (false) { - session = 0; + init (); + set_position (Gtk::WIN_POS_CENTER_ON_PARENT); } ArdourDialog::~ArdourDialog () { + pop_splash (); + Keyboard::the_keyboard().focus_out_window (0, this); + WM::Manager::instance().remove (proxy); } -bool -ArdourDialog::on_enter_notify_event (GdkEventCrossing *ev) +void +ArdourDialog::on_response (int response_id) +{ + pop_splash (); + hide (); + ARDOUR::GUIIdle (); + Gtk::Dialog::on_response (response_id); +} + +void +ArdourDialog::pop_splash () { - if (ev->detail != GDK_NOTIFY_INFERIOR) { - // GTK2FIX - //Keyboard::the_keyboard().set_current_dialog (this); + if (_splash_pushed) { + Splash* spl = Splash::instance(); + + if (spl) { + spl->pop_front(); + } + _splash_pushed = false; } - return false; } bool -ArdourDialog::on_leave_notify_event (GdkEventCrossing *ev) +ArdourDialog::on_focus_in_event (GdkEventFocus *ev) +{ + Keyboard::the_keyboard().focus_in_window (ev, this); + return Dialog::on_focus_in_event (ev); +} + +bool +ArdourDialog::on_focus_out_event (GdkEventFocus *ev) { - if (ev->detail != GDK_NOTIFY_INFERIOR) { - // GTK2FIX - //Keyboard::the_keyboard().set_current_dialog (0); + if (!get_modal()) { + Keyboard::the_keyboard().focus_out_window (ev, this); } - return false; + return Dialog::on_focus_out_event (ev); } void ArdourDialog::on_unmap () { + Keyboard::the_keyboard().leave_window (0, this); Dialog::on_unmap (); } + +void +ArdourDialog::on_show () +{ + Dialog::on_show (); + + // never allow the splash screen to obscure any dialog + + Splash* spl = Splash::instance(); + + if (spl && spl->is_visible()) { + spl->pop_back_for (*this); + _splash_pushed = true; + } +} + +bool +ArdourDialog::on_delete_event (GdkEventAny*) +{ + hide (); + return false; +} + +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(); + + 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); +}