merge new symmetric curve from mixbus, fix errors in fade out slow curve, tweak displ...
[ardour.git] / gtk2_ardour / automation_time_axis.h
index 7fc9c2575aaf2879adfa7f05e6a0e87c45148315..d883b189c0f67417fef14eba49572406cc3e927b 100644 (file)
@@ -70,10 +70,9 @@ class AutomationTimeAxisView : public TimeAxisView {
 
        virtual void set_height (uint32_t);
        void set_samples_per_unit (double);
-       bool set_visibility (bool yn);
        std::string name() const { return _name; }
 
-       void add_automation_event (ArdourCanvas::Item *item, GdkEvent *event, framepos_t, double);
+       void add_automation_event (GdkEvent *, framepos_t, double);
 
        void clear_lines ();
 
@@ -93,16 +92,12 @@ class AutomationTimeAxisView : public TimeAxisView {
        /* editing operations */
 
        void cut_copy_clear (Selection&, Editing::CutCopyOp);
-       void cut_copy_clear_objects (PointSelection&, Editing::CutCopyOp);
        bool paste (ARDOUR::framepos_t, float times, Selection&, size_t nth);
-       void reset_objects (PointSelection&);
 
        int  set_state (const XMLNode&, int version);
-       guint32 show_at (double y, int& nth, Gtk::VBox *parent);
-       void hide ();
 
-       static const std::string state_node_name;
-       XMLNode* get_state_node();
+       std::string state_id() const;
+       static bool parse_state_id (std::string const &, PBD::ID &, bool &, Evoral::Parameter &);
 
        boost::shared_ptr<ARDOUR::AutomationControl> control()    { return _control; }
        boost::shared_ptr<AutomationController>      controller() { return _controller; }
@@ -120,6 +115,12 @@ class AutomationTimeAxisView : public TimeAxisView {
                return _route;
        }
 
+       bool show_regions () const {
+               return _show_regions;
+       }
+
+       static void what_has_visible_automation (const boost::shared_ptr<ARDOUR::Automatable>& automatable, std::set<Evoral::Parameter>& visible);
+
   protected:
        /** parent route */
        boost::shared_ptr<ARDOUR::Route> _route;
@@ -156,6 +157,8 @@ class AutomationTimeAxisView : public TimeAxisView {
        Gtk::CheckMenuItem* mode_discrete_item;
        Gtk::CheckMenuItem* mode_line_item;
 
+       bool _show_regions;
+
        void add_line (boost::shared_ptr<AutomationLine>);
 
        void clear_clicked ();
@@ -165,9 +168,8 @@ class AutomationTimeAxisView : public TimeAxisView {
        void build_display_menu ();
 
        void cut_copy_clear_one (AutomationLine&, Selection&, Editing::CutCopyOp);
-       void cut_copy_clear_objects_one (AutomationLine&, PointSelection&, Editing::CutCopyOp);
        bool paste_one (AutomationLine&, ARDOUR::framepos_t, float times, Selection&, size_t nth);
-       void reset_objects_one (AutomationLine&, PointSelection&);
+       void route_going_away ();
 
        void set_automation_state (ARDOUR::AutoState);
        bool ignore_state_request;
@@ -178,8 +180,7 @@ class AutomationTimeAxisView : public TimeAxisView {
        void interpolation_changed (ARDOUR::AutomationList::InterpolationStyle);
 
        PBD::ScopedConnectionList _list_connections;
-
-       void update_extra_xml_shown (bool editor_shown);
+       PBD::ScopedConnectionList _route_connections;
 
        void entered ();
        void exited ();
@@ -187,7 +188,7 @@ class AutomationTimeAxisView : public TimeAxisView {
        //void set_colors ();
        void color_handler ();
 
-       static Pango::FontDescription* name_font;
+       static Pango::FontDescription name_font;
        static bool have_name_font;
 
 private: