diff options
author | Paul Davis <paul@linuxaudiosystems.com> | 2010-05-06 01:31:48 +0000 |
---|---|---|
committer | Paul Davis <paul@linuxaudiosystems.com> | 2010-05-06 01:31:48 +0000 |
commit | c52a0d1efc8cc6c506f9f224df980a2416818552 (patch) | |
tree | ec2809dd1238aa8c3f17d46c126967625cb9a2d4 | |
parent | 8c423ea2284289a59e1cd549e7661114fa978ec8 (diff) |
relayout solo led stuff, as per the boss' requests :)
git-svn-id: svn://localhost/ardour2/branches/3.0@7069 d708f5d6-7413-0410-9779-e7cbd77b26cf
-rw-r--r-- | gtk2_ardour/ardour3_ui_dark.rc.in | 8 | ||||
-rw-r--r-- | gtk2_ardour/led.cc | 58 | ||||
-rw-r--r-- | gtk2_ardour/led.h | 4 | ||||
-rw-r--r-- | gtk2_ardour/mixer_strip.cc | 38 | ||||
-rw-r--r-- | gtk2_ardour/mixer_strip.h | 2 |
5 files changed, 91 insertions, 19 deletions
diff --git a/gtk2_ardour/ardour3_ui_dark.rc.in b/gtk2_ardour/ardour3_ui_dark.rc.in index 87dab6f39c..1c1fdd520c 100644 --- a/gtk2_ardour/ardour3_ui_dark.rc.in +++ b/gtk2_ardour/ardour3_ui_dark.rc.in @@ -2,6 +2,11 @@ # This is the GTK style file for Ardour # +style "smallest_text" +{ + font_name = "@FONT_TINY@" +} + style "very_small_text" { font_name = "@FONT_SMALLER@" @@ -328,7 +333,7 @@ style "solo_button" = "small_button" style "solo_isolate_led" { fg[ACTIVE] = { 1.0, 0, 0 } - fg[NORMAL] = { 1, 1, 1 } + fg[NORMAL] = { 0, 1.0, 0 } } style "solo_safe_led" @@ -1801,3 +1806,4 @@ widget "*PortMatrixLabel*" style:highest "small_text" widget "*MidiTracerTextView" style:highest "midi_tracer_textview" widget "*SoloIsolatedLED" style:highest "solo_isolate_led" widget "*SoloSafeLED" style:highest "solo_safe_led" +widget "*SoloLEDLabel" style:highest "smallest_text" diff --git a/gtk2_ardour/led.cc b/gtk2_ardour/led.cc index c751eb91e0..e1a98da228 100644 --- a/gtk2_ardour/led.cc +++ b/gtk2_ardour/led.cc @@ -30,6 +30,8 @@ using namespace Glib; LED::LED() : _visual_state (0) , _active (false) + , _diameter (0.0) + , _fixed_diameter (false) , _red (0.0) , _green (1.0) , _blue (0.0) @@ -44,49 +46,64 @@ LED::~LED() void LED::render (cairo_t* cr) { - float diameter = std::min (_width, _height); + if (!_fixed_diameter) { + _diameter = std::min (_width, _height); + } //background + + RefPtr<Style> style = get_style(); + Color c; + + switch (_visual_state) { + case 0: + c = style->get_bg (STATE_NORMAL); + break; + default: + c = style->get_bg (STATE_ACTIVE); + break; + } + cairo_rectangle(cr, 0, 0, _width, _height); cairo_stroke_preserve(cr); - cairo_set_source_rgb(cr, 0, 0, 0); + cairo_set_source_rgb(cr, c.get_green_p(), c.get_red_p(), c.get_blue_p()); cairo_fill(cr); cairo_translate(cr, _width/2, _height/2); #if 0 //inset - cairo_pattern_t *pat = cairo_pattern_create_linear (0.0, 0.0, 0.0, diameter); + cairo_pattern_t *pat = cairo_pattern_create_linear (0.0, 0.0, 0.0, _diameter); cairo_pattern_add_color_stop_rgba (pat, 0, 0,0,0, 0.4); cairo_pattern_add_color_stop_rgba (pat, 1, 1,1,1, 0.7); - cairo_arc (cr, 0, 0, diameter/2, 0, 2 * M_PI); + cairo_arc (cr, 0, 0, _diameter/2, 0, 2 * M_PI); cairo_set_source (cr, pat); cairo_fill (cr); cairo_pattern_destroy (pat); //black ring cairo_set_source_rgb (cr, 0, 0, 0); - cairo_arc (cr, 0, 0, diameter/2-2, 0, 2 * M_PI); + cairo_arc (cr, 0, 0, _diameter/2-2, 0, 2 * M_PI); cairo_fill(cr); //knob color cairo_set_source_rgba (cr, _red, _green, _blue, _active ? 0.8 : 0.2); - cairo_arc (cr, 0, 0, diameter/2-3, 0, 2 * M_PI); + cairo_arc (cr, 0, 0, _diameter/2-3, 0, 2 * M_PI); cairo_fill(cr); //reflection cairo_scale(cr, 0.7, 0.7); - cairo_pattern_t *pat2 = cairo_pattern_create_linear (0.0, 0.0, 0.0, diameter/2-3); + cairo_pattern_t *pat2 = cairo_pattern_create_linear (0.0, 0.0, 0.0, _diameter/2-3); cairo_pattern_add_color_stop_rgba (pat2, 0, 1,1,1, _active ? 0.4 : 0.2); cairo_pattern_add_color_stop_rgba (pat2, 1, 1,1,1, 0.0); - cairo_arc (cr, 0, 0, diameter/2-3, 0, 2 * M_PI); + cairo_arc (cr, 0, 0, _diameter/2-3, 0, 2 * M_PI); cairo_set_source (cr, pat2); cairo_fill (cr); cairo_pattern_destroy (pat2); #endif cairo_set_source_rgba (cr, _red, _green, _blue, 1.0); - cairo_arc (cr, 0, 0, diameter/2-5, 0, 2 * M_PI); + cairo_arc (cr, 0, 0, _diameter/2-5, 0, 2 * M_PI); cairo_fill(cr); cairo_stroke (cr); @@ -118,3 +135,26 @@ LED::set_visual_state (int32_t s) set_dirty (); } } + +void +LED::set_diameter (float d) +{ + _diameter = (d*2) + 5.0; + + if (_diameter != 0.0) { + _fixed_diameter = true; + } + + set_dirty (); +} + +void +LED::on_size_request (Gtk::Requisition* req) +{ + if (_fixed_diameter) { + req->width = _diameter; + req->height = _diameter; + } else { + CairoWidget::on_size_request (req); + } +} diff --git a/gtk2_ardour/led.h b/gtk2_ardour/led.h index 69ff7a3ead..6350a36ba3 100644 --- a/gtk2_ardour/led.h +++ b/gtk2_ardour/led.h @@ -32,13 +32,17 @@ class LED : public CairoWidget void set_visual_state (int32_t s); int32_t visual_state() const { return _visual_state; } + void set_diameter (float); protected: void render (cairo_t *); + void on_size_request (Gtk::Requisition* req); private: int32_t _visual_state; bool _active; + float _diameter; + bool _fixed_diameter; float _red; float _green; float _blue; diff --git a/gtk2_ardour/mixer_strip.cc b/gtk2_ardour/mixer_strip.cc index 8bcb1ca0b9..df9fc36084 100644 --- a/gtk2_ardour/mixer_strip.cc +++ b/gtk2_ardour/mixer_strip.cc @@ -85,7 +85,8 @@ MixerStrip::MixerStrip (Mixer_UI& mx, Session* sess, bool in_mixer) , panners (sess) , _mono_button (_("Mono")) , button_table (4, 2) - , middle_button_table (2, 2) + , solo_led_table (2, 2) + , middle_button_table (1, 2) , bottom_button_table (1, 2) , meter_point_label (_("pre")) , comment_button (_("Comments")) @@ -187,6 +188,7 @@ MixerStrip::init () solo_isolated_led = manage (new LED); solo_isolated_led->show (); + solo_isolated_led->set_diameter (5); solo_isolated_led->set_no_show_all (true); solo_isolated_led->set_name (X_("SoloIsolatedLED")); solo_isolated_led->add_events (Gdk::BUTTON_PRESS_MASK|Gdk::BUTTON_RELEASE_MASK); @@ -195,12 +197,33 @@ MixerStrip::init () solo_safe_led = manage (new LED); solo_safe_led->show (); + solo_safe_led->set_diameter (5); solo_safe_led->set_no_show_all (true); solo_safe_led->set_name (X_("SoloSafeLED")); solo_safe_led->add_events (Gdk::BUTTON_PRESS_MASK|Gdk::BUTTON_RELEASE_MASK); solo_safe_led->signal_button_release_event().connect (sigc::mem_fun (*this, &RouteUI::solo_safe_button_release)); UI::instance()->set_tip (solo_safe_led, _("Lock Solo Status"), ""); + Label* iso_label = manage (new Label (_("iso"))); + Label* safe_label = manage (new Label (_("lock"))); + + iso_label->set_name (X_("SoloLEDLabel")); + safe_label->set_name (X_("SoloLEDLabel")); + + iso_label->show (); + safe_label->show (); + + solo_led_table.set_spacings (0); + solo_led_table.set_border_width (1); + solo_led_table.attach (*solo_isolated_led, 0, 1, 0, 1, Gtk::FILL, Gtk::FILL); + solo_led_table.attach (*iso_label, 1, 2, 0, 1, Gtk::FILL, Gtk::FILL); + solo_led_table.attach (*solo_safe_led, 0, 1, 1, 2, Gtk::FILL, Gtk::FILL); + solo_led_table.attach (*safe_label, 1, 2, 1, 2, Gtk::FILL, Gtk::FILL); + + solo_led_table.show (); + solo_led_box.pack_end (solo_led_table, false, false); + solo_led_box.show (); + button_table.set_homogeneous (true); button_table.set_spacings (0); @@ -210,10 +233,8 @@ MixerStrip::init () middle_button_table.set_homogeneous (true); middle_button_table.set_spacings (0); - middle_button_table.attach (*solo_safe_led, 0, 1, 0, 1); - middle_button_table.attach (*solo_isolated_led, 1, 2, 0, 1); - middle_button_table.attach (*mute_button, 0, 1, 1, 2); - middle_button_table.attach (*solo_button, 1, 2, 1, 2); + middle_button_table.attach (*mute_button, 0, 1, 0, 1); + middle_button_table.attach (*solo_button, 1, 2, 0, 1); bottom_button_table.set_col_spacings (0); bottom_button_table.set_homogeneous (true); @@ -255,6 +276,7 @@ MixerStrip::init () global_vpacker.pack_start (whvbox, Gtk::PACK_SHRINK); global_vpacker.pack_start (button_table,Gtk::PACK_SHRINK); global_vpacker.pack_start (processor_box, true, true); + global_vpacker.pack_start (solo_led_box,Gtk::PACK_SHRINK); global_vpacker.pack_start (middle_button_table,Gtk::PACK_SHRINK); global_vpacker.pack_start (gain_meter_alignment,Gtk::PACK_SHRINK); global_vpacker.pack_start (bottom_button_table,Gtk::PACK_SHRINK); @@ -365,12 +387,10 @@ MixerStrip::set_route (boost::shared_ptr<Route> rt) if (route()->is_master()) { solo_button->hide (); - solo_isolated_led->hide (); - solo_safe_led->hide (); + solo_led_box.hide (); } else { solo_button->show (); - solo_isolated_led->show (); - solo_safe_led->show (); + solo_led_box.show (); } if (_mixer_owned && (route()->is_master() || route()->is_monitor())) { diff --git a/gtk2_ardour/mixer_strip.h b/gtk2_ardour/mixer_strip.h index 93bd5fd371..0d3878fc20 100644 --- a/gtk2_ardour/mixer_strip.h +++ b/gtk2_ardour/mixer_strip.h @@ -148,6 +148,8 @@ class MixerStrip : public RouteUI, public Gtk::EventBox Gtk::ToggleButton _mono_button; Gtk::Table button_table; + Gtk::Table solo_led_table; + Gtk::HBox solo_led_box; Gtk::Table middle_button_table; Gtk::Table bottom_button_table; |