along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
- $Id$
*/
#ifndef __ardour_route_ui__
#include <pbd/xml++.h>
#include <ardour/ardour.h>
#include <ardour/route.h>
+#include <ardour/track.h>
#include "axis_view.h"
-namespace Gtkmm2ext {
- class BindableToggleButton;
-}
-
namespace ARDOUR {
class AudioTrack;
+ class MidiTrack;
}
namespace Gtk {
class Widget;
}
+class BindableToggleButton;
+
class RouteUI : public virtual AxisView
{
public:
- RouteUI(ARDOUR::Route&, ARDOUR::Session&, const char*, const char*, const char*);
+ RouteUI(ARDOUR::Session&, const char*, const char*, const char*);
+ RouteUI(boost::shared_ptr<ARDOUR::Route>, ARDOUR::Session&, const char*, const char*, const char*);
+
virtual ~RouteUI();
+ virtual void set_route (boost::shared_ptr<ARDOUR::Route>);
+ void set_button_names (const char*, const char*, const char*);
+
+ bool is_track() const;
bool is_audio_track() const;
- ARDOUR::DiskStream* get_diskstream() const;
+ bool is_midi_track() const;
- ARDOUR::Route& route() const { return _route; }
- ARDOUR::AudioTrack* audio_track() const;
+ boost::shared_ptr<ARDOUR::Route> route() const { return _route; }
+
+ boost::shared_ptr<ARDOUR::Track> track() const;
+ boost::shared_ptr<ARDOUR::AudioTrack> audio_track() const;
+ boost::shared_ptr<ARDOUR::MidiTrack> midi_track() const;
+
+ boost::shared_ptr<ARDOUR::Diskstream> get_diskstream() const;
string name() const;
+
+ // protected: XXX sigh this should be here
+
+ boost::shared_ptr<ARDOUR::Route> _route;
- ARDOUR::Route& _route;
-
- void set_color (Gdk::Color c);
+ void set_color (const Gdk::Color & c);
bool choose_color ();
bool ignore_toggle;
bool wait_for_release;
+ bool multiple_mute_change;
+ bool multiple_solo_change;
- Gtkmm2ext::BindableToggleButton * mute_button;
- Gtkmm2ext::BindableToggleButton * solo_button;
- Gtkmm2ext::BindableToggleButton * rec_enable_button;
+ BindableToggleButton* mute_button;
+ BindableToggleButton* solo_button;
+ BindableToggleButton* rec_enable_button;
virtual string solo_button_name () const { return "SoloButton"; }
virtual string safe_solo_button_name () const { return "SafeSoloButton"; }
Gtk::Menu* mute_menu;
Gtk::Menu* solo_menu;
+ Gtk::Menu* remote_control_menu;
XMLNode *xml_node;
void ensure_xml_node ();
- XMLNode* get_child_xml_node (std::string childname);
+ virtual XMLNode* get_automation_child_xml_node (Evoral::Parameter param);
- gint mute_press(GdkEventButton*);
- gint mute_release(GdkEventButton*);
- gint solo_press(GdkEventButton*);
- gint solo_release(GdkEventButton*);
- gint rec_enable_press(GdkEventButton*);
+ bool mute_press(GdkEventButton*);
+ bool mute_release(GdkEventButton*);
+ bool solo_press(GdkEventButton*);
+ bool solo_release(GdkEventButton*);
+ bool rec_enable_press(GdkEventButton*);
+ bool rec_enable_release(GdkEventButton*);
void solo_changed(void*);
+ void solo_changed_so_update_mute ();
void mute_changed(void*);
- void route_rec_enable_changed(void*);
+ virtual void processors_changed () {}
+ void route_rec_enable_changed();
void session_rec_enable_changed();
void build_solo_menu (void);
+ void build_remote_control_menu (void);
+ void refresh_remote_control_menu ();
void solo_safe_toggle (void*, Gtk::CheckMenuItem*);
void toggle_solo_safe (Gtk::CheckMenuItem*);
void build_mute_menu(void);
void init_mute_menu(ARDOUR::mute_type, Gtk::CheckMenuItem*);
- void set_mix_group_solo(ARDOUR::Route&, bool);
- void set_mix_group_mute(ARDOUR::Route&, bool);
- void set_mix_group_rec_enable(ARDOUR::Route&, bool);
+ void set_mix_group_solo(boost::shared_ptr<ARDOUR::Route>, bool);
+ void set_mix_group_mute(boost::shared_ptr<ARDOUR::Route>, bool);
+ void set_mix_group_rec_enable(boost::shared_ptr<ARDOUR::Route>, bool);
int set_color_from_route ();
- sigc::connection blink_connection;
-
- void rec_enable_button_blink (bool onoff, ARDOUR::DiskStream *, Gtk::Widget *w);
-
void remove_this_route ();
static gint idle_remove_this_route (RouteUI *);
void route_rename();
- virtual void name_changed (void *src);
+ virtual void name_changed ();
void route_removed ();
- static gint okay_gplusplus_cannot_do_complex_templates (RouteUI *rui);
-
Gtk::CheckMenuItem *route_active_menu_item;
void toggle_route_active ();
virtual void route_active_changed ();
+ Gtk::CheckMenuItem *polarity_menu_item;
+ void toggle_polarity ();
+ virtual void polarity_changed ();
+
+ Gtk::CheckMenuItem *denormal_menu_item;
+ void toggle_denormal_protection();
+ virtual void denormal_protection_changed ();
+
void disconnect_input ();
void disconnect_output ();
- void update_rec_display ();
+ virtual void update_rec_display ();
void update_mute_display ();
+
+ bool was_solo_safe;
void update_solo_display ();
+
virtual void map_frozen ();
+ void set_remote_control_id (uint32_t id, Gtk::CheckMenuItem* item);
+
void reversibly_apply_route_boolean (string name, void (ARDOUR::Route::*func)(bool, void*), bool, void *);
- void reversibly_apply_audio_track_boolean (string name, void (ARDOUR::AudioTrack::*func)(bool, void*), bool, void *);
+ void reversibly_apply_track_boolean (string name, void (ARDOUR::Track::*func)(bool, void*), bool, void *);
+
+ void adjust_latency ();
+
+ protected:
+ std::vector<sigc::connection> connections;
+ std::string s_name;
+ std::string m_name;
+ std::string r_name;
+
+ void init ();
+ void reset ();
};
#endif /* __ardour_route_ui__ */