projects
/
ardour.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
distinguish global peak-reset button from meters:
[ardour.git]
/
gtk2_ardour
/
gain_meter.h
diff --git
a/gtk2_ardour/gain_meter.h
b/gtk2_ardour/gain_meter.h
index 2c481837aeb5e345d5293a299492db22aca9fb57..38b89bb8a5a06df2ebe427f4f3edb2afe65a408a 100644
(file)
--- a/
gtk2_ardour/gain_meter.h
+++ b/
gtk2_ardour/gain_meter.h
@@
-38,6
+38,8
@@
#include "ardour/types.h"
#include "ardour/session_handle.h"
#include "ardour/types.h"
#include "ardour/session_handle.h"
+#include "ardour_button.h"
+
#include "gtkmm2ext/click_box.h"
#include "gtkmm2ext/focus_entry.h"
#include "gtkmm2ext/slider_controller.h"
#include "gtkmm2ext/click_box.h"
#include "gtkmm2ext/focus_entry.h"
#include "gtkmm2ext/slider_controller.h"
@@
-56,7
+58,6
@@
namespace ARDOUR {
}
namespace Gtkmm2ext {
class FastMeter;
}
namespace Gtkmm2ext {
class FastMeter;
- class BarController;
}
namespace Gtk {
class Menu;
}
namespace Gtk {
class Menu;
@@
-65,8
+66,7
@@
namespace Gtk {
class GainMeterBase : virtual public sigc::trackable, ARDOUR::SessionHandlePtr
{
public:
class GainMeterBase : virtual public sigc::trackable, ARDOUR::SessionHandlePtr
{
public:
- GainMeterBase (ARDOUR::Session*, const Glib::RefPtr<Gdk::Pixbuf>& pix,
- bool horizontal, int);
+ GainMeterBase (ARDOUR::Session*, bool horizontal, int, int);
virtual ~GainMeterBase ();
virtual void set_controls (boost::shared_ptr<ARDOUR::Route> route,
virtual ~GainMeterBase ();
virtual void set_controls (boost::shared_ptr<ARDOUR::Route> route,
@@
-82,15
+82,23
@@
class GainMeterBase : virtual public sigc::trackable, ARDOUR::SessionHandlePtr
void set_fader_name (const char * name);
virtual void setup_meters (int len=0);
void set_fader_name (const char * name);
virtual void setup_meters (int len=0);
+ virtual void set_type (ARDOUR::MeterType);
boost::shared_ptr<PBD::Controllable> get_controllable();
boost::shared_ptr<PBD::Controllable> get_controllable();
- LevelMeter& get_level_meter() const { return *level_meter; }
+ LevelMeter
HBox
& get_level_meter() const { return *level_meter; }
Gtkmm2ext::SliderController& get_gain_slider() const { return *gain_slider; }
Gtkmm2ext::SliderController& get_gain_slider() const { return *gain_slider; }
+ /** Emitted in the GUI thread when a button is pressed over the level meter;
+ * return true if the event is handled.
+ */
+ PBD::Signal1<bool, GdkEventButton *> LevelMeterButtonPress;
+
protected:
friend class MixerStrip;
protected:
friend class MixerStrip;
+ friend class MeterStrip;
+ friend class RouteTimeAxisView;
boost::shared_ptr<ARDOUR::Route> _route;
boost::shared_ptr<ARDOUR::PeakMeter> _meter;
boost::shared_ptr<ARDOUR::Amp> _amp;
boost::shared_ptr<ARDOUR::Route> _route;
boost::shared_ptr<ARDOUR::PeakMeter> _meter;
boost::shared_ptr<ARDOUR::Amp> _amp;
@@
-103,14
+111,17
@@
class GainMeterBase : virtual public sigc::trackable, ARDOUR::SessionHandlePtr
Gtkmm2ext::SliderController *gain_slider;
Gtk::Adjustment gain_adjustment;
Gtkmm2ext::FocusEntry gain_display;
Gtkmm2ext::SliderController *gain_slider;
Gtk::Adjustment gain_adjustment;
Gtkmm2ext::FocusEntry gain_display;
- Gtk::Button peak_display;
+ Gtkmm2ext::FocusEntry peak_display;
+// Gtk::Button peak_display;
Gtk::DrawingArea meter_metric_area;
Gtk::DrawingArea meter_metric_area;
- LevelMeter *level_meter;
+ Gtk::DrawingArea meter_ticks1_area;
+ Gtk::DrawingArea meter_ticks2_area;
+ LevelMeterHBox *level_meter;
sigc::connection gain_watching;
sigc::connection gain_watching;
-
Gtk::
Button gain_automation_style_button;
-
Gtk::Toggle
Button gain_automation_state_button;
+
Ardour
Button gain_automation_style_button;
+
Ardour
Button gain_automation_state_button;
Gtk::Menu gain_astate_menu;
Gtk::Menu gain_astyle_menu;
Gtk::Menu gain_astate_menu;
Gtk::Menu gain_astyle_menu;
@@
-123,6
+134,8
@@
class GainMeterBase : virtual public sigc::trackable, ARDOUR::SessionHandlePtr
void gain_automation_state_changed();
void gain_automation_style_changed();
void gain_automation_state_changed();
void gain_automation_style_changed();
+ void setup_gain_adjustment ();
+
std::string astate_string (ARDOUR::AutoState);
std::string short_astate_string (ARDOUR::AutoState);
std::string _astate_string (ARDOUR::AutoState, bool);
std::string astate_string (ARDOUR::AutoState);
std::string short_astate_string (ARDOUR::AutoState);
std::string _astate_string (ARDOUR::AutoState, bool);
@@
-155,10
+168,10
@@
class GainMeterBase : virtual public sigc::trackable, ARDOUR::SessionHandlePtr
Gtk::Menu* meter_menu;
void popup_meter_menu (GdkEventButton*);
Gtk::Menu* meter_menu;
void popup_meter_menu (GdkEventButton*);
-
gint start_gain_touch (GdkEventButton
*);
-
gint end_gain_touch (GdkEventButton
*);
+
bool gain_slider_button_press (GdkEventButton
*);
+
bool gain_slider_button_release (GdkEventButton
*);
- void set_
mix
_group_meter_point (ARDOUR::Route&, ARDOUR::MeterPoint);
+ void set_
route
_group_meter_point (ARDOUR::Route&, ARDOUR::MeterPoint);
void set_meter_point (ARDOUR::Route&, ARDOUR::MeterPoint);
gint meter_release (GdkEventButton*);
gint meter_press (GdkEventButton*);
void set_meter_point (ARDOUR::Route&, ARDOUR::MeterPoint);
gint meter_release (GdkEventButton*);
gint meter_press (GdkEventButton*);
@@
-168,24
+181,26
@@
class GainMeterBase : virtual public sigc::trackable, ARDOUR::SessionHandlePtr
void parameter_changed (const char*);
void reset_peak_display ();
void parameter_changed (const char*);
void reset_peak_display ();
+ void reset_route_peak_display (ARDOUR::Route*);
void reset_group_peak_display (ARDOUR::RouteGroup*);
void reset_group_peak_display (ARDOUR::RouteGroup*);
- static sigc::signal<void> ResetAllPeakDisplays;
- static sigc::signal<void,ARDOUR::RouteGroup*> ResetGroupPeakDisplays;
-
+ void redraw_metrics ();
void on_theme_changed ();
void on_theme_changed ();
- bool style_changed;
- bool dpi_changed;
- bool color_changed;
void color_handler(bool);
void color_handler(bool);
- bool _is_midi;
+ ARDOUR::DataType _data_type;
+ ARDOUR::ChanCount _previous_amp_output_streams;
+
+private:
+
+ bool level_meter_button_press (GdkEventButton *);
+ PBD::ScopedConnection _level_meter_connection;
};
class GainMeter : public GainMeterBase, public Gtk::VBox
{
public:
};
class GainMeter : public GainMeterBase, public Gtk::VBox
{
public:
- GainMeter (ARDOUR::Session*, int);
- ~GainMeter () {}
+
GainMeter (ARDOUR::Session*, int);
+ virtual ~GainMeter ();
virtual void set_controls (boost::shared_ptr<ARDOUR::Route> route,
boost::shared_ptr<ARDOUR::PeakMeter> meter,
virtual void set_controls (boost::shared_ptr<ARDOUR::Route> route,
boost::shared_ptr<ARDOUR::PeakMeter> meter,
@@
-193,28
+208,30
@@
class GainMeter : public GainMeterBase, public Gtk::VBox
int get_gm_width ();
void setup_meters (int len=0);
int get_gm_width ();
void setup_meters (int len=0);
-
-
static void setup_slider_pix
();
+ void set_type (ARDOUR::MeterType);
+
void route_active_changed
();
protected:
void hide_all_meters ();
gint meter_metrics_expose (GdkEventExpose *);
protected:
void hide_all_meters ();
gint meter_metrics_expose (GdkEventExpose *);
-
-
static std::map<std::string,Glib::RefPtr<Gdk::Pixmap> > metric_pixmaps
;
-
static Glib::RefPtr<Gdk::Pixmap> render_metrics (Gtk::Widget &, std::vector<ARDOUR::DataType>
);
+ gint meter_ticks1_expose (GdkEventExpose *);
+
gint meter_ticks2_expose (GdkEventExpose *)
;
+
void on_style_changed (const Glib::RefPtr<Gtk::Style>&
);
private:
void meter_configuration_changed (ARDOUR::ChanCount);
private:
void meter_configuration_changed (ARDOUR::ChanCount);
-
+ void meter_type_changed (ARDOUR::MeterType);
+
Gtk::HBox gain_display_box;
Gtk::HBox fader_box;
Gtk::VBox* fader_vbox;
Gtk::HBox hbox;
Gtk::HBox gain_display_box;
Gtk::HBox fader_box;
Gtk::VBox* fader_vbox;
Gtk::HBox hbox;
+ Gtk::HBox meter_hbox;
+ Gtk::Alignment fader_alignment;
+ Gtk::Alignment meter_alignment;
std::vector<ARDOUR::DataType> _types;
std::vector<ARDOUR::DataType> _types;
-
- static Glib::RefPtr<Gdk::Pixbuf> slider;
};
#endif /* __ardour_gtk_gain_meter_h__ */
};
#endif /* __ardour_gtk_gain_meter_h__ */