Make waveform show / scale / shape a global option in the prefs dialog to clean thing...
[ardour.git] / gtk2_ardour / route_time_axis.h
index 42c889e16fd3c49742c59a6fe9c985924544a7ef..cc0e46548e3cf5338c965f8fbe5f8c3a922f1ff8 100644 (file)
@@ -20,6 +20,9 @@
 #ifndef __ardour_route_time_axis_h__
 #define __ardour_route_time_axis_h__
 
+#include <list>
+#include <set>
+
 #include <gtkmm/table.h>
 #include <gtkmm/button.h>
 #include <gtkmm/box.h>
 #include <gtkmm/menuitem.h>
 #include <gtkmm/radiomenuitem.h>
 #include <gtkmm/checkmenuitem.h>
+#include <gtkmm/adjustment.h>
 
 #include <gtkmm2ext/selector.h>
-#include <list>
+#include <gtkmm2ext/slider_controller.h>
 
-#include <ardour/types.h>
+#include "ardour/playlist.h"
+#include "ardour/types.h"
 
 #include "ardour_dialog.h"
 #include "route_ui.h"
 #include "enums.h"
 #include "time_axis_view.h"
 #include "canvas.h"
-#include "color.h"
+#include "gain_meter.h"
+
 
 namespace ARDOUR {
        class Session;
        class Region;
        class Diskstream;
        class RouteGroup;
-       class Redirect;
-       class Insert;
+       class IOProcessor;
+       class Processor;
        class Location;
        class Playlist;
 }
@@ -59,7 +65,7 @@ class RegionSelection;
 class Selectable;
 class AutomationTimeAxisView;
 class AutomationLine;
-class RedirectAutomationLine;
+class ProcessorAutomationLine;
 class TimeSelection;
 
 class RouteTimeAxisView : public RouteUI, public TimeAxisView
@@ -71,72 +77,106 @@ public:
        void show_selection (TimeSelection&);
 
        void set_samples_per_unit (double);
-       void set_height (TimeAxisView::TrackHeight);
+       void set_height (uint32_t h);
        void show_timestretch (nframes_t start, nframes_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, list<Selectable *>&);
-       void get_inverted_selectables (Selection&, list<Selectable*>&);
-       bool show_automation(ARDOUR::ParamID param);
+       void get_selectables (nframes_t start, nframes_t end, double top, double bot, std::list<Selectable *>&);
+       void get_inverted_selectables (Selection&, std::list<Selectable*>&);
+       bool show_automation(Evoral::Parameter param);
+       void set_layer_display (LayerDisplay d);
+       LayerDisplay layer_display () const;
                
        boost::shared_ptr<ARDOUR::Region> 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);
 
-       list<TimeAxisView*> get_child_list();
+       TimeAxisView::Children get_child_list();
 
        /* The editor calls these when mapping an operation across multiple tracks */
-       void use_new_playlist (bool prompt);
-       void use_copy_playlist (bool prompt);
+       void use_new_playlist (bool prompt, std::vector<boost::shared_ptr<ARDOUR::Playlist> > const &);
+       void use_copy_playlist (bool prompt, std::vector<boost::shared_ptr<ARDOUR::Playlist> > const &);
        void clear_playlist ();
+
+       /* group playlist name resolving */
+       std::string resolve_new_group_playlist_name(std::string &, std::vector<boost::shared_ptr<ARDOUR::Playlist> > const &);
+
        
        void build_playlist_menu (Gtk::Menu *);
 
-       virtual void create_automation_child (ARDOUR::ParamID param) = 0;
+       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<AutomationTimeAxisView> track;
+           
+               RouteAutomationNode (Evoral::Parameter par, Gtk::CheckMenuItem* mi, boost::shared_ptr<AutomationTimeAxisView> 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<Evoral::Parameter, RouteAutomationNode*> AutomationTracks;
+       AutomationTracks automation_tracks() { return _automation_tracks; }
+
+       boost::shared_ptr<AutomationTimeAxisView> automation_child(Evoral::Parameter param);
        
-       string              name() const;
+       std::string         name() const;
        StreamView*         view() const { return _view; }
        ARDOUR::RouteGroup* edit_group() const;
        boost::shared_ptr<ARDOUR::Playlist> playlist() const;
 
+       void fast_update ();
+       void hide_meter ();
+       void show_meter ();
+       void reset_meter ();
+       void clear_meter ();
+       void io_changed (ARDOUR::IOChange, void *);
+       void meter_changed (void *);
+       void effective_gain_display () { gm.effective_gain_display(); }
+
+       static void setup_slider_pix ();
+
 protected:
        friend class StreamView;
-       
-       struct RouteAutomationNode {
-               ARDOUR::ParamID         param;
-           Gtk::CheckMenuItem*     menu_item;
-           AutomationTimeAxisView* track;
-           
-               RouteAutomationNode (ARDOUR::ParamID par, Gtk::CheckMenuItem* mi, AutomationTimeAxisView* tr)
-                   : param (par), menu_item (mi), track (tr) {}
-       };
 
-       struct InsertAutomationNode {
-               ARDOUR::ParamID         what;
-           Gtk::CheckMenuItem*     menu_item;
-           AutomationTimeAxisView* view;
-           RouteTimeAxisView&      parent;
+       struct ProcessorAutomationNode {
+               Evoral::Parameter                         what;
+               Gtk::CheckMenuItem*                       menu_item;
+               boost::shared_ptr<AutomationTimeAxisView> view;
+               RouteTimeAxisView&                        parent;
 
-           InsertAutomationNode (ARDOUR::ParamID w, Gtk::CheckMenuItem* mitem, RouteTimeAxisView& p)
-                   : what (w), menu_item (mitem), view (0), parent (p) {}
+           ProcessorAutomationNode (Evoral::Parameter w, Gtk::CheckMenuItem* mitem, RouteTimeAxisView& p)
+                   : what (w), menu_item (mitem), parent (p) {}
 
-           ~InsertAutomationNode ();
+           ~ProcessorAutomationNode ();
        };
 
-       struct InsertAutomationInfo {
-           boost::shared_ptr<ARDOUR::Insert> insert;
-           bool                              valid;
-           Gtk::Menu*                        menu;
-           vector<InsertAutomationNode*>     lines;
+       struct ProcessorAutomationInfo {
+           boost::shared_ptr<ARDOUR::Processor> processor;
+           bool                                 valid;
+           Gtk::Menu*                           menu;
+           std::vector<ProcessorAutomationNode*>     lines;
 
-           InsertAutomationInfo (boost::shared_ptr<ARDOUR::Insert> i) 
-                   : insert (i), valid (true), menu (0) {}
+           ProcessorAutomationInfo (boost::shared_ptr<ARDOUR::Processor> i) 
+                   : processor (i), valid (true), menu (0) {}
 
-           ~InsertAutomationInfo ();
+           ~ProcessorAutomationInfo ();
        };
        
 
@@ -145,34 +185,34 @@ protected:
        
        gint edit_click  (GdkEventButton *);
 
-       void inserts_changed ();
+       void processors_changed ();
        
-       void add_insert_to_subplugin_menu (boost::shared_ptr<ARDOUR::Insert>);
-       void remove_ran (InsertAutomationNode* ran);
+       void add_processor_to_subplugin_menu (boost::weak_ptr<ARDOUR::Processor>);
+       void remove_processor_automation_node (ProcessorAutomationNode* pan);
 
-       void insert_menu_item_toggled (RouteTimeAxisView::InsertAutomationInfo*,
-                                        RouteTimeAxisView::InsertAutomationNode*);
+       void processor_menu_item_toggled (RouteTimeAxisView::ProcessorAutomationInfo*,
+                                        RouteTimeAxisView::ProcessorAutomationNode*);
        
-       void insert_automation_track_hidden (InsertAutomationNode*,
-                                              boost::shared_ptr<ARDOUR::Insert>);
+       void processor_automation_track_hidden (ProcessorAutomationNode*,
+                                              boost::shared_ptr<ARDOUR::Processor>);
        
-       void automation_track_hidden (ARDOUR::ParamID param);
+       void automation_track_hidden (Evoral::Parameter param);
 
-       RouteAutomationNode* automation_track(ARDOUR::ParamID param);
+       RouteAutomationNode* automation_track(Evoral::Parameter param);
        RouteAutomationNode* automation_track(ARDOUR::AutomationType type);
 
-       InsertAutomationNode*
-       find_insert_automation_node (boost::shared_ptr<ARDOUR::Insert> i, ARDOUR::ParamID);
+       ProcessorAutomationNode*
+       find_processor_automation_node (boost::shared_ptr<ARDOUR::Processor> i, Evoral::Parameter);
        
-       RedirectAutomationLine*
-       find_insert_automation_curve (boost::shared_ptr<ARDOUR::Insert> i, ARDOUR::ParamID);
+       boost::shared_ptr<AutomationLine>
+       find_processor_automation_curve (boost::shared_ptr<ARDOUR::Processor> i, Evoral::Parameter);
 
-       void add_insert_automation_curve (boost::shared_ptr<ARDOUR::Insert> r, ARDOUR::ParamID);
-       void add_existing_insert_automation_curves (boost::shared_ptr<ARDOUR::Insert>);
+       void add_processor_automation_curve (boost::shared_ptr<ARDOUR::Processor> r, Evoral::Parameter);
+       void add_existing_processor_automation_curves (boost::weak_ptr<ARDOUR::Processor>);
 
-       void add_automation_child(ARDOUR::ParamID param, AutomationTimeAxisView* track);
+       void add_automation_child(Evoral::Parameter param, boost::shared_ptr<AutomationTimeAxisView> track, bool show=true);
        
-       void reset_insert_automation_curves ();
+       void reset_processor_automation_curves ();
 
        void take_name_changed (void *src);
        void route_name_changed ();
@@ -205,7 +245,7 @@ protected:
        void rename_current_playlist ();
        
        void         automation_click ();
-       void         toggle_automation_track (ARDOUR::ParamID param);
+       void         toggle_automation_track (Evoral::Parameter param);
        virtual void show_all_automation ();
        virtual void show_existing_automation ();
        virtual void hide_all_automation ();
@@ -222,15 +262,14 @@ protected:
        void color_handler ();
 
        void region_view_added (RegionView*);
-       void add_ghost_to_insert (RegionView*, AutomationTimeAxisView*);
-       
+
        StreamView*           _view;
        ArdourCanvas::Canvas& parent_canvas;
        bool                  no_redraw;
   
        Gtk::HBox   other_button_hbox;
        Gtk::Table  button_table;
-       Gtk::Button insert_button;
+       Gtk::Button processor_button;
        Gtk::Button edit_group_button;
        Gtk::Button playlist_button;
        Gtk::Button size_button;
@@ -244,34 +283,50 @@ protected:
        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;
+       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<ARDOUR::Playlist>);
 
        ArdourCanvas::SimpleRect* timestretch_rect;
 
        void set_track_mode (ARDOUR::TrackMode);
-       void _set_track_mode (ARDOUR::Track* track, ARDOUR::TrackMode mode, Gtk::RadioMenuItem* reset_item);
+       void _set_track_mode (ARDOUR::Track* track, ARDOUR::TrackMode mode, Gtk::RadioMenuItem* reset_item, Gtk::RadioMenuItem* reset_item_2);
        void track_mode_changed ();
 
-       list<InsertAutomationInfo*>     insert_automation;
-       vector<RedirectAutomationLine*> insert_automation_curves;
+       std::list<ProcessorAutomationInfo*> processor_automation;
+
+       typedef std::vector<boost::shared_ptr<AutomationLine> > ProcessorAutomationCurves;
+       ProcessorAutomationCurves processor_automation_curves;
        
        // Set from XML so context menu automation buttons can be correctly initialized
-       set<ARDOUR::ParamID> _show_automation;
+       std::set<Evoral::Parameter> _show_automation;
 
-       map<ARDOUR::ParamID, RouteAutomationNode*> _automation_tracks;
+       AutomationTracks _automation_tracks;
 
        sigc::connection modified_connection;
 
        void post_construct ();
        
-       void set_state (const XMLNode&);
-       
-       XMLNode* get_child_xml_node (const string & childname);
+       GainMeterBase gm;
+
+       static Glib::RefPtr<Gdk::Pixbuf> slider;
+
+       XMLNode* underlay_xml_node;
+       bool set_underlay_state();
+
+       typedef std::list<StreamView*> UnderlayList;
+       UnderlayList _underlay_streams;
+       typedef std::list<RouteTimeAxisView*> UnderlayMirrorList;
+       UnderlayMirrorList _underlay_mirrors;
 };
 
 #endif /* __ardour_route_time_axis_h__ */