X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fardour_ui.h;h=0af4cd6d2a3c78ce960b23d3b365463d73d363ee;hb=00e1b1410c98e96a283ff4f4ab87dad2f8d1e5a2;hp=a807261127ac6e37c7373ae6cc43103e82fb7ce7;hpb=b5148d93d5a9e6949f82f8685cab50cb772f2b9d;p=ardour.git diff --git a/gtk2_ardour/ardour_ui.h b/gtk2_ardour/ardour_ui.h index a807261127..0af4cd6d2a 100644 --- a/gtk2_ardour/ardour_ui.h +++ b/gtk2_ardour/ardour_ui.h @@ -58,15 +58,20 @@ #include #include #include + #include "ardour/ardour.h" #include "ardour/types.h" #include "ardour/utils.h" +#include "ardour/plugin.h" #include "ardour/session_handle.h" -#include "audio_clock.h" #include "ardour_dialog.h" +#include "ardour_button.h" #include "editing.h" #include "ui_config.h" +#include "window_proxy.h" +#include "enums.h" +#include "visibility_group.h" class About; class AddRouteDialog; @@ -74,16 +79,25 @@ class ArdourStartup; class ArdourKeyboard; class AudioClock; class BundleManager; +class ButtonJoiner; class ConnectionEditor; class KeyEditor; class LocationUIWindow; +class MainClock; class Mixer_UI; class PublicEditor; class RCOptionEditor; class RouteParams_UI; class SessionOptionEditor; +class ShuttleControl; class Splash; +class SpeakerDialog; class ThemeManager; +class TimeInfoBox; +class MidiTracer; +class WindowProxyBase; +class GlobalPortMatrixWindow; +class GUIObjectState; namespace Gtkmm2ext { class TearOff; @@ -96,68 +110,48 @@ namespace ARDOUR { class Route; class RouteGroup; class Location; + class ProcessThread; } -extern sigc::signal ColorsChanged; -extern sigc::signal DPIReset; - class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr { public: ARDOUR_UI (int *argcp, char **argvp[]); ~ARDOUR_UI(); - bool run_startup (bool should_be_new); - - 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 idle_load (const std::string& path); void finish(); - int load_session (const Glib::ustring& path, const Glib::ustring& snapshot, Glib::ustring mix_template = Glib::ustring()); + int load_session (const std::string& path, const std::string& snapshot, std::string mix_template = std::string()); 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 std::string& path, const std::string& snapshot, ARDOUR::BusProfile&); bool session_is_new() const { return _session_is_new; } ARDOUR::Session* the_session() { return _session; } - bool will_create_new_session_automatically() const { - return _will_create_new_session_automatically; - } - - void set_will_create_new_session_automatically (bool yn) { - _will_create_new_session_automatically = yn; - } - - int get_session_parameters (bool quit_on_cancel, bool should_be_new = false); - 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); - bool ask_about_loading_existing_session (const Glib::ustring& session_path); + bool get_smart_mode () const; + + int get_session_parameters (bool quit_on_cancel, bool should_be_new = false, std::string load_template = ""); + int build_session_from_nsd (const std::string& session_name, const std::string& session_path); + bool ask_about_loading_existing_session (const std::string& session_path); /// @return true if session was successfully unloaded. int unload_session (bool hide_stuff = false); void close_session(); - int save_state_canfail (std::string state_name = ""); - void save_state (const std::string & state_name = ""); - - static double gain_to_slider_position (ARDOUR::gain_t g); - static ARDOUR::gain_t slider_position_to_gain (double pos); + 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 ARDOUR_UI *instance () { return theArdourUI; } static UIConfiguration *config () { return ui_config; } @@ -170,51 +164,78 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr void toggle_theme_manager (); void toggle_bundle_manager (); void toggle_big_clock_window (); + void toggle_speaker_config_window (); + void new_midi_tracer_window (); void toggle_route_params_window (); void toggle_editing_space(); + void toggle_keep_tearoffs(); Gtk::Tooltips& tooltips() { return _tooltips; } + Gtk::HBox& editor_transport_box() { return _editor_transport_box; } + + static PublicEditor* _instance; static sigc::signal Blink; static sigc::signal RapidScreenUpdate; static sigc::signal SuperRapidScreenUpdate; - static sigc::signal Clock; + /** Emitted frequently with the audible frame, false, and the edit point as + * parameters respectively. + */ + static sigc::signal Clock; 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); - void do_transport_locate (nframes_t position); void halt_on_xrun_message (); - void xrun_handler (nframes_t); - void create_xrun_marker (nframes_t); + void xrun_handler (framepos_t); + void create_xrun_marker (framepos_t); + + GUIObjectState* gui_object_state; + + MainClock* primary_clock; + MainClock* secondary_clock; + void focus_on_clock (); - AudioClock primary_clock; - AudioClock secondary_clock; - AudioClock preroll_clock; - AudioClock postroll_clock; + TimeInfoBox* time_info_box; void store_clock_modes (); void restore_clock_modes (); void reset_main_clocks (); + void synchronize_sync_source_and_video_pullup (); + void add_route (Gtk::Window* float_window); - 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_track ( + int input_channels, + int32_t output_channels, + ARDOUR::TrackMode mode, + ARDOUR::RouteGroup* route_group, + uint32_t how_many, + std::string const & name_template + ) { + + session_add_audio_route (true, input_channels, output_channels, mode, route_group, how_many, name_template); } - 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_audio_bus (int input_channels, int32_t output_channels, ARDOUR::RouteGroup* route_group, + uint32_t how_many, std::string const & name_template) { + session_add_audio_route (false, input_channels, output_channels, ARDOUR::Normal, route_group, how_many, name_template); } - 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_track (ARDOUR::RouteGroup* route_group, uint32_t how_many, std::string const & name_template, + ARDOUR::PluginInfoPtr instrument) { + session_add_midi_route (true, route_group, how_many, name_template, instrument); } + void session_add_mixed_track (const ARDOUR::ChanCount& input, const ARDOUR::ChanCount& output, ARDOUR::RouteGroup* route_group, uint32_t how_many, std::string const & name_template, + ARDOUR::PluginInfoPtr instrument); + /*void session_add_midi_bus () { session_add_midi_route (false); }*/ @@ -227,16 +248,22 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr void maximise_editing_space (); void restore_editing_space (); + void update_tearoff_visibility (); + void setup_profile (); - void setup_theme (); void setup_tooltips (); void set_shuttle_fract (double); + void add_window_proxy (WindowProxyBase *); + void remove_window_proxy (WindowProxyBase *); + + void get_process_buffers (); + void drop_process_buffers (); + protected: friend class PublicEditor; - void toggle_clocking (); void toggle_auto_play (); void toggle_auto_input (); void toggle_punch (); @@ -259,13 +286,10 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr ARDOUR::AudioEngine *engine; Gtk::Tooltips _tooltips; - 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; + void goto_editor_window (); + void goto_mixer_window (); + void toggle_mixer_window (); + void toggle_mixer_on_top (); int setup_windows (); void setup_transport (); @@ -273,11 +297,10 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr static ARDOUR_UI *theArdourUI; - void backend_audio_error (bool we_set_params, Gtk::Window* toplevel = 0); void startup (); void shutdown (); - int ask_about_saving_session (const std::string & why); + int ask_about_saving_session (const std::vector& actions); /* periodic safety backup, to be precise */ gint autosave_session(); @@ -287,7 +310,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr 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 (); @@ -302,7 +325,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr void about_signal_response(int response); - private: Gtk::VBox top_packer; sigc::connection clock_signal_connection; @@ -312,20 +334,30 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr void manage_window (Gtk::Window&); - AudioClock big_clock; - Gtk::Window* big_clock_window; + AudioClock* big_clock; + 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 big_clock_catch_focus (); + void big_clock_reset_aspect_ratio (); 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); + ActionWindowProxy* speaker_config_window; + + void update_transport_clocks (framepos_t pos); void record_state_changed (); + std::list _midi_tracer_windows; + /* Transport Control */ void detach_tearoff (Gtk::Box* parent, Gtk::Widget* contents); @@ -334,8 +366,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr 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 _editor_transport_box; Gtk::HBox transport_hbox; Gtk::Fixed transport_base; Gtk::Fixed transport_button_base; @@ -349,7 +380,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr Gtk::HBox primary_clock_hbox; Gtk::HBox secondary_clock_hbox; - struct TransportControllable : public PBD::Controllable { enum ToggleType { Roll = 0, @@ -359,15 +389,11 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr GotoEnd, AutoLoop, PlaySelection, - ShuttleControl - }; TransportControllable (std::string name, ARDOUR_UI&, ToggleType); - void set_value (float); - float get_value (void) const; - - void set_id (const std::string&); + void set_value (double); + double get_value (void) const; ARDOUR_UI& ui; ToggleType type; @@ -380,78 +406,50 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr 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 toggle_always_play_range (); void set_transport_controllable_state (const XMLNode&); XMLNode& get_transport_controllable_state (); - BindableButton roll_button; - BindableButton stop_button; - BindableButton goto_start_button; - BindableButton goto_end_button; - BindableButton auto_loop_button; - BindableButton play_selection_button; - BindableButton rec_button; - Gtk::ToggleButton join_play_range_button; + ArdourButton roll_button; + ArdourButton stop_button; + ArdourButton goto_start_button; + ArdourButton goto_end_button; + ArdourButton auto_loop_button; + ArdourButton play_selection_button; + ArdourButton rec_button; void toggle_external_sync (); 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_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); - void use_shuttle_fract (bool force); - - bool shuttle_grabbed; - double shuttle_fract; - - Gtkmm2ext::StatefulToggleButton punch_in_button; - Gtkmm2ext::StatefulToggleButton punch_out_button; - Gtkmm2ext::StatefulToggleButton auto_return_button; - Gtkmm2ext::StatefulToggleButton auto_play_button; - 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; + ShuttleControl* shuttle_box; + + ArdourButton auto_return_button; + ArdourButton follow_edits_button; + ArdourButton auto_input_button; + ArdourButton click_button; + ArdourButton sync_button; + + ArdourButton auditioning_alert_button; + ArdourButton solo_alert_button; + ArdourButton feedback_alert_button; Gtk::VBox alert_box; void solo_blink (bool); void sync_blink (bool); void audition_blink (bool); + void feedback_blink (bool); void soloing_changed (bool); void auditioning_changed (bool); void _auditioning_changed (bool); - - void solo_alert_toggle (); - void audition_alert_toggle (); + + bool solo_alert_press (GdkEventButton* ev); + bool audition_alert_press (GdkEventButton* ev); + bool feedback_alert_press (GdkEventButton *); void big_clock_value_changed (); void primary_clock_value_changed (); @@ -468,8 +466,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr add (visible_name); add (fullpath); } - Gtk::TreeModelColumn visible_name; - Gtk::TreeModelColumn fullpath; + Gtk::TreeModelColumn visible_name; + Gtk::TreeModelColumn fullpath; }; RecentSessionModelColumns recent_session_columns; @@ -499,25 +497,26 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr void build_menu_bar (); Gtk::Label wall_clock_label; - Gtk::EventBox wall_clock_box; gint update_wall_clock (); Gtk::Label disk_space_label; - Gtk::EventBox disk_space_box; void update_disk_space (); + Gtk::Label timecode_format_label; + void update_timecode_format (); + Gtk::Label cpu_load_label; - Gtk::EventBox cpu_load_box; void update_cpu_load (); 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 (nframes_t); + void update_sample_rate (ARDOUR::framecnt_t); + Gtk::Label format_label; + void update_format (); + gint every_second (); gint every_point_one_seconds (); gint every_point_zero_one_seconds (); @@ -527,10 +526,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr sigc::connection point_oh_five_second_connection; sigc::connection point_zero_one_second_connection; - gint session_menu (GdkEventButton *); - - bool _will_create_new_session_automatically; - void open_session (); void open_recent_session (); void save_template (); @@ -538,22 +533,20 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr 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 session_add_audio_route (bool, int32_t, int32_t, ARDOUR::TrackMode, ARDOUR::RouteGroup *, uint32_t, std::string const &); + void session_add_midi_route (bool, ARDOUR::RouteGroup *, uint32_t, std::string const &, ARDOUR::PluginInfoPtr); void set_transport_sensitivity (bool); - void remove_last_capture (); - 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); void transport_roll (); void transport_play_selection(); + void transport_play_preroll(); void transport_forward (int option); void transport_rewind (int option); void transport_loop (); @@ -568,7 +561,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr guint32 last_key_press_time; - void snapshot_session (); + void snapshot_session (bool switch_to_it); + void rename_session (); Mixer_UI *mixer; int create_mixer (); @@ -582,10 +576,13 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr BundleManager *bundle_manager; void create_bundle_manager (); - LocationUIWindow *location_ui; + ActionWindowProxy* 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; @@ -606,7 +603,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr /* Keyboard Handling */ ArdourKeyboard* keyboard; - + /* Keymap handling */ void install_actions (); @@ -618,8 +615,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr About* about; Splash* splash; - void pop_back_splash (); - bool shown_flag; + + void pop_back_splash (Gtk::Window&); /* cleanup */ @@ -637,19 +634,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr ARDOUR::microseconds_t last_peak_grab; ARDOUR::microseconds_t last_shuttle_request; - struct DiskBufferStat { - time_t when; - uint32_t capture; - uint32_t playback; - - DiskBufferStat (time_t w, uint32_t c, uint32_t p) - : when (w), capture (c), playback (p) {} - }; - - std::list disk_buffer_stats; - void push_buffer_stats (uint32_t, uint32_t); - void write_buffer_stats (); - bool have_disk_speed_dialog_displayed; void disk_speed_dialog_gone (int ignored_response, Gtk::MessageDialog*); void disk_overrun_handler (); @@ -657,11 +641,11 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr void session_dialog (std::string); int pending_state_dialog (); - int sr_mismatch_dialog (nframes_t, nframes_t); + int sr_mismatch_dialog (ARDOUR::framecnt_t, ARDOUR::framecnt_t); void disconnect_from_jack (); void reconnect_to_jack (); - void set_jack_buffer_size (nframes_t); + void set_jack_buffer_size (ARDOUR::pframes_t); Gtk::MenuItem* jack_disconnect_item; Gtk::MenuItem* jack_reconnect_item; @@ -682,6 +666,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr void toggle_use_osc (); void parameter_changed (std::string); + void session_parameter_changed (std::string); bool first_idle (); @@ -695,16 +680,49 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr 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); - void end_loading_messages (); + + void toggle_translations (); + + PBD::ScopedConnectionList forever_connections; + + void step_edit_status_change (bool); void platform_specific (); void platform_setup (); + + /* these are used only in response to a platform-specific "ShouldQuit" signal + */ + bool idle_finish (); + void queue_finish (); void fontconfig_dialog (); - PBD::ScopedConnectionList forever_connections; + std::list _window_proxies; + + int missing_file (ARDOUR::Session*s, std::string str, ARDOUR::DataType type); + int ambiguous_file (std::string file, std::string path, std::vector hits); + + bool click_button_clicked (GdkEventButton *); + + VisibilityGroup _status_bar_visibility; + + /** A ProcessThread so that we have some thread-local buffers for use by + * PluginEqGui::impulse_analysis (). + */ + ARDOUR::ProcessThread* _process_thread; + + void feedback_detected (); + + ArdourButton midi_panic_button; + void midi_panic (); + + void successful_graph_sort (); + bool _feedback_exists; + + void resize_text_widgets (); }; #endif /* __ardour_gui_h__ */