X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Froute_time_axis.h;h=d9b957dbab38ebea4d0ee6c0b72b91a6dc50bcf9;hb=89d6f40e33933b12a40079e391a96856bfa79e2a;hp=1f53cd200c8bb32b638fedf9dee3dccc1fee59cd;hpb=c899ba4368e61f31820a34c5e7c9a48345a364a2;p=ardour.git diff --git a/gtk2_ardour/route_time_axis.h b/gtk2_ardour/route_time_axis.h index 1f53cd200c..d9b957dbab 100644 --- a/gtk2_ardour/route_time_axis.h +++ b/gtk2_ardour/route_time_axis.h @@ -78,25 +78,22 @@ public: void set_samples_per_unit (double); void set_height (uint32_t h); - void show_timestretch (nframes_t start, nframes_t end); + void show_timestretch (framepos_t start, framepos_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, std::list&); + void get_selectables (ARDOUR::framepos_t start, ARDOUR::framepos_t end, double top, double bot, std::list&); void get_inverted_selectables (Selection&, std::list&); - bool show_automation(Evoral::Parameter param); - void set_layer_display (LayerDisplay d); + void set_layer_display (LayerDisplay d, bool apply_to_selection = false); 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); + boost::shared_ptr find_next_region (framepos_t pos, ARDOUR::RegionPoint, int32_t dir); + framepos_t find_next_region_boundary (framepos_t pos, int32_t dir); /* Editing operations */ - bool cut_copy_clear (Selection&, Editing::CutCopyOp); - bool paste (nframes_t, float times, Selection&, size_t nth); - - TimeAxisView::Children get_child_list(); + void cut_copy_clear (Selection&, Editing::CutCopyOp); + bool paste (ARDOUR::framepos_t, float times, Selection&, size_t nth); void toggle_automation_track (const Evoral::Parameter& param); @@ -108,8 +105,7 @@ public: /* group playlist name resolving */ std::string resolve_new_group_playlist_name(std::string &, std::vector > const &); - - void build_playlist_menu (Gtk::Menu *); + void build_playlist_menu (); void add_underlay (StreamView*, bool update_xml = true); void remove_underlay (StreamView*); @@ -117,27 +113,18 @@ public: int set_state (const XMLNode&, int version); - /* This is a bit nasty to expose :/ */ - struct RouteAutomationNode { - Evoral::Parameter param; - Gtk::CheckMenuItem* menu_item; - boost::shared_ptr track; - - RouteAutomationNode (Evoral::Parameter par, Gtk::CheckMenuItem* mi, boost::shared_ptr tr) - : param (par), menu_item (mi), track (tr) {} - }; - 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; + typedef std::map > AutomationTracks; AutomationTracks automation_tracks() { return _automation_tracks; } boost::shared_ptr automation_child(Evoral::Parameter param); - + virtual Gtk::CheckMenuItem* automation_child_menu_item (Evoral::Parameter); + std::string name() const; StreamView* view() const { return _view; } ARDOUR::RouteGroup* route_group() const; @@ -184,11 +171,11 @@ protected: void update_diskstream_display (); - gint edit_click (GdkEventButton *); + gint route_group_click (GdkEventButton *); void processors_changed (ARDOUR::RouteProcessorChange); - void add_processor_to_subplugin_menu (boost::weak_ptr); + virtual void add_processor_to_subplugin_menu (boost::weak_ptr); void remove_processor_automation_node (ProcessorAutomationNode* pan); void processor_menu_item_toggled (RouteTimeAxisView::ProcessorAutomationInfo*, @@ -199,9 +186,6 @@ protected: void automation_track_hidden (Evoral::Parameter param); - RouteAutomationNode* automation_track(Evoral::Parameter param); - RouteAutomationNode* automation_track(ARDOUR::AutomationType type); - ProcessorAutomationNode* find_processor_automation_node (boost::shared_ptr i, Evoral::Parameter); @@ -226,15 +210,15 @@ protected: void set_route_group_from_menu (ARDOUR::RouteGroup *); void reset_samples_per_unit (); + void horizontal_position_changed (); - void select_track_color(); + void set_color (Gdk::Color const &); 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); + void set_align_style (ARDOUR::AlignStyle, bool apply_to_selection = false); void playlist_click (); void show_playlist_selector (); @@ -247,7 +231,7 @@ protected: virtual void show_existing_automation (); virtual void hide_all_automation (); - void timestretch (nframes_t start, nframes_t end); + void timestretch (framepos_t start, framepos_t end); void speed_changed (); @@ -257,6 +241,10 @@ protected: void region_view_added (RegionView*); + void create_gain_automation_child (const Evoral::Parameter &, bool); + + boost::shared_ptr gain_track; + StreamView* _view; ArdourCanvas::Canvas& parent_canvas; bool no_redraw; @@ -272,12 +260,6 @@ protected: Gtk::Menu* automation_action_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; @@ -289,19 +271,19 @@ protected: ArdourCanvas::SimpleRect* timestretch_rect; - void set_track_mode (ARDOUR::TrackMode); - void _set_track_mode (ARDOUR::Track* track, ARDOUR::TrackMode mode, Gtk::RadioMenuItem* reset_item, Gtk::RadioMenuItem* reset_item_2); - void track_mode_changed (); + void set_track_mode (ARDOUR::TrackMode, bool apply_to_selection = false); std::list processor_automation; typedef std::vector > ProcessorAutomationCurves; ProcessorAutomationCurves processor_automation_curves; - // Set from XML so context menu automation buttons can be correctly initialized - std::set _show_automation; - AutomationTracks _automation_tracks; + 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 ();