Fix DSP load sorting with inactive plugins
[ardour.git] / gtk2_ardour / ardour_ui_dialogs.cc
index 287c9128b47e3467585839eaffc45eae67ba8f2d..4064809d25c17d3620a200d0104d83344a8890ae 100644 (file)
@@ -1,21 +1,29 @@
 /*
-    Copyright (C) 2000 Paul Davis
-
-    This program is free software; you can redistribute it and/or modify
-    it under the terms of the GNU General Public License as published by
-    the Free Software Foundation; either version 2 of the License, or
-    (at your option) any later version.
-
-    This program is distributed in the hope that it will be useful,
-    but WITHOUT ANY WARRANTY; without even the implied warranty of
-    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-    GNU General Public License for more details.
-
-    You should have received a copy of the GNU General Public License
-    along with this program; if not, write to the Free Software
-    Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
-
-*/
+ * Copyright (C) 2005-2006 Taybin Rutkin <taybin@taybin.com>
+ * Copyright (C) 2005-2018 Paul Davis <paul@linuxaudiosystems.com>
+ * Copyright (C) 2006-2016 David Robillard <d@drobilla.net>
+ * Copyright (C) 2006 Hans Fugal <hans@fugal.net>
+ * Copyright (C) 2006 Nick Mainsbridge <mainsbridge@gmail.com>
+ * Copyright (C) 2007-2012 Carl Hetherington <carl@carlh.net>
+ * Copyright (C) 2007-2015 Tim Mayberry <mojofunk@gmail.com>
+ * Copyright (C) 2007 Doug McLain <doug@nostar.net>
+ * Copyright (C) 2013-2019 Robin Gareus <robin@gareus.org>
+ * Copyright (C) 2014-2018 Ben Loftis <ben@harrisonconsoles.com>
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License along
+ * with this program; if not, write to the Free Software Foundation, Inc.,
+ * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
+ */
 
 /* This file contains any ARDOUR_UI methods that require knowledge of
    the various dialog boxes, and exists so that no compilation dependency
@@ -74,6 +82,7 @@
 #include "time_info_box.h"
 #include "timers.h"
 #include "transport_masters_dialog.h"
+#include "virtual_keyboard_window.h"
 
 #include "pbd/i18n.h"
 
@@ -95,12 +104,18 @@ ARDOUR_UI::set_session (Session *s)
                big_transport_window->set_session (s);
        }
 
+       if (virtual_keyboard_window) {
+               virtual_keyboard_window->set_session (s);
+       }
+
        if (!_session) {
                WM::Manager::instance().set_session (s);
                /* Session option editor cannot exist across change-of-session */
                session_option_editor.drop_window ();
                /* Ditto for AddVideoDialog */
                add_video_dialog.drop_window ();
+               /* screensaver + layered button sensitivity */
+               map_transport_state ();
                return;
        }
 
@@ -182,6 +197,9 @@ ARDOUR_UI::set_session (Session *s)
        _session->locations()->removed.connect (_session_connections, MISSING_INVALIDATOR, boost::bind (&ARDOUR_UI::handle_locations_change, this, _1), gui_context());
        _session->config.ParameterChanged.connect (_session_connections, MISSING_INVALIDATOR, boost::bind (&ARDOUR_UI::session_parameter_changed, this, _1), gui_context ());
 
+       _session->LatencyUpdated.connect (_session_connections, MISSING_INVALIDATOR, boost::bind (&ARDOUR_UI::session_latency_updated, this), gui_context());
+       session_latency_updated ();
+
        /* Clocks are on by default after we are connected to a session, so show that here.
        */
 
@@ -226,22 +244,18 @@ ARDOUR_UI::set_session (Session *s)
            _session->master_out() &&
            _session->master_out()->n_outputs().n(DataType::AUDIO) > 0) {
 
-               if (!ARDOUR::Profile->get_trx()) {
-                       editor_meter = new LevelMeterHBox(_session);
-                       editor_meter->set_meter (_session->master_out()->shared_peak_meter().get());
-                       editor_meter->clear_meters();
-                       editor_meter->set_meter_type (_session->master_out()->meter_type());
-                       editor_meter->setup_meters (30, 10, 6);
-                       editor_meter->show();
-                       editor_meter->ButtonPress.connect_same_thread (editor_meter_connection, boost::bind (&ARDOUR_UI::editor_meter_button_press, this, _1));
-
-                       editor_meter_table.set_spacings(3);
-                       editor_meter_table.attach(*editor_meter,             0,1, 0,1, FILL, FILL);
-                       editor_meter_table.attach(editor_meter_peak_display, 0,1, 1,2, FILL, EXPAND|FILL);
-
-                       editor_meter->show();
-                       editor_meter_peak_display.show();
-               }
+               editor_meter = new LevelMeterHBox(_session);
+               editor_meter->set_meter (_session->master_out()->shared_peak_meter().get());
+               editor_meter->clear_meters();
+               editor_meter->setup_meters (30, 10, 6);
+               editor_meter->show();
+
+               editor_meter_table.set_spacings(3);
+               editor_meter_table.attach(*editor_meter,             0,1, 0,1, FILL, FILL);
+               editor_meter_table.attach(editor_meter_peak_display, 0,1, 1,2, FILL, EXPAND|FILL);
+
+               editor_meter->show();
+               editor_meter_peak_display.show();
 
                ArdourMeter::ResetAllPeakDisplays.connect (sigc::mem_fun(*this, &ARDOUR_UI::reset_peak_display));
                ArdourMeter::ResetRoutePeakDisplays.connect (sigc::mem_fun(*this, &ARDOUR_UI::reset_route_peak_display));
@@ -880,6 +894,14 @@ ARDOUR_UI::create_big_transport_window ()
        return btw;
 }
 
+VirtualKeyboardWindow*
+ARDOUR_UI::create_virtual_keyboard_window ()
+{
+       VirtualKeyboardWindow* vkbd = new VirtualKeyboardWindow ();
+       vkbd->set_session (_session);
+       return vkbd;
+}
+
 void
 ARDOUR_UI::handle_locations_change (Location *)
 {
@@ -905,6 +927,9 @@ ARDOUR_UI::tabbed_window_state_event_handler (GdkEventWindowState* ev, void* obj
                        if (big_transport_window) {
                                big_transport_window->set_transient_for (*editor->own_window());
                        }
+                       if (virtual_keyboard_window) {
+                               virtual_keyboard_window->set_transient_for (*editor->own_window());
+                       }
                }
 
        } else if (object == mixer) {
@@ -917,6 +942,9 @@ ARDOUR_UI::tabbed_window_state_event_handler (GdkEventWindowState* ev, void* obj
                        if (big_transport_window) {
                                big_transport_window->set_transient_for (*mixer->own_window());
                        }
+                       if (virtual_keyboard_window) {
+                               virtual_keyboard_window->set_transient_for (*mixer->own_window());
+                       }
                }
        }
 
@@ -926,14 +954,8 @@ ARDOUR_UI::tabbed_window_state_event_handler (GdkEventWindowState* ev, void* obj
 bool
 ARDOUR_UI::editor_meter_peak_button_release (GdkEventButton* ev)
 {
-       if (ev->button == 1 && Gtkmm2ext::Keyboard::modifier_state_equals (ev->state, Gtkmm2ext::Keyboard::PrimaryModifier|Gtkmm2ext::Keyboard::TertiaryModifier)) {
+       if (ev->button == 1) {
                ArdourMeter::ResetAllPeakDisplays ();
-       } else if (ev->button == 1 && Gtkmm2ext::Keyboard::modifier_state_equals (ev->state, Gtkmm2ext::Keyboard::PrimaryModifier)) {
-               if (_session->master_out()) {
-                       ArdourMeter::ResetGroupPeakDisplays (_session->master_out()->route_group());
-               }
-       } else if (_session->master_out()) {
-               ArdourMeter::ResetRoutePeakDisplays (_session->master_out().get());
        }
        return false;
 }
@@ -941,14 +963,10 @@ ARDOUR_UI::editor_meter_peak_button_release (GdkEventButton* ev)
 void
 ARDOUR_UI::toggle_mixer_space()
 {
-       Glib::RefPtr<Action> act = ActionManager::get_action ("Common", "ToggleMaximalMixer");
-
-       if (act) {
-               Glib::RefPtr<ToggleAction> tact = Glib::RefPtr<ToggleAction>::cast_dynamic(act);
-               if (tact->get_active()) {
-                       mixer->maximise_mixer_space ();
-               } else {
-                       mixer->restore_mixer_space ();
-               }
+       Glib::RefPtr<ToggleAction> tact = ActionManager::get_toggle_action ("Common", "ToggleMaximalMixer");
+       if (tact->get_active()) {
+               mixer->maximise_mixer_space ();
+       } else {
+               mixer->restore_mixer_space ();
        }
 }