X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Froute_time_axis.h;h=576c3533340d9986c053e6d0e9325aeb23d0bb35;hb=035de2a367acd7ee27c3dbfba2f6c71f3c137eb8;hp=e318451832c58483ea6d2c8cddb6ed2b32b4474f;hpb=8aa9508c82f32efcf9c7c00e2c9e76268d4dddce;p=ardour.git diff --git a/gtk2_ardour/route_time_axis.h b/gtk2_ardour/route_time_axis.h index e318451832..576c353334 100644 --- a/gtk2_ardour/route_time_axis.h +++ b/gtk2_ardour/route_time_axis.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2006 Paul Davis + Copyright (C) 2006 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 @@ -20,6 +20,9 @@ #ifndef __ardour_route_time_axis_h__ #define __ardour_route_time_axis_h__ +#include +#include + #include #include #include @@ -31,22 +34,20 @@ #include #include -#include -#include +#include "ardour/playlist.h" +#include "ardour/types.h" #include "ardour_dialog.h" #include "route_ui.h" #include "enums.h" #include "time_axis_view.h" #include "canvas.h" -#include "level_meter.h" - +#include "gain_meter.h" namespace ARDOUR { class Session; class Region; - class Diskstream; class RouteGroup; class IOProcessor; class Processor; @@ -64,27 +65,29 @@ class AutomationTimeAxisView; class AutomationLine; class ProcessorAutomationLine; class TimeSelection; +class RouteGroupMenu; class RouteTimeAxisView : public RouteUI, public TimeAxisView { public: - RouteTimeAxisView (PublicEditor&, ARDOUR::Session&, boost::shared_ptr, ArdourCanvas::Canvas& canvas); + RouteTimeAxisView (PublicEditor&, ARDOUR::Session*, boost::shared_ptr, ArdourCanvas::Canvas& canvas); virtual ~RouteTimeAxisView (); void show_selection (TimeSelection&); + void set_button_names (); void set_samples_per_unit (double); - void set_height (TimeAxisView::TrackHeight); + void set_height (uint32_t h); void show_timestretch (nframes_t start, nframes_t end); void hide_timestretch (); void selection_click (GdkEventButton*); void set_selected_points (PointSelection&); void set_selected_regionviews (RegionSelection&); - void get_selectables (nframes_t start, nframes_t end, double top, double bot, list&); - void get_inverted_selectables (Selection&, list&); - bool show_automation(ARDOUR::Parameter param); + void get_selectables (nframes_t start, nframes_t end, double top, double bot, std::list&); + void get_inverted_selectables (Selection&, std::list&); void set_layer_display (LayerDisplay d); - + LayerDisplay layer_display () const; + boost::shared_ptr find_next_region (nframes_t pos, ARDOUR::RegionPoint, int32_t dir); nframes64_t find_next_region_boundary (nframes64_t pos, int32_t dir); @@ -94,37 +97,40 @@ public: TimeAxisView::Children get_child_list(); + void toggle_automation_track (const Evoral::Parameter& param); + /* The editor calls these when mapping an operation across multiple tracks */ - void use_new_playlist (bool prompt); - void use_copy_playlist (bool prompt); + void use_new_playlist (bool prompt, std::vector > const &); + void use_copy_playlist (bool prompt, std::vector > const &); void clear_playlist (); - + + /* group playlist name resolving */ + std::string resolve_new_group_playlist_name(std::string &, std::vector > const &); + + void build_playlist_menu (Gtk::Menu *); void add_underlay (StreamView*, bool update_xml = true); void remove_underlay (StreamView*); void build_underlay_menu(Gtk::Menu*); - /* This is a bit nasty to expose :/ */ - struct RouteAutomationNode { - ARDOUR::Parameter param; - Gtk::CheckMenuItem* menu_item; - boost::shared_ptr track; - - RouteAutomationNode (ARDOUR::Parameter par, Gtk::CheckMenuItem* mi, boost::shared_ptr tr) - : param (par), menu_item (mi), track (tr) {} - }; - - virtual void create_automation_child (ARDOUR::Parameter param, bool show) = 0; + int set_state (const XMLNode&, int version); - typedef map AutomationTracks; + virtual void create_automation_child (const Evoral::Parameter& param, bool show) = 0; + + /* make sure we get the right version of this */ + + XMLNode* get_automation_child_xml_node (Evoral::Parameter param) { return RouteUI::get_automation_child_xml_node (param); } + + typedef std::map > AutomationTracks; AutomationTracks automation_tracks() { return _automation_tracks; } - boost::shared_ptr automation_child(ARDOUR::Parameter param); + boost::shared_ptr automation_child(Evoral::Parameter param); + virtual Gtk::CheckMenuItem* automation_child_menu_item (Evoral::Parameter); - string name() const; + std::string name() const; StreamView* view() const { return _view; } - ARDOUR::RouteGroup* edit_group() const; + ARDOUR::RouteGroup* route_group() const; boost::shared_ptr playlist() const; void fast_update (); @@ -133,19 +139,21 @@ public: void reset_meter (); void clear_meter (); void io_changed (ARDOUR::IOChange, void *); - void meter_changed (void *); - void effective_gain_display (); + void meter_changed (); + void effective_gain_display () { gm.effective_gain_display(); } + + static void setup_slider_pix (); protected: friend class StreamView; struct ProcessorAutomationNode { - ARDOUR::Parameter what; - Gtk::CheckMenuItem* menu_item; + Evoral::Parameter what; + Gtk::CheckMenuItem* menu_item; boost::shared_ptr view; - RouteTimeAxisView& parent; + RouteTimeAxisView& parent; - ProcessorAutomationNode (ARDOUR::Parameter w, Gtk::CheckMenuItem* mitem, RouteTimeAxisView& p) + ProcessorAutomationNode (Evoral::Parameter w, Gtk::CheckMenuItem* mitem, RouteTimeAxisView& p) : what (w), menu_item (mitem), parent (p) {} ~ProcessorAutomationNode (); @@ -155,92 +163,81 @@ protected: boost::shared_ptr processor; bool valid; Gtk::Menu* menu; - vector lines; + std::vector lines; - ProcessorAutomationInfo (boost::shared_ptr i) + ProcessorAutomationInfo (boost::shared_ptr i) : processor (i), valid (true), menu (0) {} ~ProcessorAutomationInfo (); }; - - void diskstream_changed (); + void update_diskstream_display (); - + gint edit_click (GdkEventButton *); - void processors_changed (); - - void add_processor_to_subplugin_menu (boost::shared_ptr); + void processors_changed (ARDOUR::RouteProcessorChange); + + virtual void add_processor_to_subplugin_menu (boost::weak_ptr); void remove_processor_automation_node (ProcessorAutomationNode* pan); void processor_menu_item_toggled (RouteTimeAxisView::ProcessorAutomationInfo*, RouteTimeAxisView::ProcessorAutomationNode*); - + void processor_automation_track_hidden (ProcessorAutomationNode*, boost::shared_ptr); - - void automation_track_hidden (ARDOUR::Parameter param); - RouteAutomationNode* automation_track(ARDOUR::Parameter param); - RouteAutomationNode* automation_track(ARDOUR::AutomationType type); - - ProcessorAutomationNode* - find_processor_automation_node (boost::shared_ptr i, ARDOUR::Parameter); + void automation_track_hidden (Evoral::Parameter param); + ProcessorAutomationNode* + find_processor_automation_node (boost::shared_ptr i, Evoral::Parameter); + boost::shared_ptr - find_processor_automation_curve (boost::shared_ptr i, ARDOUR::Parameter); + find_processor_automation_curve (boost::shared_ptr i, Evoral::Parameter); - void add_processor_automation_curve (boost::shared_ptr r, ARDOUR::Parameter); - void add_existing_processor_automation_curves (boost::shared_ptr); + void add_processor_automation_curve (boost::shared_ptr r, Evoral::Parameter); + void add_existing_processor_automation_curves (boost::weak_ptr); + + void add_automation_child(Evoral::Parameter param, boost::shared_ptr track, bool show=true); - void add_automation_child(ARDOUR::Parameter param, boost::shared_ptr track, bool show=true); - void reset_processor_automation_curves (); void take_name_changed (void *src); - void route_name_changed (); + void route_property_changed (const PBD::PropertyChange&); void name_entry_changed (); void update_rec_display (); virtual void label_view (); - - void add_edit_group_menu_item (ARDOUR::RouteGroup *, Gtk::RadioMenuItem::Group*); - void set_edit_group_from_menu (ARDOUR::RouteGroup *); + + void set_route_group_from_menu (ARDOUR::RouteGroup *); void reset_samples_per_unit (); void select_track_color(); - + virtual void build_automation_action_menu (); virtual void append_extra_display_menu_items () {} void build_display_menu (); - + void align_style_changed (); void set_align_style (ARDOUR::AlignStyle); - - virtual void set_playlist (boost::shared_ptr); + void playlist_click (); void show_playlist_selector (); void playlist_changed (); - void playlist_modified (); void rename_current_playlist (); - + void automation_click (); - void toggle_automation_track (ARDOUR::Parameter param); virtual void show_all_automation (); virtual void show_existing_automation (); virtual void hide_all_automation (); void timestretch (nframes_t start, nframes_t end); - void visual_click (); - void hide_click (); - void speed_changed (); - + void map_frozen (); void color_handler (); @@ -250,76 +247,66 @@ protected: StreamView* _view; ArdourCanvas::Canvas& parent_canvas; bool no_redraw; - + Gtk::HBox other_button_hbox; Gtk::Table button_table; Gtk::Button processor_button; - Gtk::Button edit_group_button; + Gtk::Button route_group_button; Gtk::Button playlist_button; - Gtk::Button size_button; Gtk::Button automation_button; - Gtk::Button hide_button; - Gtk::Button visual_button; - + Gtk::Menu subplugin_menu; Gtk::Menu* automation_action_menu; - Gtk::Menu edit_group_menu; + Gtk::MenuItem* plugins_submenu_item; + RouteGroupMenu* route_group_menu; Gtk::RadioMenuItem* align_existing_item; Gtk::RadioMenuItem* align_capture_item; Gtk::RadioMenuItem* normal_track_mode_item; + Gtk::RadioMenuItem* non_layered_track_mode_item; Gtk::RadioMenuItem* destructive_track_mode_item; Gtk::Menu* playlist_menu; Gtk::Menu* playlist_action_menu; Gtk::MenuItem* playlist_item; Gtk::Menu* mode_menu; + Gtk::Menu* color_mode_menu; - virtual Gtk::Menu* build_mode_menu() { return NULL; } + virtual Gtk::Menu* build_color_mode_menu() { return 0; } - void use_playlist (boost::weak_ptr); + void use_playlist (Gtk::RadioMenuItem *item, boost::weak_ptr wpl); ArdourCanvas::SimpleRect* timestretch_rect; void set_track_mode (ARDOUR::TrackMode); - void _set_track_mode (ARDOUR::Track* track, ARDOUR::TrackMode mode, Gtk::RadioMenuItem* reset_item); + void _set_track_mode (ARDOUR::Track* track, ARDOUR::TrackMode mode, Gtk::RadioMenuItem* reset_item, Gtk::RadioMenuItem* reset_item_2); void track_mode_changed (); - list processor_automation; + std::list processor_automation; - typedef vector > ProcessorAutomationCurves; + typedef std::vector > ProcessorAutomationCurves; ProcessorAutomationCurves processor_automation_curves; - - // Set from XML so context menu automation buttons can be correctly initialized - set _show_automation; AutomationTracks _automation_tracks; - - sigc::connection modified_connection; + typedef std::map ParameterMenuMap; + /** parameter -> menu item map for the main automation menu */ + ParameterMenuMap _main_automation_menu_map; + /** parameter -> menu item map for the plugin automation menu */ + ParameterMenuMap _subplugin_menu_map; void post_construct (); - - void set_state (const XMLNode&); - - XMLNode* get_automation_child_xml_node (ARDOUR::Parameter param); - LevelMeter lm; + GainMeterBase gm; + + static Glib::RefPtr slider; XMLNode* underlay_xml_node; bool set_underlay_state(); - typedef list UnderlayList; + typedef std::list UnderlayList; UnderlayList _underlay_streams; - typedef list UnderlayMirrorList; + typedef std::list UnderlayMirrorList; UnderlayMirrorList _underlay_mirrors; - Gtkmm2ext::HSliderController *gain_slider; - Gtk::Adjustment gain_adjustment; - static Glib::RefPtr slider; - static int setup_slider_pix (); - void gain_adjusted(); - - gint start_gain_touch (GdkEventButton*); - gint end_gain_touch (GdkEventButton*); - void gain_changed (); + bool _ignore_track_mode_change; ///< true to ignore track mode change signals }; #endif /* __ardour_route_time_axis_h__ */