X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Froute_time_axis.h;h=3a5bc34250e8c2eda23e088ece75352913ee12a6;hb=a5de2c10679cc920a7409d02e32e6dd67778ea75;hp=18733f1e746111d6cf7213956ee0c2ad39d0896c;hpb=955d731fa6933e6769986687a781d16f7889da67;p=ardour.git diff --git a/gtk2_ardour/route_time_axis.h b/gtk2_ardour/route_time_axis.h index 18733f1e74..3a5bc34250 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 @@ -38,6 +38,7 @@ #include "ardour/playlist.h" #include "ardour/types.h" +#include "ardour_button.h" #include "ardour_dialog.h" #include "route_ui.h" #include "enums.h" @@ -45,11 +46,9 @@ #include "canvas.h" #include "gain_meter.h" - namespace ARDOUR { class Session; class Region; - class Diskstream; class RouteGroup; class IOProcessor; class Processor; @@ -67,36 +66,41 @@ 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*, ArdourCanvas::Canvas& canvas); virtual ~RouteTimeAxisView (); + void set_route (boost::shared_ptr); + void show_selection (TimeSelection&); + void set_button_names (); 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, int layers, int layer); 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); - /* Editing operations */ - bool cut_copy_clear (Selection&, Editing::CutCopyOp); - bool paste (nframes_t, float times, Selection&, size_t nth); + 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); - TimeAxisView::Children get_child_list(); + /* Editing operations */ + void cut_copy_clear (Selection&, Editing::CutCopyOp); + bool paste (ARDOUR::framepos_t, float times, Selection&, size_t nth); + RegionView* combine_regions (); + void uncombine_regions (); + void uncombine_region (RegionView*); + 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, std::vector > const &); @@ -106,36 +110,22 @@ 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*); void build_underlay_menu(Gtk::Menu*); - - int set_state (const XMLNode&); - - /* 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) {} - }; + + int set_state (const XMLNode&, int version); 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; @@ -147,10 +137,10 @@ public: void reset_meter (); void clear_meter (); void io_changed (ARDOUR::IOChange, void *); - void meter_changed (void *); + void meter_changed (); void effective_gain_display () { gm.effective_gain_display(); } - static void setup_slider_pix (); + std::string state_id() const; protected: friend class StreamView; @@ -173,37 +163,33 @@ protected: Gtk::Menu* menu; 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::weak_ptr); + gint route_group_click (GdkEventButton *); + + 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 (Evoral::Parameter param); - RouteAutomationNode* automation_track(Evoral::Parameter param); - RouteAutomationNode* automation_track(ARDOUR::AutomationType type); + 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, Evoral::Parameter); @@ -211,115 +197,95 @@ protected: void add_existing_processor_automation_curves (boost::weak_ptr); void add_automation_child(Evoral::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_route_group_menu_item (ARDOUR::RouteGroup *, Gtk::RadioMenuItem::Group*); - void set_route_group_from_menu (ARDOUR::RouteGroup *); - void set_route_group_to_new (); void reset_samples_per_unit (); + void horizontal_position_changed (); - void select_track_color(); - - virtual void build_automation_action_menu (); + virtual void build_automation_action_menu (bool); 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 set_align_choice (Gtk::RadioMenuItem*, ARDOUR::AlignChoice, bool apply_to_selection = false); + void playlist_click (); void show_playlist_selector (); void playlist_changed (); - void playlist_modified (); void rename_current_playlist (); - - void automation_click (); - void toggle_automation_track (Evoral::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 automation_click (); - void visual_click (); - void hide_click (); + virtual void show_all_automation (bool apply_to_selection = false); + virtual void show_existing_automation (bool apply_to_selection = false); + virtual void hide_all_automation (bool apply_to_selection = false); + void timestretch (framepos_t start, framepos_t end); void speed_changed (); - void map_frozen (); - void color_handler (); - void region_view_added (RegionView*); + void create_gain_automation_child (const Evoral::Parameter &, bool); + void setup_processor_menu_and_curves (); + void route_color_changed (); + bool can_edit_name() const; + + boost::shared_ptr gain_track; StreamView* _view; ArdourCanvas::Canvas& parent_canvas; bool no_redraw; - + Gtk::HBox other_button_hbox; Gtk::Table button_table; - Gtk::Button processor_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; - + ArdourButton route_group_button; + ArdourButton playlist_button; + ArdourButton automation_button; + Gtk::Menu subplugin_menu; Gtk::Menu* automation_action_menu; - Gtk::Menu 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::MenuItem* plugins_submenu_item; + RouteGroupMenu* route_group_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 0; } 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, Gtk::RadioMenuItem* reset_item_2); - void track_mode_changed (); + void set_track_mode (ARDOUR::TrackMode, bool apply_to_selection = false); + /** Information about all automatable processor parameters that apply to + * this route. The Amp processor is not included in this list. + */ 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; - - 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 (); - - GainMeterBase gm; - static Glib::RefPtr slider; + GainMeterBase gm; XMLNode* underlay_xml_node; bool set_underlay_state(); @@ -328,6 +294,13 @@ protected: UnderlayList _underlay_streams; typedef std::list UnderlayMirrorList; UnderlayMirrorList _underlay_mirrors; + + bool _ignore_set_layer_display; + +private: + + void remove_child (boost::shared_ptr); + void update_playlist_tip (); }; #endif /* __ardour_route_time_axis_h__ */