forward unhandled button events from MidiRegionView back to Editor
[ardour.git] / gtk2_ardour / route_time_axis.h
index 1f53cd200c8bb32b638fedf9dee3dccc1fee59cd..d9b957dbab38ebea4d0ee6c0b72b91a6dc50bcf9 100644 (file)
@@ -78,25 +78,22 @@ public:
 
        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);
        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<Selectable *>&);
+       void get_selectables (ARDOUR::framepos_t start, ARDOUR::framepos_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);
+       void set_layer_display (LayerDisplay d, bool apply_to_selection = false);
        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);
+       boost::shared_ptr<ARDOUR::Region> find_next_region (framepos_t pos, ARDOUR::RegionPoint, int32_t dir);
+       framepos_t find_next_region_boundary (framepos_t pos, int32_t dir);
 
        /* Editing operations */
-       bool cut_copy_clear (Selection&, Editing::CutCopyOp);
-       bool paste (nframes_t, float times, Selection&, size_t nth);
-
-       TimeAxisView::Children get_child_list();
+       void cut_copy_clear (Selection&, Editing::CutCopyOp);
+       bool paste (ARDOUR::framepos_t, float times, Selection&, size_t nth);
 
        void toggle_automation_track (const Evoral::Parameter& param);
 
@@ -108,8 +105,7 @@ public:
        /* 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 *);
+       void build_playlist_menu ();
 
        void add_underlay (StreamView*, bool update_xml = true);
        void remove_underlay (StreamView*);
@@ -117,27 +113,18 @@ public:
        
        int set_state (const XMLNode&, int version);
        
-       /* 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;
+       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;
@@ -184,11 +171,11 @@ protected:
 
        void update_diskstream_display ();
 
-       gint edit_click  (GdkEventButton *);
+       gint route_group_click  (GdkEventButton *);
 
        void processors_changed (ARDOUR::RouteProcessorChange);
 
-       void add_processor_to_subplugin_menu (boost::weak_ptr<ARDOUR::Processor>);
+       virtual void add_processor_to_subplugin_menu (boost::weak_ptr<ARDOUR::Processor>);
        void remove_processor_automation_node (ProcessorAutomationNode* pan);
 
        void processor_menu_item_toggled (RouteTimeAxisView::ProcessorAutomationInfo*,
@@ -199,9 +186,6 @@ protected:
 
        void automation_track_hidden (Evoral::Parameter param);
        
-       RouteAutomationNode* automation_track(Evoral::Parameter param);
-       RouteAutomationNode* automation_track(ARDOUR::AutomationType type);
-
        ProcessorAutomationNode*
        find_processor_automation_node (boost::shared_ptr<ARDOUR::Processor> i, Evoral::Parameter);
 
@@ -226,15 +210,15 @@ protected:
        void set_route_group_from_menu (ARDOUR::RouteGroup *);
 
        void reset_samples_per_unit ();
+       void horizontal_position_changed ();
 
-       void select_track_color();
+       void set_color (Gdk::Color const &);
 
        virtual void build_automation_action_menu ();
        virtual void append_extra_display_menu_items () {}
        void         build_display_menu ();
 
-       void align_style_changed ();
-       void set_align_style (ARDOUR::AlignStyle);
+       void set_align_style (ARDOUR::AlignStyle, bool apply_to_selection = false);
 
        void         playlist_click ();
        void         show_playlist_selector ();
@@ -247,7 +231,7 @@ protected:
        virtual void show_existing_automation ();
        virtual void hide_all_automation ();
 
-       void timestretch (nframes_t start, nframes_t end);
+       void timestretch (framepos_t start, framepos_t end);
 
        void speed_changed ();
 
@@ -257,6 +241,10 @@ protected:
 
        void region_view_added (RegionView*);
 
+       void create_gain_automation_child (const Evoral::Parameter &, bool);
+
+       boost::shared_ptr<AutomationTimeAxisView> gain_track;
+       
        StreamView*           _view;
        ArdourCanvas::Canvas& parent_canvas;
        bool                  no_redraw;
@@ -272,12 +260,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_menu;
        Gtk::Menu*          playlist_action_menu;
        Gtk::MenuItem*      playlist_item;
        Gtk::Menu*          mode_menu;
@@ -289,19 +271,19 @@ 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);
 
        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
-       std::set<Evoral::Parameter> _show_automation;
-
        AutomationTracks _automation_tracks;
+       typedef std::map<Evoral::Parameter, Gtk::CheckMenuItem*> 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 ();