X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fengine_dialog.h;h=3e3f9b82fb6d21a9eb32b27d1856443fb9de8e17;hb=237741d18722252abd4a6a20d3422315481ccffe;hp=ae9c360e55942bc1039f6e3568bd595533814516;hpb=645e9caeeefe0db6ed7615842b317f3b6ecb95d9;p=ardour.git diff --git a/gtk2_ardour/engine_dialog.h b/gtk2_ardour/engine_dialog.h index ae9c360e55..3e3f9b82fb 100644 --- a/gtk2_ardour/engine_dialog.h +++ b/gtk2_ardour/engine_dialog.h @@ -36,19 +36,20 @@ #include "pbd/signals.h" #include "ardour_dialog.h" +#include "ardour_button.h" class EngineControl : public ArdourDialog, public PBD::ScopedConnectionList { public: EngineControl (); ~EngineControl (); - + static bool need_setup (); - + XMLNode& get_state (); void set_state (const XMLNode&); - + void set_desired_sample_rate (uint32_t); - + private: Gtk::Notebook notebook; @@ -78,6 +79,7 @@ class EngineControl : public ArdourDialog, public PBD::ScopedConnectionList { Gtk::Label have_control_text; Gtk::Button control_app_button; + ArdourButton midi_devices_button; Gtk::Button connect_disconnect_button; @@ -85,14 +87,18 @@ class EngineControl : public ArdourDialog, public PBD::ScopedConnectionList { Gtk::ComboBoxText lm_output_channel_combo; Gtk::ComboBoxText lm_input_channel_combo; - Gtk::Label lm_start_stop_label; - Gtk::ToggleButton lm_measure_button; + Gtk::Label lm_measure_label; + Gtk::Button lm_measure_button; Gtk::Button lm_use_button; + Gtk::Button lm_back_button; + ArdourButton lm_button_audio; Gtk::Label lm_title; + Gtk::Label lm_preamble; Gtk::Label lm_results; Gtk::Table lm_table; Gtk::VBox lm_vbox; bool have_lm_results; + bool lm_running; Gtk::Button* cancel_button; Gtk::Button* ok_button; @@ -101,16 +107,15 @@ class EngineControl : public ArdourDialog, public PBD::ScopedConnectionList { /* MIDI Tab */ Gtk::VBox midi_vbox; - Gtk::Button midi_refresh_button; + Gtk::Button midi_back_button; Gtk::Table midi_device_table; /* MIDI ... JACK */ - + Gtk::CheckButton aj_button; - + uint32_t ignore_changes; uint32_t _desired_sample_rate; - bool no_push; bool started_at_least_once; void driver_changed (); @@ -118,11 +123,12 @@ class EngineControl : public ArdourDialog, public PBD::ScopedConnectionList { void sample_rate_changed (); void buffer_size_changed (); void parameter_changed (); + void midi_option_changed (); void setup_midi_tab_for_backend (); void setup_midi_tab_for_jack (); - void refresh_midi_display (); - + void refresh_midi_display (std::string focus = ""); + std::string bufsize_as_string (uint32_t); float get_rate() const; @@ -134,12 +140,42 @@ class EngineControl : public ArdourDialog, public PBD::ScopedConnectionList { std::string get_device_name() const; std::string get_driver() const; std::string get_backend() const; + std::string get_midi_option () const; void device_changed (); void list_devices (); void show_buffer_duration (); - struct State { + void configure_midi_devices (); + + struct MidiDeviceSetting { + std::string name; + bool enabled; + uint32_t input_latency; + uint32_t output_latency; + + MidiDeviceSetting (std::string n, bool en = true, uint32_t inl = 0, uint32_t oul = 0) + : name (n) + , enabled (en) + , input_latency (inl) + , output_latency (oul) + {} + }; + + typedef boost::shared_ptr MidiDeviceSettings; + bool _can_set_midi_latencies; + std::vector _midi_devices; + + MidiDeviceSettings find_midi_device(std::string devicename) const { + for (std::vector::const_iterator p = _midi_devices.begin(); p != _midi_devices.end(); ++p) { + if ((*p)->name == devicename) { + return *p; + } + } + return MidiDeviceSettings(); + } + + struct StateStruct { std::string backend; std::string driver; std::string device; @@ -151,8 +187,9 @@ class EngineControl : public ArdourDialog, public PBD::ScopedConnectionList { uint32_t output_channels; bool active; std::string midi_option; + std::vector midi_devices; - State() + StateStruct() : input_latency (0) , output_latency (0) , input_channels (0) @@ -160,18 +197,19 @@ class EngineControl : public ArdourDialog, public PBD::ScopedConnectionList { , active (false) {} }; - + + typedef boost::shared_ptr State; typedef std::list StateList; StateList states; - State* get_matching_state (const std::string& backend, + State get_matching_state (const std::string& backend, const std::string& driver, const std::string& device); - State* get_saved_state_for_currently_displayed_backend_and_device (); + State get_saved_state_for_currently_displayed_backend_and_device (); void maybe_display_saved_state (); - State* save_state (); - void store_state (State&); + State save_state (); + void store_state (State); bool _have_control; @@ -190,14 +228,15 @@ class EngineControl : public ArdourDialog, public PBD::ScopedConnectionList { void update_sensitivity (); /* latency measurement */ - void latency_button_toggled (); - bool check_latency_measurement (); + void latency_button_clicked (); + bool check_audio_latency_measurement (); + bool check_midi_latency_measurement (); sigc::connection latency_timeout; void enable_latency_tab (); void disable_latency_tab (); void start_latency_detection (); void end_latency_detection (); - + void on_switch_page (GtkNotebookPage*, guint page_num); bool on_delete_event (GdkEventAny*); @@ -207,6 +246,13 @@ class EngineControl : public ArdourDialog, public PBD::ScopedConnectionList { PBD::ScopedConnection stopped_connection; void connect_disconnect_click (); + void calibrate_audio_latency (); + void calibrate_midi_latency (MidiDeviceSettings); + + MidiDeviceSettings _measure_midi; + void midi_latency_adjustment_changed(Gtk::Adjustment *, MidiDeviceSettings, bool); + void midi_device_enabled_toggled(ArdourButton *, MidiDeviceSettings); + sigc::connection lm_back_button_signal; }; #endif /* __gtk2_ardour_engine_dialog_h__ */