X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fardour_ui.h;h=2b83262451953af36e3fb56d3e13c3f55bbd0595;hb=76c25a4a4459b8e550c3c687458d04db0beaee77;hp=0bfc5cc7ea71f6ba704e4e92e70d2ea73aefec27;hpb=abb086738cdd0f862b1600e0780bbbf0f0967713;p=ardour.git diff --git a/gtk2_ardour/ardour_ui.h b/gtk2_ardour/ardour_ui.h index 0bfc5cc7ea..2b83262451 100644 --- a/gtk2_ardour/ardour_ui.h +++ b/gtk2_ardour/ardour_ui.h @@ -53,8 +53,8 @@ #include #include #include -#include #include +#include #include #include @@ -70,26 +70,27 @@ class OptionEditor; class Mixer_UI; class ConnectionEditor; class RouteParams_UI; -class SoundFileChooser; class About; class AddRouteDialog; class NewSessionDialog; class LocationUI; +class ColorManager; namespace Gtkmm2ext { class TearOff; -}; +} namespace ARDOUR { class AudioEngine; class Route; class Port; class IO; -}; + class ControlProtocolInfo; +} namespace ALSA { class MultiChannelDevice; -}; +} #define FRAME_NAME "BaseFrame" @@ -98,23 +99,23 @@ class ARDOUR_UI : public Gtkmm2ext::UI public: ARDOUR_UI (int *argcp, char **argvp[], string rcfile); ~ARDOUR_UI(); - + void show (); bool shown() { return shown_flag; } void show_splash (); void hide_splash (); - int load_session (string path, string snapshot, string* mix_template = 0); + int load_session (const string & path, const string & snapshot, string* mix_template = 0); bool session_loaded; - int build_session (string path, string snapshot, + int build_session (const string & path, const string & snapshot, uint32_t ctl_chns, uint32_t master_chns, - ARDOUR::Session::AutoConnectOption input_connect, - ARDOUR::Session::AutoConnectOption output_connect, + ARDOUR::AutoConnectOption input_connect, + ARDOUR::AutoConnectOption output_connect, uint32_t nphysin, uint32_t nphysout, - jack_nframes_t initial_length); + nframes_t initial_length); bool session_is_new() const { return _session_is_new; } ARDOUR::Session* the_session() { return session; } @@ -127,13 +128,13 @@ class ARDOUR_UI : public Gtkmm2ext::UI _will_create_new_session_automatically = yn; } - void new_session (bool startup = false, std::string path = string()); - gint cmdline_new_session (std::string path); + void new_session(std::string path = string()); + gint cmdline_new_session (string path); int unload_session (); - void close_session() { unload_session(); } + void close_session(); int save_state_canfail (string state_name = ""); - void save_state (string state_name = ""); + void save_state (const string & state_name = ""); void restore_state (string state_name = ""); static double gain_to_slider_position (ARDOUR::gain_t g); @@ -144,34 +145,27 @@ class ARDOUR_UI : public Gtkmm2ext::UI PublicEditor& the_editor(){return *editor;} Mixer_UI* the_mixer() { return mixer; } - void allow_focus (bool yn); - - static gint generic_focus_in_event (GdkEventFocus *); - static gint generic_focus_out_event (GdkEventFocus *); - void toggle_location_window (); + void toggle_color_manager (); void toggle_big_clock_window (); void toggle_connection_editor (); void toggle_route_params_window (); - void toggle_tempo_window (); - - gint32 select_diskstream (GdkEventButton *ev); + void toggle_editing_space(); Gtk::Tooltips& tooltips() { return _tooltips; } static sigc::signal Blink; static sigc::signal RapidScreenUpdate; static sigc::signal SuperRapidScreenUpdate; - static sigc::signal Clock; + static sigc::signal Clock; /* this is a helper function to centralize the (complex) logic for blinking rec-enable buttons. */ - void rec_enable_button_blink (bool onoff, ARDOUR::DiskStream *, Gtk::Widget *w); + void rec_enable_button_blink (bool onoff, ARDOUR::AudioDiskstream *, Gtk::Widget *w); void name_io_setup (ARDOUR::AudioEngine&, string&, ARDOUR::IO& io, bool in); - void choose_io (ARDOUR::IO&, bool input); static gint hide_and_quit (GdkEventAny *ev, ArdourDialog *); @@ -182,7 +176,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI void save_ardour_state (); gboolean configure_handler (GdkEventConfigure* conf); - void do_transport_locate (jack_nframes_t position); + void do_transport_locate (nframes_t position); void halt_on_xrun_message (); AudioClock primary_clock; @@ -190,26 +184,38 @@ class ARDOUR_UI : public Gtkmm2ext::UI AudioClock preroll_clock; AudioClock postroll_clock; + void store_clock_modes (); + void restore_clock_modes (); + void add_route (); - void session_add_audio_track (int input_channels, int32_t output_channels) { - session_add_audio_route (true, input_channels, output_channels); + void session_add_audio_track (int input_channels, int32_t output_channels, ARDOUR::TrackMode mode, uint32_t how_many) { + session_add_audio_route (true, input_channels, output_channels, mode, how_many); } - void session_add_audio_bus (int input_channels, int32_t output_channels) { - session_add_audio_route (false, input_channels, output_channels); + void session_add_audio_bus (int input_channels, int32_t output_channels, uint32_t how_many) { + session_add_audio_route (false, input_channels, output_channels, ARDOUR::Normal, how_many); } void session_add_midi_track (); void set_engine (ARDOUR::AudioEngine&); + gint start_engine (); gint exit_on_main_window_close (GdkEventAny *); + void maximise_editing_space (); + void restore_editing_space (); + + void set_native_file_header_format (ARDOUR::HeaderFormat sf); + void set_native_file_data_format (ARDOUR::SampleFormat sf); + + void set_keybindings_path (std::string path); + void save_keybindings (); + protected: friend class PublicEditor; - void toggle_metering (); void toggle_clocking (); void toggle_auto_play (); void toggle_auto_input (); @@ -217,10 +223,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI void toggle_punch_out (); void toggle_auto_return (); void toggle_click (); - void toggle_follow (); void toggle_session_auto_loop (); - void toggle_session_punch_in (); void toggle_options_window (); @@ -277,43 +281,28 @@ class ARDOUR_UI : public Gtkmm2ext::UI Gtk::Table option_table; int setup_windows (); - void setup_session_menu (); void setup_transport (); void setup_clock (); - void setup_session_info (); void setup_adjustables (); - Gtk::MenuBar* make_menubar (); - static ARDOUR_UI *theArdourUI; void startup (); void shutdown (); void finish(); - int ask_about_saving_session (string why); - gint ask_about_save_deleted (GdkEventAny*); - void save_session_choice_made (int); + int ask_about_saving_session (const string & why); int save_the_session; void queue_transport_change (); void map_transport_state (); int32_t do_engine_start (); - gint start_engine (); void engine_halted (); void engine_stopped (); void engine_running (); - void map_some_session_state (Gtk::ToggleButton& button, - bool (ARDOUR::Session::*get)() const); - - void toggle_some_session_state (Gtk::ToggleButton& button, - bool (ARDOUR::Session::*get)() const, - void (ARDOUR::Session::*set)(bool)); - void map_button_state (); - - void clear_meters (); + void use_config (); static gint _blink (void *); void blink (); @@ -325,6 +314,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI void control_methods_adjusted (); void mmc_device_id_adjusted (); + void about_signal_response(int response); + private: Gtk::VBox top_packer; @@ -333,16 +324,21 @@ class ARDOUR_UI : public Gtkmm2ext::UI void start_clocking (); void stop_clocking (); - AudioClock big_clock; - Gtk::Frame big_clock_frame; - ArdourDialog* big_clock_window; + void manage_window (Gtk::Window&); + + AudioClock big_clock; + Gtk::Frame big_clock_frame; + Gtk::Window* big_clock_window; + + void update_transport_clocks (nframes_t pos); + void record_state_changed (); /* Transport Control */ void detach_tearoff (Gtk::Box* parent, Gtk::Widget* contents); void reattach_tearoff (Gtk::Box* parent, Gtk::Widget* contents, int32_t order); - Gtkmm2ext::TearOff* transport_tearoff; + Gtkmm2ext::TearOff* transport_tearoff; Gtk::Frame transport_frame; Gtk::HBox transport_tearoff_hbox; Gtk::HBox transport_hbox; @@ -358,40 +354,45 @@ class ARDOUR_UI : public Gtkmm2ext::UI Gtk::HBox primary_clock_hbox; Gtk::HBox secondary_clock_hbox; - Gtk::Button goto_start_button; - Gtk::Button goto_end_button; - Gtk::Button rewind_button; - Gtk::Button forward_button; - Gtk::Button stop_button; - - enum ShuttleBehaviour { - Sprung, - Wheel - }; - - enum ShuttleUnits { - Percentage, - Semitones - }; - - Gtk::DrawingArea shuttle_box; - Gtk::EventBox speed_display_box; - Gtk::Label speed_display_label; - Gtk::Button shuttle_units_button; - Gtk::Button shuttle_style_button; - Gtk::Menu* shuttle_unit_menu; - Gtk::Menu* shuttle_style_menu; - ShuttleBehaviour shuttle_behaviour; - ShuttleUnits shuttle_units; - - void shuttle_style_clicked (); + Gtkmm2ext::StatefulButton roll_button; + Gtkmm2ext::StatefulButton stop_button; + Gtkmm2ext::StatefulButton rewind_button; + Gtkmm2ext::StatefulButton forward_button; + Gtkmm2ext::StatefulButton goto_start_button; + Gtkmm2ext::StatefulButton goto_end_button; + Gtkmm2ext::StatefulButton auto_loop_button; + Gtkmm2ext::StatefulButton play_selection_button; + + Gtkmm2ext::StatefulButton rec_button; + + Gtk::ToggleButton time_master_button; + Gtk::ComboBoxText sync_option_combo; + + void sync_option_changed (); + void toggle_time_master (); + void toggle_video_sync (); + + Gtk::DrawingArea shuttle_box; + Gtk::EventBox speed_display_box; + Gtk::Label speed_display_label; + Gtk::Button shuttle_units_button; + Gtk::ComboBoxText shuttle_style_button; + Gtk::Menu* shuttle_unit_menu; + Gtk::Menu* shuttle_style_menu; + float shuttle_max_speed; + Gtk::Menu* shuttle_context_menu; + + void build_shuttle_context_menu (); + void show_shuttle_context_menu (); + void shuttle_style_changed(); void shuttle_unit_clicked (); - void set_shuttle_behaviour (ShuttleBehaviour); - void set_shuttle_units (ShuttleUnits); + void set_shuttle_max_speed (float); void update_speed_display (); + float last_speed_displayed; gint shuttle_box_button_press (GdkEventButton*); gint shuttle_box_button_release (GdkEventButton*); + gint shuttle_box_scroll (GdkEventScroll*); gint shuttle_box_motion (GdkEventMotion*); gint shuttle_box_expose (GdkEventExpose*); gint mouse_shuttle (double x, bool force); @@ -400,25 +401,17 @@ class ARDOUR_UI : public Gtkmm2ext::UI bool shuttle_grabbed; double shuttle_fract; - Gtk::ToggleButton auto_loop_button; - Gtk::ToggleButton play_selection_button; - Gtk::ToggleButton roll_button; - - Gtk::ToggleButton rec_button; Gtk::ToggleButton punch_in_button; Gtk::ToggleButton punch_out_button; Gtk::ToggleButton auto_return_button; Gtk::ToggleButton auto_play_button; Gtk::ToggleButton auto_input_button; Gtk::ToggleButton click_button; - Gtk::ToggleButton follow_button; Gtk::ToggleButton auditioning_alert_button; Gtk::ToggleButton solo_alert_button; Gtk::VBox alert_box; - void follow_changed (); - void solo_blink (bool); void audition_blink (bool); @@ -444,8 +437,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI void allow_mmc_and_local (); void allow_local_only (); - static void rate_printer (char buf[32], Gtk::Adjustment &, void *); - Gtk::Menu* session_popup_menu; struct RecentSessionModelColumns : public Gtk::TreeModel::ColumnRecord { @@ -465,8 +456,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI Gtk::FileChooserDialog* open_session_selector; void build_session_selector(); - void recent_session_selection_changed (); void redisplay_recent_sessions(); + void recent_session_row_activated (const Gtk::TreePath& path, Gtk::TreeViewColumn* col); struct RecentSessionsSorter { bool operator() (std::pair a, std::pair b) const { @@ -477,38 +468,11 @@ class ARDOUR_UI : public Gtkmm2ext::UI /* menu bar and associated stuff */ Gtk::MenuBar* menu_bar; - Gtk::Fixed menu_bar_base; + Gtk::EventBox menu_bar_base; Gtk::HBox menu_hbox; void build_menu_bar (); - void pack_toplevel_controls(); - - /* handles on the menu bar items that need to - be sensitive to whether or not we have - a session loaded. - */ - - Gtk::MenuItem *add_track_item; - Gtk::MenuItem *save_item; - Gtk::MenuItem *snapshot_item; - Gtk::MenuItem *save_as_item; - Gtk::MenuItem *save_template_item; - Gtk::MenuItem *export_item; - Gtk::MenuItem *close_item; - - Gtk::CheckMenuItem *meter_bridge_dialog_check; - Gtk::CheckMenuItem *connection_editor_check; - Gtk::CheckMenuItem *route_params_check; - Gtk::CheckMenuItem *locations_dialog_check; - Gtk::CheckMenuItem *big_clock_check; - Gtk::CheckMenuItem *tempo_editor_check; -// Gtk::CheckMenuItem *sfdb_check; - Gtk::CheckMenuItem *options_window_check; - - /* */ - Gtk::MenuItem *image_compositor_item ; - /* */ - + void build_control_surface_menu (); Gtk::Label wall_clock_label; Gtk::EventBox wall_clock_box; @@ -522,17 +486,13 @@ class ARDOUR_UI : public Gtkmm2ext::UI Gtk::EventBox cpu_load_box; void update_cpu_load (); - Gtk::Label disk_rate_label; - Gtk::EventBox disk_rate_box; - void update_disk_rate(); - Gtk::Label buffer_load_label; Gtk::EventBox buffer_load_box; void update_buffer_load (); Gtk::Label sample_rate_label; Gtk::EventBox sample_rate_box; - void update_sample_rate (jack_nframes_t); + void update_sample_rate (nframes_t); gint every_second (); gint every_point_one_seconds (); @@ -542,65 +502,23 @@ class ARDOUR_UI : public Gtkmm2ext::UI sigc::connection point_one_second_connection; sigc::connection point_zero_one_second_connection; - void diskstream_added (ARDOUR::DiskStream*); - gint session_menu (GdkEventButton *); bool _will_create_new_session_automatically; - NewSessionDialog* new_session_window; - string template_name; - - void new_session_ok_clicked (); - void new_session_template_choice (Gtk::TreeView&, Glib::RefPtr); - void hide_dialog (ArdourDialog *dialog); - - void fs_cancel_clicked (Gtk::FileSelection*); - gint fs_delete_event (GdkEventAny*, Gtk::FileSelection*); - + NewSessionDialog* new_session_dialog; + void open_session (); void open_recent_session (); - void open_ok_clicked (); - void save_template (); - - void session_add_audio_route (bool disk, int32_t input_channels, int32_t output_channels); - - void add_diskstream_to_menu (ARDOUR::DiskStream&); - void diskstream_selected (gint32); - Gtk::Menu *diskstream_menu; - gint32 selected_dstream; - - gint mouse_transport_goto_start (GdkEventButton *) { - transport_goto_start (); return TRUE; - } - gint mouse_transport_goto_end (GdkEventButton *) { - transport_goto_end (); return TRUE; - } - gint mouse_transport_record (GdkEventButton *) { - transport_record (); return TRUE; - } - gint mouse_transport_forward (GdkEventButton *) { - transport_forward (0); return TRUE; - } - gint mouse_transport_rewind (GdkEventButton *) { - transport_rewind (0); return TRUE; - } - gint mouse_transport_loop (GdkEventButton *) { - transport_loop (); return TRUE; - } - gint mouse_transport_play_selection (GdkEventButton *) { - transport_play_selection (); return TRUE; - } - - gint mouse_transport_roll (GdkEventButton *); - gint mouse_transport_stop (GdkEventButton *); + void session_add_audio_route (bool disk, int32_t input_channels, int32_t output_channels, ARDOUR::TrackMode mode, uint32_t how_many); void set_transport_sensitivity (bool); void remove_last_capture (); + void transport_goto_zero (); void transport_goto_start (); void transport_goto_end (); void transport_stop (); @@ -612,38 +530,31 @@ class ARDOUR_UI : public Gtkmm2ext::UI void transport_rewind (int option); void transport_loop (); - void transport_locating (); void transport_rolling (); void transport_rewinding (); void transport_forwarding (); void transport_stopped (); - void send_all_midi_feedback (); - bool _session_is_new; void connect_to_session (ARDOUR::Session *); void connect_dependents_to_session (ARDOUR::Session *); void we_have_dependents (); - void setup_keybindings (); + + std::string keybindings_path; + void setup_keybindings (); + void setup_session_options (); + guint32 last_key_press_time; void snapshot_session (); - void map_control_change (ARDOUR::Session::ControlType); - void queue_map_control_change (ARDOUR::Session::ControlType); - void map_record_state (); - void queue_map_record_state (); - Mixer_UI *mixer; int create_mixer (); PublicEditor *editor; int create_editor (); - MeterBridge *meter_bridge; - int create_meter_bridge (); - RouteParams_UI *route_params; int create_route_params (); @@ -652,17 +563,9 @@ class ARDOUR_UI : public Gtkmm2ext::UI LocationUI *location_ui; int create_location_ui (); + void handle_locations_change (ARDOUR::Location*); - void meter_bridge_hiding (); - void location_ui_hiding (); - void big_clock_hiding (); - void route_params_hiding (); - void connection_editor_hiding (); - void option_hiding (); - - /* Various options */ - - void toggle_recording_plugins (); + ColorManager* color_manager; /* Options window */ @@ -671,7 +574,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI /* route dialog */ AddRouteDialog *add_route_dialog; - void add_route_dialog_done (int status); /* Keyboard Handling */ @@ -679,16 +581,13 @@ class ARDOUR_UI : public Gtkmm2ext::UI /* Keymap handling */ - void install_keybindings (); void install_actions (); - void test_binding_action (const char *); void start_keyboard_prefix(); - void toggle_record_enable (guint32); - void toggle_monitor_enable (guint32); + void toggle_record_enable (uint32_t); - uint32_t rec_enabled_diskstreams; - void count_recenabled_diskstreams (ARDOUR::DiskStream&); + uint32_t rec_enabled_streams; + void count_recenabled_streams (ARDOUR::Route&); About* about; bool shown_flag; @@ -696,7 +595,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI Gtk::MenuItem *cleanup_item; - void display_cleanup_results (ARDOUR::Session::cleanup_report& rep, const gchar* list_title, string msg); + void display_cleanup_results (ARDOUR::Session::cleanup_report& rep, const gchar* list_title, const string & msg); void cleanup (); void flush_trash (); @@ -707,12 +606,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI struct timeval last_peak_grab; struct timeval last_shuttle_request; - void cannot_record_no_input (ARDOUR::DiskStream*); - - void delete_sources_in_the_right_thread (list*); - - void editor_display_control_changed (Editing::DisplayControl c); - bool have_disk_overrun_displayed; bool have_disk_underrun_displayed; @@ -725,7 +618,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI void disconnect_from_jack (); void reconnect_to_jack (); - void set_jack_buffer_size (jack_nframes_t); + void set_jack_buffer_size (nframes_t); Gtk::MenuItem* jack_disconnect_item; Gtk::MenuItem* jack_reconnect_item; @@ -734,7 +627,52 @@ class ARDOUR_UI : public Gtkmm2ext::UI int make_session_clean (); bool filter_ardour_session_dirs (const Gtk::FileFilter::Info&); - Glib::RefPtr ui_manager; + Glib::RefPtr common_actions; + + void editor_realized (); + + std::vector positional_sync_strings; + + void toggle_send_midi_feedback (); + void toggle_use_mmc (); + void toggle_send_mmc (); + void toggle_use_midi_control(); + void toggle_send_mtc (); + + void set_input_auto_connect (ARDOUR::AutoConnectOption); + void set_output_auto_connect (ARDOUR::AutoConnectOption); + void set_solo_model (ARDOUR::SoloModel); + void set_monitor_model (ARDOUR::MonitorModel); + + void toggle_StopPluginsWithTransport(); + void toggle_DoNotRunPluginsWhileRecording(); + void toggle_VerifyRemoveLastCapture(); + void toggle_StopRecordingOnXrun(); + void toggle_StopTransportAtEndOfSession(); + void toggle_GainReduceFastTransport(); + void toggle_LatchedSolo(); + void toggle_LatchedRecordEnable (); + + void mtc_port_changed (); + void map_solo_model (); + void map_monitor_model (); + void map_file_header_format (); + void map_file_data_format (); + void map_input_auto_connect (); + void map_output_auto_connect (); + void parameter_changed (const char*); + + void set_meter_hold (ARDOUR::MeterHold); + void set_meter_falloff (ARDOUR::MeterFalloff); + void map_meter_hold (); + void map_meter_falloff (); + + void toggle_control_protocol (ARDOUR::ControlProtocolInfo*); + void toggle_control_protocol_feedback (ARDOUR::ControlProtocolInfo*, const char* group_name, std::string action_name); + + bool can_save_keybindings; + bool first_idle (); }; #endif /* __ardour_gui_h__ */ +