X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fmixer_ui.h;h=01460b61dcb7f20b6c871dfb778a1af5e0571339;hb=d8ade6d30595a3a8be343b392e47d422940eac27;hp=f1f004351ae2435565e4d2abebd087fa839a9f01;hpb=cdc2d055f1ede3d9565dbf2b2d1abbf87a1f622c;p=ardour.git diff --git a/gtk2_ardour/mixer_ui.h b/gtk2_ardour/mixer_ui.h index f1f004351a..01460b61dc 100644 --- a/gtk2_ardour/mixer_ui.h +++ b/gtk2_ardour/mixer_ui.h @@ -15,7 +15,6 @@ along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. - $Id$ */ #ifndef __ardour_mixer_ui_h__ @@ -33,20 +32,19 @@ #include #include +#include + #include -#include #include -#include "keyboard_target.h" -#include "route_redirect_selection.h" +#include "route_processor_selection.h" #include "enums.h" namespace ARDOUR { class Route; class RouteGroup; class Session; - class DiskStream; - class AudioEngine; + class AudioDiskstream; }; class MixerStrip; @@ -55,7 +53,7 @@ class PluginSelector; class Mixer_UI : public Gtk::Window { public: - Mixer_UI (ARDOUR::AudioEngine&); + Mixer_UI (); ~Mixer_UI(); void connect_to_session (ARDOUR::Session *); @@ -72,48 +70,59 @@ class Mixer_UI : public Gtk::Window int set_state (const XMLNode& ); 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); RouteRedirectSelection& selection() { return _selection; } + + static const char* get_order_key(); private: - ARDOUR::AudioEngine& engine; ARDOUR::Session *session; + + 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; + Gtk::Label group_display_button_label; + Gtk::Button group_display_button; + Gtk::ScrolledWindow track_display_scroller; + Gtk::ScrolledWindow group_display_scroller; + Gtk::VBox group_display_vbox; + Gtk::Frame track_display_frame; + Gtk::Frame group_display_frame; + Gtk::VPaned rhs_pane1; + Gtk::HBox strip_packer; + Gtk::HBox out_packer; + Gtk::HPaned list_hpane; + + // for restoring window geometry. + int m_root_x, m_root_y, m_width, m_height; - 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 snapshot_display_scroller; - Gtk::VBox group_display_vbox; - Gtk::Frame track_display_frame; - Gtk::Frame group_display_frame; - Gtk::VPaned rhs_pane1; - Gtk::VPaned rhs_pane2; - Gtk::HBox strip_packer; - Gtk::HBox out_packer; - Gtk::HPaned list_hpane; + void set_window_pos_and_size (); + void get_window_pos_and_size (); + + bool on_key_press_event (GdkEventKey*); void pane_allocation_handler (Gtk::Allocation&, Gtk::Paned*); list strips; - gint strip_scroller_button_release (GdkEventButton*); + bool strip_scroller_button_release (GdkEventButton*); - void add_strip (ARDOUR::Route*); + void add_strip (ARDOUR::Session::RouteList&); void remove_strip (MixerStrip *); - void show_strip (MixerStrip *); - void hide_strip (MixerStrip *); - void hide_all_strips (bool with_select); void unselect_all_strips(); void select_all_strips (); @@ -122,6 +131,9 @@ class Mixer_UI : public Gtk::Window 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); @@ -132,23 +144,47 @@ class Mixer_UI : public Gtk::Window void disconnect_from_session (); - sigc::connection screen_update_connection; - void update_strips (); sigc::connection fast_screen_update_connection; void fast_update_strips (); - void track_display_selected (gint row, gint col, GdkEvent *ev); - void track_display_unselected (gint row, gint col, GdkEvent *ev); - void queue_track_display_reordered (gint row, gint col); - void track_display_reordered_proxy (const Gtk::TreePath& path, const Gtk::TreeIter& i, int* n); - void track_display_reordered (); void track_name_changed (MixerStrip *); + void redisplay_track_list (); + bool no_track_list_redisplay; + bool track_display_button_press (GdkEventButton*); + + 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 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 hide_all_routes (); + void show_all_routes (); + void show_all_audiobus (); + void hide_all_audiobus (); + void show_all_audiotracks(); + void hide_all_audiotracks (); + + Gtk::Menu* mix_group_context_menu; + bool in_group_row_change; + void group_selected (gint row, gint col, GdkEvent *ev); void group_unselected (gint row, gint col, GdkEvent *ev); void group_display_active_clicked(); void new_mix_group (); + void remove_selected_mix_group (); + void build_mix_group_context_menu (); + void activate_all_mix_groups (); + void disable_all_mix_groups (); void add_mix_group (ARDOUR::RouteGroup *); + void mix_groups_changed (); + void mix_group_name_edit (const Glib::ustring&, const Glib::ustring&); + void mix_group_row_change (const Gtk::TreeModel::Path& path,const Gtk::TreeModel::iterator& iter); Gtk::Menu *track_menu; void track_column_click (gint); @@ -156,78 +192,61 @@ class Mixer_UI : public Gtk::Window PluginSelector *_plugin_selector; - void strip_name_changed (void *src, MixerStrip *); - - static GdkPixmap *check_pixmap; - static GdkBitmap *check_mask; - static GdkPixmap *empty_pixmap; - static GdkBitmap *empty_mask; + void strip_name_changed (MixerStrip *); void group_flags_changed (void *src, ARDOUR::RouteGroup *); /* various treeviews */ struct TrackDisplayModelColumns : public Gtk::TreeModel::ColumnRecord { - TrackDisplayModelColumns() { + TrackDisplayModelColumns () { add (text); + add (visible); add (route); add (strip); } + Gtk::TreeModelColumn visible; Gtk::TreeModelColumn text; - Gtk::TreeModelColumn route; + Gtk::TreeModelColumn > route; Gtk::TreeModelColumn strip; }; struct GroupDisplayModelColumns : public Gtk::TreeModel::ColumnRecord { GroupDisplayModelColumns() { add (active); + add (visible); add (text); add (group); } - Gtk::TreeModelColumn active; - Gtk::TreeModelColumn text; - Gtk::TreeModelColumn group; + Gtk::TreeModelColumn active; + Gtk::TreeModelColumn visible; + Gtk::TreeModelColumn text; + Gtk::TreeModelColumn group; }; - struct SnapshotDisplayModelColumns : public Gtk::TreeModel::ColumnRecord { - SnapshotDisplayModelColumns() { - add (visible_name); - add (real_name); - } - Gtk::TreeModelColumn visible_name; - Gtk::TreeModelColumn real_name; - }; - - TrackDisplayModelColumns track_display_columns; - GroupDisplayModelColumns group_display_columns; - SnapshotDisplayModelColumns snapshot_display_columns; + TrackDisplayModelColumns track_columns; + GroupDisplayModelColumns group_columns; Gtk::TreeView track_display; Gtk::TreeView group_display; - Gtk::TreeView snapshot_display; - Glib::RefPtr track_display_model; - Glib::RefPtr group_display_model; - Glib::RefPtr snapshot_display_model; + Glib::RefPtr track_model; + Glib::RefPtr group_model; - bool track_display_button_press (GdkEventButton*); bool group_display_button_press (GdkEventButton*); - bool snapshot_display_button_press (GdkEventButton*); - - void track_display_selection_changed (); void group_display_selection_changed (); - void snapshot_display_selection_changed (); - - void redisplay_snapshots(); - void session_state_saved (string); - gint strip_button_release_event (GdkEventButton*, MixerStrip*); + bool strip_button_release_event (GdkEventButton*, MixerStrip*); RouteRedirectSelection _selection; Width _strip_width; - static const int32_t default_width = -1; + void sync_order_keys (); + bool ignore_route_reorder; + bool ignore_sync; + + static const int32_t default_width = 478; static const int32_t default_height = 765; };