X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=mainwindow.h;h=beb4eed75c61fe0bb6260793c58d1b5eaae52a5a;hb=fa54f2630c56a1df0046923d6a77b1bd58abf240;hp=0d3906d091b34347b6f6bcc47164bf09e5c5ce89;hpb=2f279ea7b988bdf204f6ba397b955dac28000133;p=nageru diff --git a/mainwindow.h b/mainwindow.h index 0d3906d..beb4eed 100644 --- a/mainwindow.h +++ b/mainwindow.h @@ -1,18 +1,23 @@ #ifndef MAINWINDOW_H #define MAINWINDOW_H +#include +#include #include +#include #include #include #include -#include +#include "analyzer.h" +#include "audio_mixer.h" #include "midi_mapper.h" #include "mixer.h" -class GLWidget; -class Ui_AudioExpandedView; +class QEvent; +class QObject; class QResizeEvent; +class Ui_AudioExpandedView; namespace Ui { class AudioExpandedView; @@ -21,7 +26,6 @@ class Display; class MainWindow; } // namespace Ui -class QDial; class QLabel; class QPushButton; @@ -42,13 +46,18 @@ public slots: void cut_triggered(); void x264_bitrate_triggered(); void exit_triggered(); + void manual_triggered(); void about_triggered(); + void open_analyzer_triggered(); void simple_audio_mode_triggered(); void multichannel_audio_mode_triggered(); void input_mapping_triggered(); void midi_mapping_triggered(); + void timecode_stream_triggered(); + void timecode_stdout_triggered(); void transition_clicked(int transition_number); void channel_clicked(int channel_number); + void quick_cut_activated(int channel_number); void wb_button_clicked(int channel_number); void set_transition_names(std::vector transition_names); void update_channel_name(Mixer::Output output, const std::string &name); @@ -60,6 +69,7 @@ public slots: void limiter_threshold_knob_changed(int value); void compressor_threshold_knob_changed(unsigned bus_index, int value); void mini_fader_changed(int bus, double db_volume); + void mute_button_toggled(int bus, bool checked); void reset_meters_button_clicked(); void relayout(); @@ -75,10 +85,13 @@ public slots: void set_compressor_threshold(unsigned bus_idx, float value) override; void set_fader(unsigned bus_idx, float value) override; + void toggle_mute(unsigned bus_idx) override; void toggle_locut(unsigned bus_idx) override; void toggle_auto_gain_staging(unsigned bus_idx) override; void toggle_compressor(unsigned bus_idx) override; void clear_peak(unsigned bus_idx) override; + void toggle_limiter() override; + void toggle_auto_makeup_gain() override; void clear_all_highlights() override; @@ -93,10 +106,13 @@ public slots: void highlight_compressor_threshold(unsigned bus_idx, bool highlight) override; void highlight_fader(unsigned bus_idx, bool highlight) override; + void highlight_mute(unsigned bus_idx, bool highlight) override; void highlight_toggle_locut(unsigned bus_idx, bool highlight) override; void highlight_toggle_auto_gain_staging(unsigned bus_idx, bool highlight) override; void highlight_toggle_compressor(unsigned bus_idx, bool highlight) override; void highlight_clear_peak(unsigned bus_idx, bool highlight) override {} // We don't mark this currently. + void highlight_toggle_limiter(bool highlight) override; + void highlight_toggle_auto_makeup_gain(bool highlight) override; // Raw receivers are not used. void controller_changed(unsigned controller) override {} @@ -107,6 +123,7 @@ private: void setup_audio_miniview(); void setup_audio_expanded_view(); bool eventFilter(QObject *watched, QEvent *event) override; + void closeEvent(QCloseEvent *event) override; void set_white_balance(int channel_number, int x, int y); void update_cutoff_labels(float cutoff_hz); void update_eq_label(unsigned bus_index, EQBand band, float gain_db); @@ -133,7 +150,10 @@ private: void highlight_control(T *control, bool highlight); template - void highlight_control_if_exists(unsigned bus_idx, T *(Ui_AudioExpandedView::*control), bool highlight); + void highlight_mute_control(T *control, bool highlight); + + template + void highlight_control_if_exists(unsigned bus_idx, T *(Ui_AudioExpandedView::*control), bool highlight, bool is_mute_button = false); Ui::MainWindow *ui; QLabel *disk_free_label; @@ -143,6 +163,7 @@ private: std::vector audio_expanded_views; int current_wb_pick_display = -1; MIDIMapper midi_mapper; + std::unique_ptr analyzer; }; extern MainWindow *global_mainwindow;