Fix quantization and other time-related ops.
[ardour.git] / gtk2_ardour / route_time_axis.h
index d596de3df70f0ee65bd9e4e3aaa3a39f4b52f25a..03060c702f1ac77eb9b774693843ac7a25df5e81 100644 (file)
 #include "ardour/playlist.h"
 #include "ardour/types.h"
 
+#include "ardour_button.h"
 #include "ardour_dialog.h"
 #include "route_ui.h"
 #include "enums.h"
 #include "time_axis_view.h"
-#include "canvas.h"
 #include "gain_meter.h"
 
 namespace ARDOUR {
@@ -55,6 +55,10 @@ namespace ARDOUR {
        class Playlist;
 }
 
+namespace ArdourCanvas {
+       class Rectangle;
+}
+
 class PublicEditor;
 class RegionView;
 class StreamView;
@@ -66,19 +70,22 @@ class AutomationLine;
 class ProcessorAutomationLine;
 class TimeSelection;
 class RouteGroupMenu;
+class ItemCounts;
 
 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 ();
 
-       void set_samples_per_unit (double);
+       void set_samples_per_pixel (double);
        void set_height (uint32_t h);
-       void show_timestretch (framepos_t start, framepos_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&);
@@ -93,9 +100,12 @@ public:
 
        /* Editing operations */
        void cut_copy_clear (Selection&, Editing::CutCopyOp);
-       bool paste (ARDOUR::framepos_t, float times, Selection&, size_t nth);
-       void join_regions ();
+       bool paste (ARDOUR::framepos_t, unsigned paste_count, float times, const Selection&, ItemCounts&);
+       RegionView* combine_regions ();
+       void uncombine_regions ();
+       void uncombine_region (RegionView*);
        void toggle_automation_track (const Evoral::Parameter& param);
+       void fade_range (TimeSelection&);
 
        /* The editor calls these when mapping an operation across multiple tracks */
        void use_new_playlist (bool prompt, std::vector<boost::shared_ptr<ARDOUR::Playlist> > const &);
@@ -110,21 +120,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; }
+       const AutomationTracks& automation_tracks() const { 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,7 +145,7 @@ public:
        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;
@@ -185,7 +191,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);
 
@@ -203,14 +209,11 @@ protected:
        void route_property_changed (const PBD::PropertyChange&);
        void name_entry_changed ();
 
-       void update_rec_display ();
+       void blink_rec_display (bool onoff);
 
        virtual void label_view ();
 
-       void reset_samples_per_unit ();
-       void horizontal_position_changed ();
-
-       void set_color (Gdk::Color const &);
+       void reset_samples_per_pixel ();
 
        virtual void build_automation_action_menu (bool);
        virtual void append_extra_display_menu_items () {}
@@ -231,29 +234,29 @@ protected:
        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 create_mute_automation_child (const Evoral::Parameter &, bool);
+       void setup_processor_menu_and_curves ();
+       void route_color_changed ();
+        bool can_edit_name() const;
 
        boost::shared_ptr<AutomationTimeAxisView> gain_track;
-       
+       boost::shared_ptr<AutomationTimeAxisView> mute_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 automation_button;
+       ArdourButton route_group_button;
+       ArdourButton playlist_button;
+       ArdourButton automation_button;
+       ArdourButton number_label;
 
        Gtk::Menu           subplugin_menu;
        Gtk::Menu*          automation_action_menu;
@@ -268,10 +271,13 @@ protected:
 
        void use_playlist (Gtk::RadioMenuItem *item, boost::weak_ptr<ARDOUR::Playlist> wpl);
 
-       ArdourCanvas::SimpleRect* timestretch_rect;
+       ArdourCanvas::Rectangle* timestretch_rect;
 
        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;
@@ -288,8 +294,6 @@ protected:
 
        GainMeterBase gm;
 
-       static Glib::RefPtr<Gdk::Pixbuf> slider;
-
        XMLNode* underlay_xml_node;
        bool set_underlay_state();
 
@@ -298,7 +302,14 @@ protected:
        typedef std::list<RouteTimeAxisView*> UnderlayMirrorList;
        UnderlayMirrorList _underlay_mirrors;
 
-       bool _ignore_track_mode_change; ///< true to ignore track mode change signals
+       bool _ignore_set_layer_display;
+
+private:
+
+       void remove_child (boost::shared_ptr<TimeAxisView>);
+       void update_playlist_tip ();
+       void parameter_changed (std::string const & p);
+       void update_track_number_visibility();
 };
 
 #endif /* __ardour_route_time_axis_h__ */