X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fexport_channel_selector.h;h=bc165273c73f1b66e81d32a6303253bae6348e68;hb=37b1f5017e904005fae6b815b1519b3fa595d8d3;hp=c2e99940aa7f5a48e122848028abfb39980461de;hpb=98389f7da420ee205f6827b7df4db3ea0802f751;p=ardour.git diff --git a/gtk2_ardour/export_channel_selector.h b/gtk2_ardour/export_channel_selector.h index c2e99940aa..bc165273c7 100644 --- a/gtk2_ardour/export_channel_selector.h +++ b/gtk2_ardour/export_channel_selector.h @@ -23,8 +23,11 @@ #include -#include -#include +#include "ardour/export_profile_manager.h" + +#ifdef interface +#undef interface +#endif #include #include @@ -43,16 +46,25 @@ namespace ARDOUR { class XMLNode; -class ExportChannelSelector : public Gtk::HBox +class ExportChannelSelector : public Gtk::HBox, public ARDOUR::SessionHandlePtr { protected: typedef boost::shared_ptr ChannelConfigPtr; - typedef boost::shared_ptr HandlerPtr; + typedef std::list ChannelConfigList; + typedef boost::shared_ptr ProfileManagerPtr; + + ProfileManagerPtr manager; public: + ExportChannelSelector (ARDOUR::Session * session, ProfileManagerPtr manager) + : SessionHandlePtr (session) + , manager (manager) + {} + virtual ~ExportChannelSelector () {} - - virtual void set_state (ARDOUR::ExportProfileManager::ChannelConfigStatePtr const state_, ARDOUR::Session * session_) = 0; + + virtual void sync_with_manager () = 0; + sigc::signal CriticalSelectionChanged; }; @@ -61,10 +73,10 @@ class PortExportChannelSelector : public ExportChannelSelector public: - PortExportChannelSelector (); + PortExportChannelSelector (ARDOUR::Session * session, ProfileManagerPtr manager); ~PortExportChannelSelector (); - - void set_state (ARDOUR::ExportProfileManager::ChannelConfigStatePtr const state_, ARDOUR::Session * session_); + + void sync_with_manager (); private: @@ -74,7 +86,6 @@ class PortExportChannelSelector : public ExportChannelSelector typedef std::list CahnnelList; - ARDOUR::Session * session; ARDOUR::ExportProfileManager::ChannelConfigStatePtr state; /*** GUI stuff ***/ @@ -85,101 +96,101 @@ class PortExportChannelSelector : public ExportChannelSelector Gtk::Label channels_label; Gtk::SpinButton channels_spinbutton; Gtk::CheckButton split_checkbox; - + /* Column record for channel selector view */ - + class RouteCols : public Gtk::TreeModelColumnRecord { public: - + struct Channel; - + RouteCols () : n_channels (0) { add (selected); add (name); add (io); add (port_list_col); } - + void add_channels (uint32_t chans); uint32_t n_channels; - + /* Channel count starts from one! */ - + Channel & get_channel (uint32_t channel); - + /* Static columns */ - + Gtk::TreeModelColumn selected; - Gtk::TreeModelColumn name; + Gtk::TreeModelColumn name; Gtk::TreeModelColumn io; - + /* Combo list column (shared by all channels) */ - + typedef Gtk::TreeModelColumn > ComboCol; ComboCol port_list_col; - + /* Channel struct, that represents the selected port and it's name */ - + struct Channel { public: Channel (RouteCols & cols) { cols.add (port); cols.add (label); } - - Gtk::TreeModelColumn port; - Gtk::TreeModelColumn label; + + Gtk::TreeModelColumn > port; + Gtk::TreeModelColumn label; }; std::list channels; - + /* List of available ports * Note: We need only one list of selectable ports per route, * so the list is kept in the column record */ - + /* Column record for selecting ports for a channel from a route */ - + class PortCols : public Gtk::TreeModel::ColumnRecord { public: - PortCols () { add (selected); add(port); add(label); } - - Gtk::TreeModelColumn selected; // not used ATM - Gtk::TreeModelColumn port; - Gtk::TreeModelColumn label; + PortCols () { add(selected); add(port); add(label); } + + Gtk::TreeModelColumn selected; // not used ATM + Gtk::TreeModelColumn > port; + Gtk::TreeModelColumn label; }; PortCols port_cols; }; - + /* Channels view */ - + class ChannelTreeView : public Gtk::TreeView { public: - + ChannelTreeView (uint32_t max_channels); void set_config (ChannelConfigPtr c); - + /* Routes have to be added before adding channels */ - + void clear_routes () { route_list->clear (); } void add_route (ARDOUR::IO * route); void set_channel_count (uint32_t channels); - + sigc::signal CriticalSelectionChanged; - + private: - + ChannelConfigPtr config; void update_config (); - + /* Signal handlers for selections changes in the view */ - - void update_toggle_selection (Glib::ustring const & path); - void update_selection_text (Glib::ustring const & path, Glib::ustring const & new_text, uint32_t channel); - + + void update_toggle_selection (std::string const & path); + void update_selection_text (std::string const & path, std::string const & new_text, uint32_t channel); + RouteCols route_cols; Glib::RefPtr route_list; - + uint32_t static_columns; uint32_t n_channels; }; - + uint32_t max_channels; - + Gtk::ScrolledWindow channel_scroller; Gtk::Alignment channel_alignment; ChannelTreeView channel_view; @@ -189,30 +200,72 @@ class PortExportChannelSelector : public ExportChannelSelector class RegionExportChannelSelector : public ExportChannelSelector { public: - RegionExportChannelSelector (ARDOUR::AudioRegion const & region, ARDOUR::AudioTrack & track); - - virtual void set_state (ARDOUR::ExportProfileManager::ChannelConfigStatePtr const state_, ARDOUR::Session * session_); + RegionExportChannelSelector (ARDOUR::Session * session, + ProfileManagerPtr manager, + ARDOUR::AudioRegion const & region, + ARDOUR::AudioTrack & track); + + virtual void sync_with_manager (); private: void handle_selection (); - ARDOUR::Session * session; ARDOUR::ExportProfileManager::ChannelConfigStatePtr state; boost::shared_ptr factory; ARDOUR::AudioRegion const & region; ARDOUR::AudioTrack & track; - + uint32_t region_chans; uint32_t track_chans; - + /*** GUI components ***/ - + Gtk::VBox vbox; - + Gtk::RadioButtonGroup type_group; Gtk::RadioButton raw_button; + Gtk::RadioButton fades_button; Gtk::RadioButton processed_button; }; +class TrackExportChannelSelector : public ExportChannelSelector +{ + public: + TrackExportChannelSelector (ARDOUR::Session * session, ProfileManagerPtr manager); + + virtual void sync_with_manager (); + + private: + + void fill_list(); + void add_track (boost::shared_ptr route); + void update_config(); + + ChannelConfigList configs; + + Gtk::VBox main_layout; + + struct TrackCols : public Gtk::TreeModelColumnRecord + { + public: + Gtk::TreeModelColumn > route; + Gtk::TreeModelColumn label; + Gtk::TreeModelColumn selected; + + TrackCols () { add (route); add(label); add(selected); } + }; + TrackCols track_cols; + + Glib::RefPtr track_list; + Gtk::TreeView track_view; + + Gtk::ScrolledWindow track_scroller; + + Gtk::HBox options_box; + Gtk::RadioButton::Group source_group; + Gtk::RadioButton region_contents_button; + Gtk::RadioButton track_output_button; +}; + #endif /* __export_channel_selector_h__ */