From 917e3522d0038055339397f69f5467fb034eb955 Mon Sep 17 00:00:00 2001 From: Robin Gareus Date: Fri, 28 Jun 2013 23:09:39 +0200 Subject: [PATCH] meterbridge: add rec-enable btn & prepare metric/tick separation --- gtk2_ardour/meter_strip.cc | 30 +++++++++++++++++++++++++++++- gtk2_ardour/meter_strip.h | 14 +++++++++++++- 2 files changed, 42 insertions(+), 2 deletions(-) diff --git a/gtk2_ardour/meter_strip.cc b/gtk2_ardour/meter_strip.cc index f1bd5bee89..77217bdd57 100644 --- a/gtk2_ardour/meter_strip.cc +++ b/gtk2_ardour/meter_strip.cc @@ -51,12 +51,16 @@ using namespace std; PBD::Signal1 MeterStrip::CatchDeletion; MeterStrip::MetricPatterns MeterStrip::metric_patterns; +MeterStrip::TickPatterns MeterStrip::tick_patterns; MeterStrip::MeterStrip (Meterbridge& mtr, Session* sess, boost::shared_ptr rt) - : _route(rt) + : AxisView(sess) + , RouteUI(sess) + , _route(rt) , style_changed (false) { set_spacing(2); + RouteUI::set_route (rt); int meter_width = 6; if (_route->shared_peak_meter()->input_streams().n_total() == 1) { @@ -91,12 +95,18 @@ MeterStrip::MeterStrip (Meterbridge& mtr, Session* sess, boost::shared_ptrpack_start(*rec_enable_button, true, false); + btnbox->set_size_request(-1, 16); + pack_start(*meter_align, true, true); + pack_start (*btnbox, false, false); pack_start (label, false, false); meter_metric_area.show(); level_meter->show(); meter_align->show(); + btnbox->show(); label.show(); _route->shared_peak_meter()->ConfigurationChanged.connect ( @@ -126,6 +136,24 @@ MeterStrip::self_delete () delete this; } +void +MeterStrip::update_rec_display () +{ + RouteUI::update_rec_display (); +} + +std::string +MeterStrip::state_id() const +{ + return string_compose ("mtrs %1", _route->id().to_s()); +} + +void +MeterStrip::set_button_names() +{ + rec_enable_button->set_text (_("R")); +} + void MeterStrip::strip_property_changed (const PropertyChange& what_changed) { diff --git a/gtk2_ardour/meter_strip.h b/gtk2_ardour/meter_strip.h index a431f6b49b..a96840ed6c 100644 --- a/gtk2_ardour/meter_strip.h +++ b/gtk2_ardour/meter_strip.h @@ -28,6 +28,7 @@ #include "ardour/types.h" #include "ardour/ardour.h" +#include "route_ui.h" #include "level_meter.h" @@ -42,7 +43,7 @@ namespace Gtk { class Meterbridge; -class MeterStrip : public Gtk::VBox +class MeterStrip : public Gtk::VBox, public RouteUI { public: MeterStrip (Meterbridge&, ARDOUR::Session*, boost::shared_ptr); @@ -63,6 +64,10 @@ class MeterStrip : public Gtk::VBox typedef std::map MetricPatterns; static MetricPatterns metric_patterns; + + typedef std::map TickPatterns; + static TickPatterns tick_patterns; + static cairo_pattern_t* render_metrics (Gtk::Widget &, std::vector); void on_theme_changed (); @@ -71,9 +76,16 @@ class MeterStrip : public Gtk::VBox void on_size_allocate (Gtk::Allocation&); void on_size_request (Gtk::Requisition*); + /* route UI */ + void update_rec_display (); + std::string state_id() const; + void set_button_names (); + private: + Gtk::HBox meterbox; Gtk::Label label; Gtk::DrawingArea meter_metric_area; + Gtk::DrawingArea meter_tick_area; std::vector _types; LevelMeter *level_meter;