X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fardour_ui.h;h=1fd73e472c14ff2ee4da691894e3048318c1d34c;hb=03d28648208bbb1be9108593e9327b6375ecb5ef;hp=a05cca96bd7ce4557a140c6e3fbfd82a34c687c1;hpb=b99b507be9cb290ff9fc2d6197af045964eb68a2;p=ardour.git diff --git a/gtk2_ardour/ardour_ui.h b/gtk2_ardour/ardour_ui.h index a05cca96bd..1fd73e472c 100644 --- a/gtk2_ardour/ardour_ui.h +++ b/gtk2_ardour/ardour_ui.h @@ -61,20 +61,22 @@ #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 BundleManager; class ConnectionEditor; class KeyEditor; -class Keyboard; class LocationUIWindow; class Mixer_UI; class PublicEditor; @@ -83,6 +85,9 @@ class RouteParams_UI; class SessionOptionEditor; class Splash; class ThemeManager; +class MidiTracer; +class WindowProxyBase; +class GlobalPortMatrixWindow; namespace Gtkmm2ext { class TearOff; @@ -100,39 +105,32 @@ namespace ARDOUR { 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(); - 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; } + ARDOUR::Session* the_session() { return _session; } bool will_create_new_session_automatically() const { return _will_create_new_session_automatically; @@ -142,18 +140,18 @@ class ARDOUR_UI : public Gtkmm2ext::UI _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); + int get_session_parameters (bool quit_on_cancel, bool should_be_new = false, std::string load_template = ""); + void parse_cmdline_path (const std::string& cmdline_path, std::string& session_name, std::string& session_path, bool& existing_session); + int load_cmdline_session (const std::string& session_name, const std::string& session_path, bool& existing_session); + 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 = ""); + 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); @@ -169,8 +167,10 @@ class ARDOUR_UI : public Gtkmm2ext::UI void toggle_theme_manager (); void toggle_bundle_manager (); void toggle_big_clock_window (); + void new_midi_tracer_window (); void toggle_route_params_window (); void toggle_editing_space(); + void toggle_keep_tearoffs(); Gtk::Tooltips& tooltips() { return _tooltips; } @@ -182,11 +182,12 @@ class ARDOUR_UI : public Gtkmm2ext::UI 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 do_transport_locate (nframes_t, bool); void halt_on_xrun_message (); void xrun_handler (nframes_t); void create_xrun_marker (nframes_t); @@ -198,6 +199,9 @@ class ARDOUR_UI : public Gtkmm2ext::UI 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); @@ -227,9 +231,13 @@ class ARDOUR_UI : public Gtkmm2ext::UI 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; @@ -254,13 +262,12 @@ class ARDOUR_UI : public Gtkmm2ext::UI private: ArdourStartup* _startup; ARDOUR::AudioEngine *engine; - ARDOUR::Session *session; Gtk::Tooltips _tooltips; void goto_editor_window (); void goto_mixer_window (); - void toggle_editor_mixer_on_top (); - bool _mixer_on_top; + void toggle_mixer_window (); + void toggle_mixer_on_top (); Gtk::ToggleButton preroll_button; Gtk::ToggleButton postroll_button; @@ -285,7 +292,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI 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 (); @@ -300,7 +307,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI void about_signal_response(int response); - private: Gtk::VBox top_packer; sigc::connection clock_signal_connection; @@ -311,7 +317,16 @@ class ARDOUR_UI : public Gtkmm2ext::UI void manage_window (Gtk::Window&); AudioClock big_clock; - 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); @@ -319,6 +334,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI 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); @@ -327,6 +344,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; @@ -355,8 +374,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&); @@ -384,6 +403,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI BindableButton auto_loop_button; BindableButton play_selection_button; BindableButton rec_button; + Gtk::ToggleButton join_play_range_button; void toggle_external_sync (); void toggle_time_master (); @@ -440,8 +460,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI 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); void big_clock_value_changed (); void primary_clock_value_changed (); @@ -458,8 +478,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI add (visible_name); add (fullpath); } - Gtk::TreeModelColumn visible_name; - Gtk::TreeModelColumn fullpath; + Gtk::TreeModelColumn visible_name; + Gtk::TreeModelColumn fullpath; }; RecentSessionModelColumns recent_session_columns; @@ -517,6 +537,12 @@ class ARDOUR_UI : public Gtkmm2ext::UI sigc::connection point_oh_five_second_connection; sigc::connection point_zero_one_second_connection; + AudioClock _menu_bar_clock; + sigc::connection _menu_bar_clock_connection; + void menu_bar_clock_value_changed (); + void show_menu_bar_clock (); + void hide_menu_bar_clock (); + gint session_menu (GdkEventButton *); bool _will_create_new_session_automatically; @@ -550,7 +576,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI 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 (); @@ -558,7 +584,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 (); @@ -572,10 +598,13 @@ class ARDOUR_UI : public Gtkmm2ext::UI 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; @@ -595,8 +624,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI /* Keyboard Handling */ - Keyboard* keyboard; - + ArdourKeyboard* keyboard; + /* Keymap handling */ void install_actions (); @@ -609,7 +638,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI About* about; Splash* splash; void pop_back_splash (); - bool shown_flag; /* cleanup */ @@ -627,19 +655,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI 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 (); @@ -685,6 +700,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI 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); @@ -693,6 +709,20 @@ 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; + + int missing_file (ARDOUR::Session*s, std::string str, ARDOUR::DataType type); }; #endif /* __ardour_gui_h__ */