X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fmixer_ui.h;h=916ef5aa21bea6255d05eaf4992686f0be8b0538;hb=8d81f121e5b68030eea5444c3ebad14d6a0bfa82;hp=7431c030b60ce8b985312413e919f5174cea9097;hpb=dffa3861baeb837c41d0c3090923d28089c3e981;p=ardour.git diff --git a/gtk2_ardour/mixer_ui.h b/gtk2_ardour/mixer_ui.h index 7431c030b6..916ef5aa21 100644 --- a/gtk2_ardour/mixer_ui.h +++ b/gtk2_ardour/mixer_ui.h @@ -42,10 +42,12 @@ #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 "enums.h" #include "mixer_actor.h" @@ -59,12 +61,28 @@ class PluginSelector; class MixerGroupTabs; class MonitorSection; -class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public ARDOUR::SessionHandlePtr, public MixerActor, public Gtkmm2ext::VisibilityTracker +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: 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 (); @@ -76,22 +94,18 @@ class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public AR 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 maximise_mixer_space(); void restore_mixer_space(); - void ensure_float (Gtk::Window&); - MonitorSection* monitor_section() const { return _monitor_section; } void deselect_all_strip_processors(); @@ -99,22 +113,22 @@ class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public AR void select_none (); + bool window_not_visible () const; + protected: void set_route_targets_for_operation (); private: Mixer_UI (); - static Mixer_UI* _instance; - - 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; + 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; @@ -138,8 +152,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*); @@ -185,6 +197,24 @@ class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public AR 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 (); @@ -259,9 +289,11 @@ class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public AR add (plugin); } Gtk::TreeModelColumn name; - Gtk::TreeModelColumn plugin; + Gtk::TreeModelColumn plugin; }; + ARDOUR::PluginInfoList favorite_order; + std::map favorite_ui_state; TrackDisplayModelColumns track_columns; GroupDisplayModelColumns group_columns; @@ -269,11 +301,11 @@ class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public AR Gtk::TreeView track_display; Gtk::TreeView group_display; - Gtkmm2ext::DnDTreeView favorite_plugins_display; + Gtkmm2ext::DnDTreeView favorite_plugins_display; Glib::RefPtr track_model; Glib::RefPtr group_model; - Glib::RefPtr favorite_plugins_model; + Glib::RefPtr favorite_plugins_model; bool group_display_button_press (GdkEventButton*); void group_display_selection_changed (); @@ -317,8 +349,12 @@ class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public AR void monitor_section_attached (); void monitor_section_detached (); - void refiller (ARDOUR::PluginManager& manager, const ARDOUR::PluginInfoList& plugs); + 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; @@ -328,5 +364,3 @@ class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public AR }; #endif /* __ardour_mixer_ui_h__ */ - -