introduce GUIObjectState; massive, pervasive changes in visibility and height managem...
[ardour.git] / gtk2_ardour / route_time_axis.h
index bffa126a1446ac3a8b84c020aab9cfa1dd4f48ef..5952ddfb316587bd25b9b82abb426111d33f920d 100644 (file)
@@ -70,9 +70,11 @@ class RouteGroupMenu;
 class RouteTimeAxisView : public RouteUI, public TimeAxisView
 {
 public:
-       RouteTimeAxisView (PublicEditor&, ARDOUR::Session*, boost::shared_ptr<ARDOUR::Route>, ArdourCanvas::Canvas& canvas);
+       RouteTimeAxisView (PublicEditor&, ARDOUR::Session*, ArdourCanvas::Canvas& canvas);
        virtual ~RouteTimeAxisView ();
 
+       void set_route (boost::shared_ptr<ARDOUR::Route>);
+
        void show_selection (TimeSelection&);
        void set_button_names ();
 
@@ -94,7 +96,9 @@ public:
        /* 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 */
@@ -110,21 +114,17 @@ public:
        void add_underlay (StreamView*, bool update_xml = true);
        void remove_underlay (StreamView*);
        void build_underlay_menu(Gtk::Menu*);
-       
-       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 */
+       int set_state (const XMLNode&, int version);
 
-       XMLNode* get_automation_child_xml_node (Evoral::Parameter param) { return RouteUI::get_automation_child_xml_node (param); }
+       virtual void create_automation_child (const Evoral::Parameter& param, bool show) = 0;
 
        typedef std::map<Evoral::Parameter, boost::shared_ptr<AutomationTimeAxisView> > AutomationTracks;
        AutomationTracks automation_tracks() { return _automation_tracks; }
 
        boost::shared_ptr<AutomationTimeAxisView> 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;
@@ -139,6 +139,8 @@ public:
        void meter_changed ();
        void effective_gain_display () { gm.effective_gain_display(); }
 
+       std::string state_id() const;
+
        static void setup_slider_pix ();
 
 protected:
@@ -185,7 +187,7 @@ protected:
                                               boost::shared_ptr<ARDOUR::Processor>);
 
        void automation_track_hidden (Evoral::Parameter param);
-       
+
        ProcessorAutomationNode*
        find_processor_automation_node (boost::shared_ptr<ARDOUR::Processor> i, Evoral::Parameter);
 
@@ -207,19 +209,16 @@ protected:
 
        virtual void label_view ();
 
-       void set_route_group_from_menu (ARDOUR::RouteGroup *);
-
        void reset_samples_per_unit ();
        void horizontal_position_changed ();
 
        void set_color (Gdk::Color const &);
 
-       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);
+       void set_align_choice (Gtk::RadioMenuItem*, ARDOUR::AlignChoice, bool apply_to_selection = false);
 
        void         playlist_click ();
        void         show_playlist_selector ();
@@ -228,9 +227,10 @@ protected:
        void rename_current_playlist ();
 
        void         automation_click ();
-       virtual void show_all_automation ();
-       virtual void show_existing_automation ();
-       virtual void hide_all_automation ();
+
+       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);
 
@@ -244,8 +244,10 @@ protected:
 
        void create_gain_automation_child (const Evoral::Parameter &, bool);
 
+       void setup_processor_menu_and_curves ();
+
        boost::shared_ptr<AutomationTimeAxisView> gain_track;
-       
+
        StreamView*           _view;
        ArdourCanvas::Canvas& parent_canvas;
        bool                  no_redraw;
@@ -261,11 +263,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_action_menu;
        Gtk::MenuItem*      playlist_item;
        Gtk::Menu*          mode_menu;
@@ -277,10 +274,11 @@ 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);
 
+       /** Information about all automatable processor parameters that apply to
+        *  this route.  The Amp processor is not included in this list.
+        */
        std::list<ProcessorAutomationInfo*> processor_automation;
 
        typedef std::vector<boost::shared_ptr<AutomationLine> > ProcessorAutomationCurves;