X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fmixer_ui.h;h=5a3b746457c6b15d4d4e9e40dafa222b4f1deb4c;hb=e9b4f14668a54e32e83005f0b09889372d1abe11;hp=41609e8de218c7bab84905d3ae203fa0b885cc8c;hpb=168b1471dc8bd2885cf39cc66d6548eb25e0919b;p=ardour.git diff --git a/gtk2_ardour/mixer_ui.h b/gtk2_ardour/mixer_ui.h index 41609e8de2..5a3b746457 100644 --- a/gtk2_ardour/mixer_ui.h +++ b/gtk2_ardour/mixer_ui.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2000 Paul Davis + Copyright (C) 2000 Paul Davis This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -31,34 +31,37 @@ #include #include #include +#include #include "pbd/stateful.h" +#include "pbd/signals.h" #include "ardour/ardour.h" +#include "ardour/session_handle.h" -#include "route_processor_selection.h" #include "enums.h" +#include "mixer_actor.h" namespace ARDOUR { class Route; class RouteGroup; - class Session; - class AudioDiskstream; }; class MixerStrip; class PluginSelector; class MixerGroupTabs; +class MonitorSection; -class Mixer_UI : public Gtk::Window +class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public ARDOUR::SessionHandlePtr, public MixerActor { public: - Mixer_UI (); + static Mixer_UI* instance(); ~Mixer_UI(); - void connect_to_session (ARDOUR::Session *); - - PluginSelector& plugin_selector() { return *_plugin_selector; } + void set_session (ARDOUR::Session *); + void track_editor_selection (); + + PluginSelector* plugin_selector(); void set_strip_width (Width); Width get_strip_width () const { return _strip_width; } @@ -78,13 +81,17 @@ class Mixer_UI : public Gtk::Window void toggle_auto_rebinding (); void set_auto_rebinding(bool); - RouteRedirectSelection& selection() { return _selection; } + MonitorSection* monitor_section() const { return _monitor_section; } + + protected: + void set_route_targets_for_operation (); private: - ARDOUR::Session *session; + Mixer_UI (); + static Mixer_UI* _instance; bool _visible; - + Gtk::HBox global_hpacker; Gtk::VBox global_vpacker; Gtk::ScrolledWindow scroller; @@ -108,22 +115,27 @@ class Mixer_UI : public Gtk::Window // for restoring window geometry. int m_root_x, m_root_y, m_width, m_height; - + 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*); - + std::list strips; bool strip_scroller_button_release (GdkEventButton*); + void scroll_left (); + void scroll_right (); void add_strip (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 (); @@ -138,13 +150,11 @@ class Mixer_UI : public Gtk::Window 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 (); - void disconnect_from_session (); - + void session_going_away (); + sigc::connection fast_screen_update_connection; void fast_update_strips (); @@ -154,7 +164,7 @@ class Mixer_UI : public Gtk::Window bool no_track_list_redisplay; 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); @@ -164,7 +174,7 @@ class Mixer_UI : public Gtk::Window void set_all_strips_visibility (bool yn); void set_all_audio_visibility (int tracks, bool yn); - + void hide_all_routes (); void show_all_routes (); void show_all_audiobus (); @@ -172,7 +182,6 @@ class Mixer_UI : public Gtk::Window void show_all_audiotracks(); void hide_all_audiotracks (); - Gtk::Menu* route_group_context_menu; bool in_group_row_change; void group_selected (gint row, gint col, GdkEvent *ev); @@ -180,26 +189,26 @@ class Mixer_UI : public Gtk::Window 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); void build_track_menu (); + MonitorSection* _monitor_section; PluginSelector *_plugin_selector; - void strip_name_changed (MixerStrip *); - - void group_flags_changed (void *src, ARDOUR::RouteGroup *); + void strip_property_changed (const PBD::PropertyChange&, MixerStrip *); + void route_group_property_changed (ARDOUR::RouteGroup *, const PBD::PropertyChange &); /* various treeviews */ - + struct TrackDisplayModelColumns : public Gtk::TreeModel::ColumnRecord { TrackDisplayModelColumns () { add (text); @@ -208,19 +217,19 @@ class Mixer_UI : public Gtk::Window add (strip); } Gtk::TreeModelColumn visible; - Gtk::TreeModelColumn text; + Gtk::TreeModelColumn text; Gtk::TreeModelColumn > route; Gtk::TreeModelColumn strip; }; struct GroupDisplayModelColumns : public Gtk::TreeModel::ColumnRecord { - GroupDisplayModelColumns() { + GroupDisplayModelColumns() { add (visible); add (text); add (group); } Gtk::TreeModelColumn visible; - Gtk::TreeModelColumn text; + Gtk::TreeModelColumn text; Gtk::TreeModelColumn group; }; @@ -238,8 +247,6 @@ class Mixer_UI : public Gtk::Window bool strip_button_release_event (GdkEventButton*, MixerStrip*); - RouteRedirectSelection _selection; - Width _strip_width; void sync_order_keys (std::string const &); @@ -250,10 +257,24 @@ class Mixer_UI : public Gtk::Window 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; + + void update_title (); + MixerStrip* strip_by_x (int x); + friend class MixerGroupTabs; + + void follow_editor_selection (); + bool _following_editor_selection; }; #endif /* __ardour_mixer_ui_h__ */