level_meter = 0;
_strip_type = 0;
_tick_bar = 0;
+ _metricmode = -1;
+ metric_type = MeterPeak;
mtr_vbox.set_spacing(2);
nfo_vbox.set_spacing(2);
peakbx.set_size_request(-1, 14);
_has_midi = false;
_tick_bar = 0;
+ _metricmode = -1;
+ metric_type = MeterPeak;
int meter_width = 6;
if (_route->shared_peak_meter()->input_streams().n_total() == 1) {
namebx.set_size_request(18, 52);
namebx.pack_start(name_label, true, false, 3);
+ mon_in_box.pack_start(*monitor_input_button, true, false);
+ btnbox.pack_start(mon_in_box, false, false, 1);
+ mon_disk_box.pack_start(*monitor_disk_button, true, false);
+ btnbox.pack_start(mon_disk_box, false, false, 1);
+
recbox.pack_start(*rec_enable_button, true, false);
btnbox.pack_start(recbox, false, false, 1);
mutebox.pack_start(*mute_button, true, false);
solo_button->set_corner_radius(2);
solo_button->set_size_request(16, 16);
+ monitor_input_button->set_corner_radius(2);
+ monitor_input_button->set_size_request(16, 16);
+
+ monitor_disk_button->set_corner_radius(2);
+ monitor_disk_button->set_size_request(16, 16);
+
mutebox.set_size_request(16, 16);
solobox.set_size_request(16, 16);
recbox.set_size_request(16, 16);
+ mon_in_box.set_size_request(16, 16);
+ mon_disk_box.set_size_request(16, 16);
spacer.set_size_request(-1,0);
update_button_box();
mtr_container.show();
mtr_hsep.show();
nfo_vbox.show();
+ monitor_input_button->show();
+ monitor_disk_button->show();
_route->shared_peak_meter()->ConfigurationChanged.connect (
route_connections, invalidator (*this), boost::bind (&MeterStrip::meter_configuration_changed, this, _1), gui_context()
MeterStrip::~MeterStrip ()
{
- delete level_meter;
- CatchDeletion (this);
+ if (level_meter) {
+ delete level_meter;
+ CatchDeletion (this);
+ }
}
void
}
}
+ monitor_input_button->set_text (_("I"));
+ monitor_disk_button->set_text (_("D"));
}
void
nh = 52;
break;
case 2:
- nh = 106;
+ nh = 88;
break;
case 3:
- nh = 148;
+ nh = 106;
break;
case 4:
- nh = 254;
+ nh = 148;
break;
}
namebx.set_size_request(18, nh);
case MeterIEC1NOR:
case MeterIEC2BBC:
case MeterIEC2EBU:
+ case MeterK12:
case MeterK14:
case MeterK20:
mtr_container.set_name ("meterstripPPM");
} else {
recbox.hide();
}
+ if (_session->config.get_show_monitor_on_meterbridge()) {
+ height += 18 + 18;
+ mon_in_box.show();
+ mon_disk_box.show();
+ } else {
+ mon_in_box.hide();
+ mon_disk_box.hide();
+ }
btnbox.set_size_request(16, height);
check_resize();
}
else if (p == "show-name-on-meterbridge") {
update_name_box();
}
+ else if (p == "show-monitor-on-meterbridge") {
+ update_button_box();
+ }
else if (p == "meterbridge-label-height") {
queue_resize();
}
add_level_meter_type_item (items, group, ArdourMeter::meter_type_string(MeterIEC2EBU), MeterIEC2EBU);
add_level_meter_type_item (items, group, ArdourMeter::meter_type_string(MeterK20), MeterK20);
add_level_meter_type_item (items, group, ArdourMeter::meter_type_string(MeterK14), MeterK14);
+ add_level_meter_type_item (items, group, ArdourMeter::meter_type_string(MeterK12), MeterK12);
add_level_meter_type_item (items, group, ArdourMeter::meter_type_string(MeterVU), MeterVU);
MeterType cmt = _route->meter_type();