X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fmeter_strip.h;h=0e7232537de172bb733a237d307787c2b9e95555;hb=3099d99e0b9c12c500507cc2e3e14015c7364823;hp=e817f7d5c616e3ec057420ee71bf1307555f8dae;hpb=47ec32fa15c0528e463e5dc553f040b043ab8245;p=ardour.git diff --git a/gtk2_ardour/meter_strip.h b/gtk2_ardour/meter_strip.h index e817f7d5c6..0e7232537d 100644 --- a/gtk2_ardour/meter_strip.h +++ b/gtk2_ardour/meter_strip.h @@ -43,13 +43,18 @@ namespace Gtk { class Style; } -class MeterStrip : public Gtk::VBox, public RouteUI +class MeterStrip : public Gtk::VBox, public AxisView, public RouteUI { public: MeterStrip (ARDOUR::Session*, boost::shared_ptr); MeterStrip (int, ARDOUR::MeterType); ~MeterStrip (); + std::string name() const; + Gdk::Color color () const; + + boost::shared_ptr stripable() const { return RouteUI::stripable(); } + void set_session (ARDOUR::Session* s); void fast_update (); boost::shared_ptr route() { return _route; } @@ -72,9 +77,11 @@ class MeterStrip : public Gtk::VBox, public RouteUI bool is_metric_display() { return _strip_type == 0; } ARDOUR::MeterType meter_type(); + bool selected() const { return false; } + protected: boost::shared_ptr _route; - PBD::ScopedConnectionList route_connections; + PBD::ScopedConnectionList meter_route_connections; PBD::ScopedConnectionList level_meter_connection; void self_delete (); @@ -88,7 +95,7 @@ class MeterStrip : public Gtk::VBox, public RouteUI void on_size_request (Gtk::Requisition*); /* route UI */ - void update_rec_display (); + void blink_rec_display (bool onoff); std::string state_id() const; void set_button_names (); @@ -100,7 +107,9 @@ class MeterStrip : public Gtk::VBox, public RouteUI Gtk::HBox meterbox; Gtk::HBox spacer; Gtk::HBox namebx; + Gtk::VBox namenumberbx; ArdourButton name_label; + ArdourButton number_label; Gtk::DrawingArea meter_metric_area; Gtk::DrawingArea meter_ticks1_area; Gtk::DrawingArea meter_ticks2_area; @@ -108,6 +117,8 @@ class MeterStrip : public Gtk::VBox, public RouteUI Gtk::HBox mutebox; Gtk::HBox solobox; Gtk::HBox recbox; + Gtk::HBox mon_in_box; + Gtk::HBox mon_disk_box; Gtk::Alignment meter_align; Gtk::Alignment peak_align; @@ -126,8 +137,7 @@ class MeterStrip : public Gtk::VBox, public RouteUI LevelMeterHBox *level_meter; - PBD::ScopedConnection _config_connection; - void strip_property_changed (const PBD::PropertyChange&); + void route_property_changed (const PBD::PropertyChange&); void meter_configuration_changed (ARDOUR::ChanCount); void meter_type_changed (ARDOUR::MeterType); void update_background (ARDOUR::MeterType); @@ -138,9 +148,12 @@ class MeterStrip : public Gtk::VBox, public RouteUI void redraw_metrics (); void update_button_box (); void update_name_box (); + void name_changed (); + + void route_color_changed (); bool _suspend_menu_callbacks; - bool level_meter_button_release (GdkEventButton* ev); + bool level_meter_button_press (GdkEventButton* ev); void popup_level_meter_menu (GdkEventButton* ev); void add_level_meter_type_item (Gtk::Menu_Helpers::MenuList&, Gtk::RadioMenuItem::Group&, std::string const &, ARDOUR::MeterType);