X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fardour_ui.h;h=bf9a88d29e8ff433d05475ca3349797a4259bc1a;hb=6e904b1e1600f4ccc0338d0b0864f7e02d417b13;hp=442d319f770283fa6ec6bce2ef45d1dae50ea9bd;hpb=ed990de6040215412baf8f448b1876d78bd9cc19;p=ardour.git diff --git a/gtk2_ardour/ardour_ui.h b/gtk2_ardour/ardour_ui.h index 442d319f77..bf9a88d29e 100644 --- a/gtk2_ardour/ardour_ui.h +++ b/gtk2_ardour/ardour_ui.h @@ -20,6 +20,8 @@ #ifndef __ardour_gui_h__ #define __ardour_gui_h__ +#include + /* need _BSD_SOURCE to get timersub macros */ #ifdef _BSD_SOURCE @@ -31,12 +33,12 @@ #endif #include - #include #include -#include +#include "pbd/xml++.h" +#include "pbd/controllable.h" #include #include #include @@ -56,81 +58,79 @@ #include #include #include -#include -#include -#include +#include "ardour/ardour.h" +#include "ardour/types.h" +#include "ardour/utils.h" +#include "ardour/session_handle.h" #include "audio_clock.h" #include "ardour_dialog.h" #include "editing.h" #include "ui_config.h" +#include "window_proxy.h" +class About; +class AddRouteDialog; +class ArdourStartup; +class ArdourKeyboard; class AudioClock; -class PublicEditor; -class Keyboard; -class OptionEditor; +class BundleManager; +class ConnectionEditor; class KeyEditor; +class LocationUIWindow; class Mixer_UI; -class ConnectionEditor; +class PublicEditor; +class RCOptionEditor; class RouteParams_UI; -class About; +class SessionOptionEditor; class Splash; -class AddRouteDialog; -class NewSessionDialog; -class LocationUI; class ThemeManager; -class BundleManager; +class MidiTracer; +class WindowProxyBase; +class GlobalPortMatrixWindow; namespace Gtkmm2ext { class TearOff; } namespace ARDOUR { - class AudioEngine; - class Route; - class Port; - class IO; class ControlProtocolInfo; + class IO; + class Port; + class Route; + class RouteGroup; + class Location; } -namespace ALSA { - class MultiChannelDevice; -} - -#define FRAME_NAME "BaseFrame" - extern sigc::signal ColorsChanged; extern sigc::signal DPIReset; -class ARDOUR_UI : public Gtkmm2ext::UI +class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr { public: ARDOUR_UI (int *argcp, char **argvp[]); ~ARDOUR_UI(); - void show (); - bool shown() { return shown_flag; } + bool run_startup (bool should_be_new, std::string load_template); void show_splash (); void hide_splash (); + void launch_chat (); + void launch_manual (); + void launch_reference (); void show_about (); void hide_about (); void idle_load (const Glib::ustring& path); + void finish(); + int load_session (const Glib::ustring& path, const Glib::ustring& snapshot, Glib::ustring mix_template = Glib::ustring()); bool session_loaded; - int build_session (const Glib::ustring& path, const Glib::ustring& snapshot, - uint32_t ctl_chns, - uint32_t master_chns, - ARDOUR::AutoConnectOption input_connect, - ARDOUR::AutoConnectOption output_connect, - uint32_t nphysin, - uint32_t nphysout, - nframes_t initial_length); + int build_session (const Glib::ustring& path, const Glib::ustring& snapshot, ARDOUR::BusProfile&); bool session_is_new() const { return _session_is_new; } - ARDOUR::Session* the_session() { return session; } + ARDOUR::Session* the_session() { return _session; } bool will_create_new_session_automatically() const { return _will_create_new_session_automatically; @@ -140,7 +140,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI _will_create_new_session_automatically = yn; } - bool get_session_parameters (bool have_engine = false, bool should_be_new = false); + int get_session_parameters (bool quit_on_cancel, bool should_be_new = false, std::string load_template = ""); void parse_cmdline_path (const Glib::ustring& cmdline_path, Glib::ustring& session_name, Glib::ustring& session_path, bool& existing_session); int load_cmdline_session (const Glib::ustring& session_name, const Glib::ustring& session_path, bool& existing_session); int build_session_from_nsd (const Glib::ustring& session_name, const Glib::ustring& session_path); @@ -150,9 +150,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI int unload_session (bool hide_stuff = false); void close_session(); - int save_state_canfail (string state_name = ""); - void save_state (const string & state_name = ""); - void restore_state (string state_name = ""); + int save_state_canfail (std::string state_name = "", bool switch_to_it = false); + void save_state (const std::string & state_name = "", bool switch_to_it = false); static double gain_to_slider_position (ARDOUR::gain_t g); static ARDOUR::gain_t slider_position_to_gain (double pos); @@ -163,16 +162,15 @@ class ARDOUR_UI : public Gtkmm2ext::UI PublicEditor& the_editor(){return *editor;} Mixer_UI* the_mixer() { return mixer; } - ARDOUR::AudioEngine& the_engine() const { return *engine; } - void toggle_key_editor (); void toggle_location_window (); void toggle_theme_manager (); void toggle_bundle_manager (); void toggle_big_clock_window (); - void toggle_connection_editor (); + void new_midi_tracer_window (); void toggle_route_params_window (); void toggle_editing_space(); + void toggle_keep_tearoffs(); Gtk::Tooltips& tooltips() { return _tooltips; } @@ -181,19 +179,10 @@ class ARDOUR_UI : public Gtkmm2ext::UI static sigc::signal SuperRapidScreenUpdate; 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::AudioDiskstream *, Gtk::Widget *w); - - void name_io_setup (ARDOUR::AudioEngine&, string&, ARDOUR::IO& io, bool in); - - static gint hide_and_quit (GdkEventAny *ev, ArdourDialog *); - XMLNode* editor_settings() const; XMLNode* mixer_settings () const; XMLNode* keyboard_settings () const; + XMLNode* tearoff_settings (const char*) const; void save_ardour_state (); gboolean configure_handler (GdkEventConfigure* conf); @@ -210,19 +199,20 @@ class ARDOUR_UI : public Gtkmm2ext::UI void store_clock_modes (); void restore_clock_modes (); + void reset_main_clocks (); void add_route (Gtk::Window* float_window); - 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_track (int input_channels, int32_t output_channels, ARDOUR::TrackMode mode, ARDOUR::RouteGroup* route_group, uint32_t how_many) { + session_add_audio_route (true, false, input_channels, output_channels, mode, route_group, how_many); } - 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_audio_bus (bool aux, int input_channels, int32_t output_channels, ARDOUR::RouteGroup* route_group, uint32_t how_many) { + session_add_audio_route (false, aux, input_channels, output_channels, ARDOUR::Normal, route_group, how_many); } - void session_add_midi_track (uint32_t how_many) { - session_add_midi_route (true, how_many); + void session_add_midi_track (ARDOUR::RouteGroup* route_group, uint32_t how_many) { + session_add_midi_route (true, route_group, how_many); } /*void session_add_midi_bus () { @@ -237,14 +227,15 @@ class ARDOUR_UI : public Gtkmm2ext::UI 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 setup_profile (); void setup_theme (); + void setup_tooltips (); void set_shuttle_fract (double); + void add_window_proxy (WindowProxyBase *); + void remove_window_proxy (WindowProxyBase *); + protected: friend class PublicEditor; @@ -256,62 +247,29 @@ class ARDOUR_UI : public Gtkmm2ext::UI bool ignore_dual_punch; void toggle_punch_in (); void toggle_punch_out (); + void show_loop_punch_ruler_and_disallow_hide (); + void reenable_hide_loop_punch_ruler_if_appropriate (); void toggle_auto_return (); void toggle_click (); void toggle_session_auto_loop (); - void toggle_options_window (); + void toggle_rc_options_window (); + void toggle_session_options_window (); private: - struct GlobalClickBox : public Gtk::VBox { - Gtkmm2ext::ClickBox *box; - Gtk::Frame frame; - Gtk::Label label; - vector &strings; - Gtk::Adjustment adjustment; - - static void printer (char buf[32], Gtk::Adjustment &adj, void *arg); - - GlobalClickBox (const string &str, vector &vs) - : strings (vs), - adjustment (0, 0, vs.size() - 1, 1, 1, 0) { - box = new Gtkmm2ext::ClickBox (&adjustment, "ClickButton"); - label.set_text (str); - label.set_name ("GlobalButtonLabel"); - frame.add (*box); - frame.set_shadow_type (Gtk::SHADOW_IN); - pack_start (label); - pack_start (frame); - box->set_print_func (printer, this); - box->set_wrap (true); - }; - }; - - ARDOUR::AudioEngine *engine; - ARDOUR::Session *session; - - Gtk::Tooltips _tooltips; - - void goto_editor_window (); - void goto_mixer_window (); + ArdourStartup* _startup; + ARDOUR::AudioEngine *engine; + Gtk::Tooltips _tooltips; - Gtk::Table adjuster_table; - Gtk::Frame adjuster_frame; - Gtk::Fixed adjuster_base; - - GlobalClickBox *online_control_button; - vector online_control_strings; - - GlobalClickBox *crossfade_time_button; - vector crossfade_time_strings; + void goto_editor_window (); + void goto_mixer_window (); + void toggle_editor_mixer_on_top (); + bool _mixer_on_top; Gtk::ToggleButton preroll_button; Gtk::ToggleButton postroll_button; - Gtk::Table transport_table; - Gtk::Table option_table; - int setup_windows (); void setup_transport (); void setup_clock (); @@ -322,20 +280,17 @@ class ARDOUR_UI : public Gtkmm2ext::UI void startup (); void shutdown (); - void finish(); - int ask_about_saving_session (const string & why); - int save_the_session; + int ask_about_saving_session (const std::string & why); /* periodic safety backup, to be precise */ gint autosave_session(); void update_autosave(); sigc::connection _autosave_connection; - void queue_transport_change (); void map_transport_state (); int32_t do_engine_start (); - void engine_halted (); + void engine_halted (const char* reason, bool free_reason); void engine_stopped (); void engine_running (); @@ -361,12 +316,25 @@ class ARDOUR_UI : public Gtkmm2ext::UI void manage_window (Gtk::Window&); AudioClock big_clock; - Gtk::Frame big_clock_frame; - Gtk::Window* big_clock_window; + ActionWindowProxy* big_clock_window; + int original_big_clock_width; + int original_big_clock_height; + double original_big_clock_font_size; + + void big_clock_size_allocate (Gtk::Allocation&); + bool idle_big_clock_text_resizer (int width, int height); + void big_clock_realized (); + bool big_clock_resize_in_progress; + int big_clock_height; + + void float_big_clock (Gtk::Window* parent); + bool main_window_state_event_handler (GdkEventWindowState*, bool window_was_editor); void update_transport_clocks (nframes_t pos); void record_state_changed (); + std::list _midi_tracer_windows; + /* Transport Control */ void detach_tearoff (Gtk::Box* parent, Gtk::Widget* contents); @@ -375,6 +343,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI Gtkmm2ext::TearOff* transport_tearoff; Gtk::Frame transport_frame; Gtk::HBox transport_tearoff_hbox; + Gtk::HBox play_range_hbox; + Gtk::VBox play_range_vbox; Gtk::HBox transport_hbox; Gtk::Fixed transport_base; Gtk::Fixed transport_button_base; @@ -403,8 +373,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI }; TransportControllable (std::string name, ARDOUR_UI&, ToggleType); - void set_value (float); - float get_value (void) const; + void set_value (double); + double get_value (void) const; void set_id (const std::string&); @@ -412,14 +382,14 @@ class ARDOUR_UI : public Gtkmm2ext::UI ToggleType type; }; - TransportControllable roll_controllable; - TransportControllable stop_controllable; - TransportControllable goto_start_controllable; - TransportControllable goto_end_controllable; - TransportControllable auto_loop_controllable; - TransportControllable play_selection_controllable; - TransportControllable rec_controllable; - TransportControllable shuttle_controllable; + boost::shared_ptr roll_controllable; + boost::shared_ptr stop_controllable; + boost::shared_ptr goto_start_controllable; + boost::shared_ptr goto_end_controllable; + boost::shared_ptr auto_loop_controllable; + boost::shared_ptr play_selection_controllable; + boost::shared_ptr rec_controllable; + boost::shared_ptr shuttle_controllable; BindingProxy shuttle_controller_binding_proxy; void set_transport_controllable_state (const XMLNode&); @@ -432,10 +402,9 @@ class ARDOUR_UI : public Gtkmm2ext::UI BindableButton auto_loop_button; BindableButton play_selection_button; BindableButton rec_button; + Gtk::ToggleButton join_play_range_button; - Gtk::ComboBoxText sync_option_combo; - - void sync_option_changed (); + void toggle_external_sync (); void toggle_time_master (); void toggle_video_sync (); @@ -475,24 +444,23 @@ class ARDOUR_UI : public Gtkmm2ext::UI Gtkmm2ext::StatefulToggleButton auto_input_button; Gtkmm2ext::StatefulToggleButton click_button; Gtkmm2ext::StatefulToggleButton time_master_button; + Gtkmm2ext::StatefulToggleButton sync_button; Gtk::ToggleButton auditioning_alert_button; Gtk::ToggleButton solo_alert_button; - Gtk::ToggleButton midi_panic_button; - Gtk::VBox alert_box; void solo_blink (bool); + void sync_blink (bool); void audition_blink (bool); void soloing_changed (bool); void auditioning_changed (bool); void _auditioning_changed (bool); - void solo_alert_toggle (); - void audition_alert_toggle (); - void midi_panic_toggle (); + bool solo_alert_press (GdkEventButton* ev); + bool audition_alert_press (GdkEventButton* ev); void big_clock_value_changed (); void primary_clock_value_changed (); @@ -525,7 +493,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI void recent_session_row_activated (const Gtk::TreePath& path, Gtk::TreeViewColumn* col); struct RecentSessionsSorter { - bool operator() (std::pair a, std::pair b) const { + bool operator() (std::pair a, std::pair b) const { return cmp_nocase(a.first, b.first) == -1; } }; @@ -538,7 +506,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI void use_menubar_as_top_menubar (); void build_menu_bar (); - void build_control_surface_menu (); Gtk::Label wall_clock_label; Gtk::EventBox wall_clock_box; @@ -573,14 +540,15 @@ class ARDOUR_UI : public Gtkmm2ext::UI bool _will_create_new_session_automatically; - NewSessionDialog* new_session_dialog; - void open_session (); void open_recent_session (); void save_template (); - void session_add_audio_route (bool disk, int32_t input_channels, int32_t output_channels, ARDOUR::TrackMode mode, uint32_t how_many); - void session_add_midi_route (bool disk, uint32_t how_many); + void edit_metadata (); + void import_metadata (); + + void session_add_audio_route (bool disk, bool aux, int32_t input_channels, int32_t output_channels, ARDOUR::TrackMode mode, ARDOUR::RouteGroup *, uint32_t how_many); + void session_add_midi_route (bool disk, ARDOUR::RouteGroup *, uint32_t how_many); void set_transport_sensitivity (bool); @@ -589,6 +557,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI void transport_goto_zero (); void transport_goto_start (); void transport_goto_end (); + void transport_goto_wallclock (); void transport_stop (); void transport_stop_and_forget_capture (); void transport_record (bool roll); @@ -597,14 +566,10 @@ class ARDOUR_UI : public Gtkmm2ext::UI void transport_forward (int option); void transport_rewind (int option); void transport_loop (); - - void transport_rolling (); - void transport_rewinding (); - void transport_forwarding (); - void transport_stopped (); + void toggle_roll (bool with_abort, bool roll_out_of_bounded_mode); bool _session_is_new; - void connect_to_session (ARDOUR::Session *); + void set_session (ARDOUR::Session *); void connect_dependents_to_session (ARDOUR::Session *); void we_have_dependents (); @@ -612,7 +577,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI guint32 last_key_press_time; - void snapshot_session (); + void snapshot_session (bool switch_to_it); Mixer_UI *mixer; int create_mixer (); @@ -626,12 +591,12 @@ class ARDOUR_UI : public Gtkmm2ext::UI BundleManager *bundle_manager; void create_bundle_manager (); - ConnectionEditor *connection_editor; - int create_connection_editor (); + ActionWindowProxy* location_ui; + int create_location_ui (); + void handle_locations_change (ARDOUR::Location*); - LocationUI *location_ui; - int create_location_ui (); - void handle_locations_change (ARDOUR::Location*); + ActionWindowProxy* _global_port_matrix[ARDOUR::DataType::num_types]; + void toggle_global_port_matrix (ARDOUR::DataType); static UIConfiguration *ui_config; ThemeManager *theme_manager; @@ -640,9 +605,11 @@ class ARDOUR_UI : public Gtkmm2ext::UI KeyEditor *key_editor; - /* Options window */ + /* RC Options window */ + + RCOptionEditor *rc_option_editor; - OptionEditor *option_editor; + SessionOptionEditor *session_option_editor; /* route dialog */ @@ -650,8 +617,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI /* Keyboard Handling */ - Keyboard* keyboard; - + ArdourKeyboard* keyboard; + /* Keymap handling */ void install_actions (); @@ -664,22 +631,22 @@ class ARDOUR_UI : public Gtkmm2ext::UI About* about; Splash* splash; void pop_back_splash (); - bool shown_flag; /* cleanup */ Gtk::MenuItem *cleanup_item; - void display_cleanup_results (ARDOUR::Session::cleanup_report& rep, const gchar* list_title, const string & msg); + void display_cleanup_results (ARDOUR::CleanupReport& rep, const gchar* list_title, + const std::string& plural_msg, const std::string& singular_msg); void cleanup (); void flush_trash (); bool have_configure_timeout; - struct timeval last_configure_time; + ARDOUR::microseconds_t last_configure_time; gint configure_timeout (); - struct timeval last_peak_grab; - struct timeval last_shuttle_request; + ARDOUR::microseconds_t last_peak_grab; + ARDOUR::microseconds_t last_shuttle_request; bool have_disk_speed_dialog_displayed; void disk_speed_dialog_gone (int ignored_response, Gtk::MessageDialog*); @@ -698,9 +665,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI Gtk::MenuItem* jack_reconnect_item; Gtk::Menu* jack_bufsize_menu; - int make_session_clean (); - bool filter_ardour_session_dirs (const Gtk::FileFilter::Info&); - Glib::RefPtr common_actions; void editor_realized (); @@ -711,61 +675,11 @@ class ARDOUR_UI : public Gtkmm2ext::UI void toggle_use_mmc (); void toggle_send_mmc (); void toggle_send_mtc (); - void toggle_use_midi_clock (); + void toggle_send_midi_clock (); void toggle_use_osc (); - void toggle_denormal_protection (); - - 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 set_remote_model (ARDOUR::RemoteModel); - void set_denormal_model (ARDOUR::DenormalModel); - - void toggle_sync_order_keys (); - void toggle_StopPluginsWithTransport(); - void toggle_DoNotRunPluginsWhileRecording(); - void toggle_VerifyRemoveLastCapture(); - void toggle_PeriodicSafetyBackups(); - void toggle_StopRecordingOnXrun(); - void toggle_CreateXrunMarker(); - void toggle_StopTransportAtEndOfSession(); - void toggle_GainReduceFastTransport(); - void toggle_LatchedSolo(); - void toggle_ShowSoloMutes(); - void toggle_LatchedRecordEnable (); - void toggle_RegionEquivalentsOverlap (); - void toggle_PrimaryClockDeltaEditCursor (); - void toggle_SecondaryClockDeltaEditCursor (); - void toggle_ShowTrackMeters (); - void toggle_only_copy_imported_files (); - void toggle_use_narrow_ms(); - void toggle_rubberbanding_snaps_to_grid (); - void toggle_auto_analyse_audio (); - void toggle_TapeMachineMode(); - - void mtc_port_changed (); - void map_solo_model (); - void map_monitor_model (); - void map_denormal_model (); - void map_denormal_protection (); - void map_remote_model (); - void map_file_header_format (); - void map_file_data_format (); - void map_input_auto_connect (); - void map_output_auto_connect (); - void map_only_copy_imported_files (); - 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); + void parameter_changed (std::string); bool first_idle (); @@ -776,8 +690,10 @@ class ARDOUR_UI : public Gtkmm2ext::UI void audioengine_setup (); void display_message (const char *prefix, gint prefix_len, - Glib::RefPtr ptag, Glib::RefPtr mtag, const char *msg); + Glib::RefPtr ptag, Glib::RefPtr mtag, + const char *msg); Gtk::Label status_bar_label; + bool status_bar_button_press (GdkEventButton*); Gtk::ToggleButton error_log_button; void loading_message (const std::string& msg); @@ -786,6 +702,18 @@ class ARDOUR_UI : public Gtkmm2ext::UI void platform_specific (); void platform_setup (); void fontconfig_dialog (); + void toggle_translations (); + + PBD::ScopedConnectionList forever_connections; + + void step_edit_status_change (bool); + + /* these are used only in response to a platform-specific "ShouldQuit" signal + */ + bool idle_finish (); + void queue_finish (); + + std::list _window_proxies; }; #endif /* __ardour_gui_h__ */