X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=gtk2_ardour%2Fmixer_ui.h;h=e5985f830c20ec180071b6c7b31d2be9862fac4d;hb=eedeb4949d16e5415ba790a042c5db6d83580b36;hp=c8d3bacae00fce801ca0a0febe0f649c78e024a5;hpb=f0748535a5023d132eff03999a705a3e56c516db;p=ardour.git diff --git a/gtk2_ardour/mixer_ui.h b/gtk2_ardour/mixer_ui.h index c8d3bacae0..e5985f830c 100644 --- a/gtk2_ardour/mixer_ui.h +++ b/gtk2_ardour/mixer_ui.h @@ -31,20 +31,30 @@ #include #include #include +#include #include "pbd/stateful.h" #include "pbd/signals.h" #include "ardour/ardour.h" +#include "ardour/types.h" #include "ardour/session_handle.h" +#include "ardour/plugin.h" +#include "ardour/plugin_manager.h" + + +#include "gtkmm2ext/visibility_tracker.h" +#include "gtkmm2ext/dndtreeview.h" +#include "gtkmm2ext/treeutils.h" + +#include "gtkmm2ext/tabbable.h" -#include "route_processor_selection.h" #include "enums.h" +#include "mixer_actor.h" namespace ARDOUR { class Route; class RouteGroup; - class AudioDiskstream; }; class MixerStrip; @@ -52,55 +62,85 @@ class PluginSelector; class MixerGroupTabs; class MonitorSection; -class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public ARDOUR::SessionHandlePtr +class PluginTreeStore : public Gtk::TreeStore +{ +public: + static Glib::RefPtr create(const Gtk::TreeModelColumnRecord& columns) { + return Glib::RefPtr (new PluginTreeStore (columns)); + } + +protected: + PluginTreeStore (const Gtk::TreeModelColumnRecord& columns) : Gtk::TreeStore (columns) {} + virtual bool row_draggable_vfunc (const Gtk::TreeModel::Path&) const { return true; } + virtual bool row_drop_possible_vfunc (const Gtk::TreeModel::Path&, const Gtk::SelectionData&) const; +}; + +class Mixer_UI : public Gtkmm2ext::Tabbable, public PBD::ScopedConnectionList, public ARDOUR::SessionHandlePtr, public MixerActor, public Gtkmm2ext::VisibilityTracker { public: - Mixer_UI (); + static Mixer_UI* instance(); ~Mixer_UI(); + Gtk::Window* use_own_window (bool and_fill_it); + void show_window (); + void set_session (ARDOUR::Session *); + void track_editor_selection (); PluginSelector* plugin_selector(); - void set_strip_width (Width); + void set_strip_width (Width, bool save = false); Width get_strip_width () const { return _strip_width; } void unselect_strip_in_display (MixerStrip*); void select_strip_in_display (MixerStrip*); - XMLNode& get_state (void); - int set_state (const XMLNode& ); + XMLNode& get_state (); + int set_state (const XMLNode&, int /* version */); + + void show_mixer_list (bool yn); + void show_monitor_section (bool); - void show_window (); - bool hide_window (GdkEventAny *ev); void show_strip (MixerStrip *); void hide_strip (MixerStrip *); - void ensure_float (Gtk::Window&); - void toggle_auto_rebinding (); - void set_auto_rebinding(bool); + void maximise_mixer_space(); + void restore_mixer_space(); - RouteRedirectSelection& selection() { return _selection; } MonitorSection* monitor_section() const { return _monitor_section; } + void deselect_all_strip_processors(); + void delete_processors(); + + void select_none (); + + bool window_not_visible () const; + + protected: + void set_route_targets_for_operation (); + private: - bool _visible; - - Gtk::HBox global_hpacker; - Gtk::VBox global_vpacker; - Gtk::ScrolledWindow scroller; - Gtk::EventBox scroller_base; - Gtk::HBox scroller_hpacker; - Gtk::VBox mixer_scroller_vpacker; - Gtk::VBox list_vpacker; + Mixer_UI (); + static Mixer_UI* _instance; + Gtk::VBox _content; + Gtk::HBox global_hpacker; + Gtk::VBox global_vpacker; + Gtk::ScrolledWindow scroller; + Gtk::EventBox scroller_base; + Gtk::HBox scroller_hpacker; + Gtk::VBox mixer_scroller_vpacker; + Gtk::VBox list_vpacker; Gtk::Label group_display_button_label; Gtk::Button group_display_button; Gtk::ScrolledWindow track_display_scroller; Gtk::ScrolledWindow group_display_scroller; + Gtk::ScrolledWindow favorite_plugins_scroller; Gtk::VBox group_display_vbox; Gtk::Frame track_display_frame; Gtk::Frame group_display_frame; + Gtk::Frame favorite_plugins_frame; Gtk::VPaned rhs_pane1; + Gtk::VPaned rhs_pane2; Gtk::HBox strip_packer; Gtk::HBox out_packer; Gtk::HPaned list_hpane; @@ -113,8 +153,6 @@ class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public AR void set_window_pos_and_size (); void get_window_pos_and_size (); - bool on_key_press_event (GdkEventKey*); - bool on_key_release_event (GdkEventKey*); bool on_scroll_event (GdkEventScroll*); void pane_allocation_handler (Gtk::Allocation&, Gtk::Paned*); @@ -124,10 +162,13 @@ class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public AR bool strip_scroller_button_release (GdkEventButton*); void scroll_left (); void scroll_right (); + void toggle_midi_input_active (bool flip_others); - void add_strip (ARDOUR::RouteList&); + void add_strips (ARDOUR::RouteList&); void remove_strip (MixerStrip *); + MixerStrip* strip_by_route (boost::shared_ptr); + void hide_all_strips (bool with_select); void unselect_all_strips(); void select_all_strips (); @@ -136,14 +177,9 @@ class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public AR void unselect_all_audiobus_strips (); void select_all_audiobus_strips (); - void auto_rebind_midi_controls (); - bool auto_rebinding; - void strip_select_op (bool audiotrack, bool select); void select_strip_op (MixerStrip*, bool select); - void follow_strip_selection (); - gint start_updating (); gint stop_updating (); @@ -159,15 +195,34 @@ class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public AR bool track_display_button_press (GdkEventButton*); void strip_width_changed (); - void track_list_change (const Gtk::TreeModel::Path&,const Gtk::TreeModel::iterator&); void track_list_delete (const Gtk::TreeModel::Path&); void track_list_reorder (const Gtk::TreeModel::Path& path, const Gtk::TreeModel::iterator& iter, int* new_order); + void plugin_row_activated (const Gtk::TreeModel::Path& path, Gtk::TreeViewColumn* column); + bool plugin_row_button_press (GdkEventButton*); + void popup_note_context_menu (GdkEventButton*); + void plugin_drop (const Glib::RefPtr&, const Gtk::SelectionData& data); + + enum ProcessorPosition { + AddTop, + AddPreFader, + AddPostFader, + AddBottom + }; + + void add_selected_processor (ProcessorPosition); + void add_favorite_processor (ARDOUR::PluginPresetPtr, ProcessorPosition); + void remove_selected_from_favorites (); + void delete_selected_preset (); + ARDOUR::PluginPresetPtr selected_plugin (); + void initial_track_display (); void show_track_list_menu (); void set_all_strips_visibility (bool yn); - void set_all_audio_visibility (int tracks, bool yn); + void set_all_audio_midi_visibility (int, bool); + void track_visibility_changed (std::string const & path); + void update_track_visibility (); void hide_all_routes (); void show_all_routes (); @@ -175,8 +230,9 @@ class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public AR void hide_all_audiobus (); void show_all_audiotracks(); void hide_all_audiotracks (); + void show_all_miditracks(); + void hide_all_miditracks (); - Gtk::Menu* route_group_context_menu; bool in_group_row_change; void group_selected (gint row, gint col, GdkEvent *ev); @@ -184,13 +240,13 @@ class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public AR void group_display_active_clicked(); void new_route_group (); void remove_selected_route_group (); - void build_route_group_context_menu (); void activate_all_route_groups (); void disable_all_route_groups (); void add_route_group (ARDOUR::RouteGroup *); void route_groups_changed (); - void route_group_name_edit (const Glib::ustring&, const Glib::ustring&); + void route_group_name_edit (const std::string&, const std::string&); void route_group_row_change (const Gtk::TreeModel::Path& path,const Gtk::TreeModel::iterator& iter); + void route_group_row_deleted (Gtk::TreeModel::Path const &); Gtk::Menu *track_menu; void track_column_click (gint); @@ -200,8 +256,7 @@ class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public AR PluginSelector *_plugin_selector; void strip_property_changed (const PBD::PropertyChange&, MixerStrip *); - - void group_flags_changed (void *src, ARDOUR::RouteGroup *); + void route_group_property_changed (ARDOUR::RouteGroup *, const PBD::PropertyChange &); /* various treeviews */ @@ -213,7 +268,7 @@ class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public AR add (strip); } Gtk::TreeModelColumn visible; - Gtk::TreeModelColumn text; + Gtk::TreeModelColumn text; Gtk::TreeModelColumn > route; Gtk::TreeModelColumn strip; }; @@ -225,42 +280,88 @@ class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public AR add (group); } Gtk::TreeModelColumn visible; - Gtk::TreeModelColumn text; + Gtk::TreeModelColumn text; Gtk::TreeModelColumn group; }; + struct PluginsDisplayModelColumns : public Gtk::TreeModel::ColumnRecord { + PluginsDisplayModelColumns() { + add (name); + add (plugin); + } + Gtk::TreeModelColumn name; + Gtk::TreeModelColumn plugin; + }; + + ARDOUR::PluginInfoList favorite_order; + std::map favorite_ui_state; + TrackDisplayModelColumns track_columns; GroupDisplayModelColumns group_columns; + PluginsDisplayModelColumns favorite_plugins_columns; Gtk::TreeView track_display; Gtk::TreeView group_display; + Gtkmm2ext::DnDTreeView favorite_plugins_display; Glib::RefPtr track_model; Glib::RefPtr group_model; + Glib::RefPtr favorite_plugins_model; bool group_display_button_press (GdkEventButton*); void group_display_selection_changed (); bool strip_button_release_event (GdkEventButton*, MixerStrip*); - RouteRedirectSelection _selection; - Width _strip_width; - void sync_order_keys (std::string const &); - bool strip_redisplay_does_not_reset_order_keys; - bool strip_redisplay_does_not_sync_order_keys; - bool ignore_sync; + void sync_order_keys_from_treeview (); + void sync_treeview_from_order_keys (); + void reset_remote_control_ids (); + void reset_order_keys (); + + bool ignore_reorder; void parameter_changed (std::string const &); void set_route_group_activation (ARDOUR::RouteGroup *, bool); + void setup_track_display (); + void new_track_or_bus (); + static const int32_t default_width = 478; static const int32_t default_height = 765; + /** true if we are rebuilding the route group list, or clearing + it during a session teardown. + */ + bool _in_group_rebuild_or_clear; + bool _route_deletion_in_progress; + + void update_title (); + MixerStrip* strip_by_x (int x); + friend class MixerGroupTabs; -}; -#endif /* __ardour_mixer_ui_h__ */ + void follow_editor_selection (); + bool _following_editor_selection; + + void monitor_section_going_away (); + void monitor_section_attached (); + void monitor_section_detached (); + void store_current_favorite_order(); + void refiller (ARDOUR::PluginInfoList& result, const ARDOUR::PluginInfoList& plugs); + void refill_favorite_plugins (); + void sync_treeview_from_favorite_order (); + void sync_treeview_favorite_ui_state (const Gtk::TreeModel::Path&, const Gtk::TreeModel::iterator&); + void save_favorite_ui_state (const Gtk::TreeModel::iterator& iter, const Gtk::TreeModel::Path& path); + + /// true if we are in fullscreen mode + bool _maximised; + + // true if mixer list is visible + bool _show_mixer_list; +}; + +#endif /* __ardour_mixer_ui_h__ */