#include "pbd/xml++.h"
#include "pbd/signals.h"
+#include <gtkmm/textview.h>
+#include <gtkmm/colorselection.h>
+
+#include "gtkmm2ext/widget_state.h"
+
#include "ardour/ardour.h"
#include "ardour/mute_master.h"
-#include "ardour/session_event.h"
#include "ardour/session.h"
+#include "ardour/session_event.h"
+#include "ardour/session_handle.h"
#include "ardour/route.h"
#include "ardour/route_group.h"
#include "ardour/track.h"
#include "axis_view.h"
+#include "selectable.h"
+#include "stripable_colorpicker.h"
+#include "window_manager.h"
namespace ARDOUR {
class AudioTrack;
class Widget;
}
-class BindableToggleButton;
-class LED;
+namespace ArdourWidgets {
+ class ArdourButton;
+ class Prompter;
+}
+
+class ArdourWindow;
+class IOSelectorWindow;
+class ControlSlaveUI;
-class RouteUI : public virtual AxisView
+class RoutePinWindowProxy : public WM::ProxyBase
{
- public:
- RouteUI(ARDOUR::Session*);
- RouteUI(boost::shared_ptr<ARDOUR::Route>, ARDOUR::Session*);
+public:
+ RoutePinWindowProxy (std::string const &, boost::shared_ptr<ARDOUR::Route>);
+ ~RoutePinWindowProxy();
+
+ Gtk::Window* get (bool create = false);
+ ARDOUR::SessionHandlePtr* session_handle();
+
+private:
+ boost::weak_ptr<ARDOUR::Route> _route;
+
+ void route_going_away ();
+ PBD::ScopedConnection going_away_connection;
+};
+
+class RouteUI : public virtual Selectable, public virtual ARDOUR::SessionHandlePtr, public virtual PBD::ScopedConnectionList, public virtual sigc::trackable
+{
+public:
+ RouteUI (ARDOUR::Session*);
virtual ~RouteUI();
+ boost::shared_ptr<ARDOUR::Stripable> stripable() const;
+
virtual void set_route (boost::shared_ptr<ARDOUR::Route>);
virtual void set_button_names () = 0;
bool has_audio_outputs () const;
boost::shared_ptr<ARDOUR::Route> route() const { return _route; }
+ ARDOUR::RouteGroup* route_group() const;
boost::shared_ptr<ARDOUR::Track> track() const;
boost::shared_ptr<ARDOUR::AudioTrack> audio_track() const;
boost::shared_ptr<ARDOUR::MidiTrack> midi_track() const;
- std::string name() const;
-
// protected: XXX sigh this should be here
boost::shared_ptr<ARDOUR::Route> _route;
- void set_color (const Gdk::Color & c);
- bool choose_color ();
+ virtual void set_color (uint32_t c);
+ Gdk::Color route_color () const;
+ void choose_color ();
bool ignore_toggle;
bool wait_for_release;
bool multiple_solo_change;
Gtk::HBox _invert_button_box;
- BindableToggleButton* mute_button;
- BindableToggleButton* solo_button;
- BindableToggleButton* rec_enable_button; /* audio tracks */
- BindableToggleButton* show_sends_button; /* busses */
+ ArdourWidgets::ArdourButton* mute_button;
+ ArdourWidgets::ArdourButton* solo_button;
+ ArdourWidgets::ArdourButton* rec_enable_button; /* audio tracks */
+ ArdourWidgets::ArdourButton* show_sends_button; /* busses */
+ ArdourWidgets::ArdourButton* monitor_input_button;
+ ArdourWidgets::ArdourButton* monitor_disk_button;
+
+ Glib::RefPtr<Gdk::Pixbuf> solo_safe_pixbuf;
- LED* solo_safe_led;
- LED* solo_isolated_led;
+ ArdourWidgets::ArdourButton* solo_safe_led;
+ ArdourWidgets::ArdourButton* solo_isolated_led;
- Gtk::Label solo_button_label;
- Gtk::Label mute_button_label;
- Gtk::Label rec_enable_button_label;
+
+ Gtk::Label monitor_input_button_label;
+ Gtk::Label monitor_disk_button_label;
void send_blink (bool);
sigc::connection send_blink_connection;
- virtual std::string solo_button_name () const { return "SoloButton"; }
- virtual std::string safe_solo_button_name () const { return "SafeSoloButton"; }
+ sigc::connection rec_blink_connection;
Gtk::Menu* mute_menu;
Gtk::Menu* solo_menu;
Gtk::Menu* sends_menu;
- XMLNode *xml_node;
- void ensure_xml_node ();
-
- virtual XMLNode* get_automation_child_xml_node (Evoral::Parameter);
+ boost::shared_ptr<ARDOUR::Delivery> _current_delivery;
bool mute_press(GdkEventButton*);
bool mute_release(GdkEventButton*);
bool show_sends_press(GdkEventButton*);
bool show_sends_release(GdkEventButton*);
- void step_gain_up ();
- void step_gain_down ();
- void page_gain_up ();
- void page_gain_down ();
+ bool monitor_release(GdkEventButton*, ARDOUR::MonitorChoice);
+ bool monitor_input_press(GdkEventButton*);
+ bool monitor_input_release(GdkEventButton*);
+ bool monitor_disk_press(GdkEventButton*);
+ bool monitor_disk_release(GdkEventButton*);
+ void update_monitoring_display ();
+
+ void edit_input_configuration ();
+ void edit_output_configuration ();
void build_sends_menu ();
void set_sends_gain_from_track ();
void solo_changed(bool, void*);
void solo_changed_so_update_mute ();
- void mute_changed(void*);
void listen_changed(void*);
virtual void processors_changed (ARDOUR::RouteProcessorChange) {}
void route_rec_enable_changed();
void solo_isolated_toggle (void*, Gtk::CheckMenuItem*);
void toggle_solo_isolated (Gtk::CheckMenuItem*);
- bool solo_isolate_button_release (GdkEventButton*);
- bool solo_safe_button_release (GdkEventButton*);
+ bool solo_isolate_button_release (GdkEventButton*);
+ bool solo_safe_button_release (GdkEventButton*);
void solo_safe_toggle (void*, Gtk::CheckMenuItem*);
void toggle_solo_safe (Gtk::CheckMenuItem*);
int set_color_from_route ();
- void remove_this_route ();
- static gint idle_remove_this_route (RouteUI *);
-
void route_rename();
- virtual void property_changed (const PBD::PropertyChange&);
+ void manage_pins ();
+ void maybe_add_route_print_mgr ();
+ void fan_out (bool to_busses = true, bool group = true);
+
+ virtual void route_property_changed (const PBD::PropertyChange&) = 0;
void route_removed ();
- Gtk::CheckMenuItem *route_active_menu_item;
- void toggle_route_active ();
- virtual void route_active_changed ();
+ virtual void route_active_changed () {}
+ void set_route_active (bool, bool);
+ void duplicate_selected_routes ();
- Gtk::Menu* record_menu;
- void build_record_menu ();
+ Gtk::Menu* record_menu;
+ void build_record_menu ();
Gtk::CheckMenuItem *step_edit_item;
void toggle_step_edit ();
virtual void step_edit_changed (bool);
-
+
+ Gtk::CheckMenuItem *rec_safe_item;
+ void toggle_rec_safe ();
+
virtual void polarity_changed ();
Gtk::CheckMenuItem *denormal_menu_item;
void disconnect_input ();
void disconnect_output ();
- virtual void update_rec_display ();
+ virtual void blink_rec_display (bool onoff);
void update_mute_display ();
void update_solo_display ();
virtual void map_frozen ();
void adjust_latency ();
+ bool process_save_template_prompter (ArdourWidgets::Prompter& prompter, const std::string& dir);
void save_as_template ();
- void open_remote_control_id_dialog ();
- static int solo_visual_state (boost::shared_ptr<ARDOUR::Route>);
- static int solo_visual_state_with_isolate (boost::shared_ptr<ARDOUR::Route>);
- static int solo_isolate_visual_state (boost::shared_ptr<ARDOUR::Route>);
- static int solo_safe_visual_state (boost::shared_ptr<ARDOUR::Route>);
- static int mute_visual_state (ARDOUR::Session*, boost::shared_ptr<ARDOUR::Route>);
+ static Gtkmm2ext::ActiveState solo_active_state (boost::shared_ptr<ARDOUR::Stripable>);
+ static Gtkmm2ext::ActiveState solo_isolate_active_state (boost::shared_ptr<ARDOUR::Stripable>);
+ static Gtkmm2ext::ActiveState solo_safe_active_state (boost::shared_ptr<ARDOUR::Stripable>);
+ static Gtkmm2ext::ActiveState mute_active_state (ARDOUR::Session*, boost::shared_ptr<ARDOUR::Stripable>);
+
+ /** Emitted when a bus has been set or unset from `display sends to this bus' mode
+ * by a click on the `Sends' button. The parameter is the route that the sends are
+ * to, or 0 if no route is now in this mode.
+ */
+ static PBD::Signal1<void, boost::shared_ptr<ARDOUR::Route> > BusSendDisplayChanged;
+
+ void comment_editor_done_editing ();
+ void setup_comment_editor ();
+ void open_comment_editor ();
+ void toggle_comment_editor ();
+
+ gint comment_key_release_handler (GdkEventKey*);
+ void comment_changed ();
+ void comment_edited ();
+ bool ignore_comment_edit;
+
+protected:
+
+ ArdourWindow* comment_window;
+ Gtk::TextView* comment_area;
+ IOSelectorWindow *input_selector;
+ IOSelectorWindow *output_selector;
- protected:
PBD::ScopedConnectionList route_connections;
bool self_destruct;
- void init ();
- void reset ();
+ void init ();
+ void reset ();
void self_delete ();
- virtual void start_step_editing () {}
- virtual void stop_step_editing() {}
+ virtual void start_step_editing () {}
+ virtual void stop_step_editing() {}
+
+ void set_invert_sensitive (bool);
+ bool verify_new_route_name (const std::string& name);
- void set_invert_sensitive (bool);
+ void route_gui_changed (PBD::PropertyChange const&);
+ virtual void route_color_changed () {}
- private:
void check_rec_enable_sensitivity ();
- void parameter_changed (std::string const &);
+
+ virtual void bus_send_display_changed (boost::shared_ptr<ARDOUR::Route>);
+
+ static std::string program_port_prefix;
+
+ bool mark_hidden (bool yn);
+
+private:
+ void parameter_changed (std::string const&);
void relabel_solo_button ();
+ void track_mode_changed ();
+
+ std::string route_state_id () const;
+protected:
struct SoloMuteRelease {
- SoloMuteRelease (bool was_active)
- : active (was_active)
- , exclusive (false) {}
-
- boost::shared_ptr<ARDOUR::RouteList> routes;
- boost::shared_ptr<ARDOUR::RouteList> routes_on;
- boost::shared_ptr<ARDOUR::RouteList> routes_off;
- boost::shared_ptr<ARDOUR::Route> route;
- bool active;
- bool exclusive;
+ SoloMuteRelease (bool was_active)
+ : active (was_active)
+ , exclusive (false)
+ {}
+
+ boost::shared_ptr<ARDOUR::RouteList> routes;
+ boost::shared_ptr<ARDOUR::RouteList> routes_on;
+ boost::shared_ptr<ARDOUR::RouteList> routes_off;
+ boost::shared_ptr<ARDOUR::Route> route;
+ bool active;
+ bool exclusive;
};
SoloMuteRelease* _solo_release;
SoloMuteRelease* _mute_release;
+ ControlSlaveUI* csu;
+
+private:
void setup_invert_buttons ();
void set_invert_button_state ();
- void invert_toggled (uint32_t, BindableToggleButton *);
void invert_menu_toggled (uint32_t);
bool invert_press (GdkEventButton *);
-
+ bool invert_release (GdkEventButton *, uint32_t i);
+
int _i_am_the_modifier;
- std::list<BindableToggleButton*> _invert_buttons;
+ std::vector<ArdourWidgets::ArdourButton*> _invert_buttons;
Gtk::Menu* _invert_menu;
+ StripableColorDialog _color_picker;
+
+ static void set_showing_sends_to (boost::shared_ptr<ARDOUR::Route>);
+ static boost::weak_ptr<ARDOUR::Route> _showing_sends_to;
+
static uint32_t _max_invert_buttons;
};