X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fardour_ui.h;h=1c952324791b8e1329238119a9f13494784c9014;hb=e344f57a305d7f33f883cd18abcf22bd6ad39e27;hp=ddb2ec3bdd61ec1c8335c350e453e5d5e859baf2;hpb=718b2eab6706f304e398f036e3d817567cd746e8;p=ardour.git diff --git a/gtk2_ardour/ardour_ui.h b/gtk2_ardour/ardour_ui.h index ddb2ec3bdd..1c95232479 100644 --- a/gtk2_ardour/ardour_ui.h +++ b/gtk2_ardour/ardour_ui.h @@ -58,16 +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; @@ -75,9 +79,11 @@ 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; @@ -87,9 +93,11 @@ class ShuttleControl; class Splash; class SpeakerDialog; class ThemeManager; +class TimeInfoBox; class MidiTracer; class WindowProxyBase; class GlobalPortMatrixWindow; +class GUIObjectState; namespace Gtkmm2ext { class TearOff; @@ -102,6 +110,7 @@ namespace ARDOUR { class Route; class RouteGroup; class Location; + class ProcessThread; } class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr @@ -131,17 +140,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr 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, 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); @@ -190,15 +189,17 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr void save_ardour_state (); gboolean configure_handler (GdkEventConfigure* conf); - void do_transport_locate (framepos_t, bool); void halt_on_xrun_message (); void xrun_handler (framepos_t); void create_xrun_marker (framepos_t); - AudioClock primary_clock; - AudioClock secondary_clock; - AudioClock preroll_clock; - AudioClock postroll_clock; + GUIObjectState* gui_object_state; + + MainClock* primary_clock; + MainClock* secondary_clock; + void focus_on_clock (); + + TimeInfoBox* time_info_box; void store_clock_modes (); void restore_clock_modes (); @@ -216,30 +217,23 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr 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 ( - int input_channels, - int32_t output_channels, - ARDOUR::RouteGroup* route_group, - uint32_t how_many, - std::string const & name_template - ) { - + 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, - std::string const & name_template - ) { - - session_add_midi_route (true, route_group, how_many, name_template); + 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); }*/ @@ -252,8 +246,9 @@ 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); @@ -261,10 +256,12 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr 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 (); @@ -287,13 +284,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_mixer_window (); - void toggle_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 (); @@ -301,11 +295,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(); @@ -339,7 +332,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr void manage_window (Gtk::Window&); - AudioClock big_clock; + AudioClock* big_clock; ActionWindowProxy* big_clock_window; int original_big_clock_width; int original_big_clock_height; @@ -350,6 +343,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr 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); @@ -398,8 +393,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr void set_value (double); double get_value (void) const; - void set_id (const std::string&); - ARDOUR_UI& ui; ToggleType type; }; @@ -411,21 +404,21 @@ 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; - boost::shared_ptr join_play_range_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; - BindableToggleButton 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; + + ButtonJoiner* transport_joiner; void toggle_external_sync (); void toggle_time_master (); @@ -433,23 +426,22 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr ShuttleControl* shuttle_box; - 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; + ArdourButton auto_return_button; + ArdourButton auto_play_button; + ArdourButton auto_input_button; + ArdourButton click_button; + ArdourButton sync_button; - Gtk::ToggleButton auditioning_alert_button; - Gtk::ToggleButton solo_alert_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); @@ -457,6 +449,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr 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 (); @@ -504,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 (ARDOUR::framecnt_t); + Gtk::Label format_label; + void update_format (); + gint every_second (); gint every_point_one_seconds (); gint every_point_zero_one_seconds (); @@ -532,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 (); @@ -544,18 +534,15 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr void import_metadata (); 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 &); + 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(); @@ -574,6 +561,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr guint32 last_key_press_time; void snapshot_session (bool switch_to_it); + void rename_session (); Mixer_UI *mixer; int create_mixer (); @@ -614,7 +602,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr /* Keyboard Handling */ ArdourKeyboard* keyboard; - + /* Keymap handling */ void install_actions (); @@ -626,7 +614,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr About* about; Splash* splash; - void pop_back_splash (); + + void pop_back_splash (Gtk::Window&); /* cleanup */ @@ -676,6 +665,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 (); @@ -693,21 +683,21 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr Gtk::ToggleButton error_log_button; void loading_message (const std::string& msg); - void end_loading_messages (); - void platform_specific (); - void platform_setup (); - void fontconfig_dialog (); 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 (); std::list _window_proxies; @@ -715,6 +705,23 @@ class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr 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__ */