#include <limits.h>
#include "ardour/amp.h"
+#include "ardour/logmeter.h"
#include "ardour/route_group.h"
#include "ardour/session_route.h"
#include "ardour/dB.h"
#include "pbd/stacktrace.h"
#include "gain_meter.h"
-#include "logmeter.h"
#include "gui_thread.h"
#include "keyboard.h"
#include "public_editor.h"
#include "ardour/midi_track.h"
#include "ardour/dB.h"
-#include "i18n.h"
+#include "pbd/i18n.h"
using namespace ARDOUR;
using namespace ARDOUR_UI_UTILS;
dB_coeff_step(Config->get_max_gain())) // page increment
, gain_automation_style_button ("")
, gain_automation_state_button ("")
+ , meter_point_button (_("pre"))
, gain_astate_propagate (false)
, _data_type (DataType::AUDIO)
{
gain_display.signal_activate().connect (sigc::mem_fun (*this, &GainMeter::gain_activated));
gain_display.signal_focus_in_event().connect (sigc::mem_fun (*this, &GainMeter::gain_focused), false);
gain_display.signal_focus_out_event().connect (sigc::mem_fun (*this, &GainMeter::gain_focused), false);
- gain_display.set_alignment(0.5);
+ gain_display.set_alignment (0.5);
peak_display.set_name ("MixerStripPeakDisplay");
set_size_request_to_display_given_text (peak_display, "-80.g", 2, 6); /* note the descender */
max_peak = minus_infinity();
peak_display.set_text (_("-inf"));
- peak_display.set_alignment(0.5);
+ peak_display.set_alignment (0.5);
/* stuff related to the fact that the peak display is not, in
fact, supposed to be a text entry.
gain_astyle_menu.items().push_back (MenuElem (_("Abs")));
gain_astate_menu.set_name ("ArdourContextMenu");
+ gain_astate_menu.set_reserve_toggle_size(false);
gain_astyle_menu.set_name ("ArdourContextMenu");
+ meter_point_button.set_name ("mixer strip button");
+
+ set_tooltip (&meter_point_button, _("Metering point"));
+
+ meter_point_button.unset_flags (Gtk::CAN_FOCUS);
+
+ meter_point_button.set_size_request(15, 15);
+
+ meter_point_menu.set_name ("ArdourContextMenu");
+ meter_point_menu.set_reserve_toggle_size(false);
+
+ meter_point_menu.items().clear ();
+ meter_point_menu.items().push_back (MenuElem(_("Input"),
+ sigc::bind (sigc::mem_fun (*this,
+ &GainMeterBase::meter_point_clicked), (MeterPoint) MeterInput)));
+ meter_point_menu.items().push_back (MenuElem(_("Pre Fader"),
+ sigc::bind (sigc::mem_fun (*this,
+ &GainMeterBase::meter_point_clicked), (MeterPoint) MeterPreFader)));
+ meter_point_menu.items().push_back (MenuElem(_("Post Fader"),
+ sigc::bind (sigc::mem_fun (*this,
+ &GainMeterBase::meter_point_clicked), (MeterPoint) MeterPostFader)));
+ meter_point_menu.items().push_back (MenuElem(_("Output"),
+ sigc::bind (sigc::mem_fun (*this,
+ &GainMeterBase::meter_point_clicked), (MeterPoint) MeterOutput)));
+ meter_point_menu.items().push_back (MenuElem(_("Custom"),
+ sigc::bind (sigc::mem_fun (*this,
+ &GainMeterBase::meter_point_clicked), (MeterPoint) MeterCustom)));
+ meter_point_button.signal_button_press_event().connect (sigc::mem_fun (*this, &GainMeter::meter_press), false);
+
gain_adjustment.signal_value_changed().connect (sigc::mem_fun(*this, &GainMeterBase::fader_moved));
peak_display.signal_button_release_event().connect (sigc::mem_fun(*this, &GainMeterBase::peak_button_release), false);
gain_display.signal_key_press_event().connect (sigc::mem_fun(*this, &GainMeterBase::gain_key_press), false);
void
GainMeterBase::set_type (MeterType t)
{
- level_meter->set_type(t);
+ level_meter->set_meter_type(t);
}
void
void
GainMeterBase::reset_peak_display ()
{
+ if (!_route) {
+ // catch "reset all" for VCAs
+ return;
+ }
_meter->reset_max();
level_meter->clear_meters();
- max_peak = -INFINITY;
+ max_peak = minus_infinity ();
peak_display.set_text (_("-inf"));
peak_display.set_name ("MixerStripPeakDisplay");
}
{
float f;
- {
- // Switch to user's preferred locale so that
- // if they use different LC_NUMERIC conventions,
- // we will honor them.
-
- PBD::LocaleGuard lg;
- if (sscanf (gain_display.get_text().c_str(), "%f", &f) != 1) {
- return;
- }
+ // Use the user's preferred locale/LC_NUMERIC setting
+ if (sscanf (gain_display.get_text().c_str(), "%f", &f) != 1) {
+ return;
}
/* clamp to displayable values */
value = gain_adjustment.get_value();
}
- _control->set_value (value, Controllable::UseGroup);
+ // XXX hack allow to override group
+ // (this breaks group'ed shift+click reset)
+ if (Keyboard::the_keyboard().key_is_down (GDK_Shift_R)
+ || Keyboard::the_keyboard().key_is_down (GDK_Shift_L)) {
+ _control->set_value (value, Controllable::NoGroup);
+ } else {
+ _control->set_value (value, Controllable::UseGroup);
+ }
}
show_gain ();
static_cast<Gtkmm2ext::SliderController*>(gain_slider)->set_sensitive (x);
}
-static MeterPoint
-next_meter_point (MeterPoint mp)
-{
- switch (mp) {
- case MeterInput:
- return MeterPreFader;
- break;
-
- case MeterPreFader:
- return MeterPostFader;
- break;
-
- case MeterPostFader:
- return MeterOutput;
- break;
-
- case MeterOutput:
- return MeterCustom;
- break;
-
- case MeterCustom:
- return MeterInput;
- break;
- }
-
- abort(); /*NOTREACHED*/
- return MeterInput;
-}
-
gint
GainMeterBase::meter_press(GdkEventButton* ev)
{
- wait_for_release = false;
-
if (!_route) {
- return FALSE;
+ return false;
}
-
if (!ignore_toggle) {
-
- if (Keyboard::is_context_menu_event (ev)) {
-
- // no menu at this time.
-
- } else {
-
- if (Keyboard::is_button2_event(ev)) {
-
- // Primary-button2 click is the midi binding click
- // button2-click is "momentary"
-
- if (!Keyboard::modifier_state_equals (ev->state, Keyboard::ModifierMask (Keyboard::PrimaryModifier))) {
- wait_for_release = true;
- old_meter_point = _route->meter_point ();
- }
- }
-
- if (_route && (ev->button == 1 || Keyboard::is_button2_event (ev))) {
-
+ switch (ev->button) {
+ case 1:
if (Keyboard::modifier_state_equals (ev->state, Keyboard::ModifierMask (Keyboard::PrimaryModifier|Keyboard::TertiaryModifier))) {
/* Primary+Tertiary-click applies change to all routes */
- _session->foreach_route (this, &GainMeterBase::set_meter_point, next_meter_point (_route->meter_point()));
-
+ meter_point_change_target = MeterPointChangeAll;
} else if (Keyboard::modifier_state_equals (ev->state, Keyboard::PrimaryModifier)) {
- /* Primary-click: solo mix group.
- NOTE: Primary-button2 is MIDI learn.
- */
+ /* Primary-click: apply change to all routes in group */
- if (ev->button == 1) {
- set_route_group_meter_point (*_route, next_meter_point (_route->meter_point()));
- }
+ meter_point_change_target = MeterPointChangeGroup;
} else {
/* click: change just this route */
- // XXX no undo yet
-
- _route->set_meter_point (next_meter_point (_route->meter_point()));
+ meter_point_change_target = MeterPointChangeSingle;
}
- }
+ Gtkmm2ext::anchored_menu_popup(&meter_point_menu,
+ &meter_point_button,
+ "", 1, ev->time);
+ break;
+ default:
+ break;
}
}
-
- return true;
-
-}
-
-gint
-GainMeterBase::meter_release(GdkEventButton*)
-{
- if (!ignore_toggle) {
- if (wait_for_release) {
- wait_for_release = false;
-
- if (_route) {
- set_meter_point (*_route, old_meter_point);
- }
- }
- }
-
return true;
}
}
void
-GainMeterBase::meter_point_clicked ()
+GainMeterBase::meter_point_clicked (MeterPoint mp)
{
if (_route) {
- /* WHAT? */
+ switch (meter_point_change_target) {
+ case MeterPointChangeAll:
+ _session->foreach_route (this, &GainMeterBase::set_meter_point, mp);
+ break;
+ case MeterPointChangeGroup:
+ set_route_group_meter_point (*_route, mp);
+ break;
+ case MeterPointChangeSingle:
+ _route->set_meter_point (mp);
+ break;
+ }
}
}
GainMeterBase::amp_stop_touch ()
{
_control->stop_touch (false, _control->session().transport_frame());
+ effective_gain_display ();
}
gint
switch (ev->button) {
case 1:
gain_astate_propagate = Keyboard::modifier_state_contains (ev->state, Keyboard::ModifierMask (Keyboard::PrimaryModifier | Keyboard::TertiaryModifier));
- gain_astate_menu.popup (1, ev->time);
+ Gtkmm2ext::anchored_menu_popup(&gain_astate_menu,
+ &gain_automation_state_button,
+ "", 1, ev->time);
break;
default:
break;