Remove fade handles from recording regions. Fixes #3322.
[ardour.git] / gtk2_ardour / public_editor.h
index e91f2911e311edb76ff18a6453b52c4d968c1967..ea9ef9dfad8cb71b10e0229e711903d0e3ade581 100644 (file)
@@ -52,6 +52,10 @@ namespace Gtk {
        class Menu;
 }
 
+namespace Gtkmm2ext { 
+        class TearOff;
+}
+
 class Editor;
 class TimeAxisViewItem;
 class TimeAxisView;
@@ -75,6 +79,7 @@ class MarkerTimeAxis;
 class ImageFrameView;
 class ImageFrameTimeAxis;
 class MarkerView;
+class DragManager;
 
 /// Representation of the interface of the Editor class
 
@@ -139,7 +144,7 @@ class PublicEditor : public Gtk::Window, public PBD::StatefulDestructible {
        /** Set the mouse mode (gain, object, range, timefx etc.)
         * @param m Mouse mode (defined in editing_syms.h)
         * @param force Perform the effects of the change even if no change is required
-        * (ie even if the current mouse mode is equal to \ref m)
+        * (ie even if the current mouse mode is equal to @param m)
         */
        virtual void set_mouse_mode (Editing::MouseMode m, bool force = false) = 0;
 
@@ -169,20 +174,13 @@ class PublicEditor : public Gtk::Window, public PBD::StatefulDestructible {
         */
        virtual bool sound_notes () const = 0;
 
-       /** Possibly start the audition of a region.  If \ref r is 0, or not an AudioRegion
-        * any current audition is cancelled.  If we are currently auditioning \ref r,
-        * the audition will be cancelled.  Otherwise an audition of \ref r will start.
+       /** Possibly start the audition of a region.  If @param r is 0, or not an AudioRegion
+        * any current audition is cancelled.  If we are currently auditioning @param r,
+        * the audition will be cancelled.  Otherwise an audition of @param r will start.
         * \param r Region to consider.
         */
        virtual void consider_auditioning (boost::shared_ptr<ARDOUR::Region> r) = 0;
 
-       /** Set whether waveforms should be shown while recording audio tracks.
-        * @param yn true to show waveforms, otherwise false.
-        */
-       virtual void set_show_waveforms_recording (bool yn) = 0;
-
-       /** @return true if waveforms are being shown while recording, otherwise false */
-       virtual bool show_waveforms_recording () const = 0;
        virtual void new_region_from_selection () = 0;
        virtual void separate_region_from_selection () = 0;
 
@@ -226,7 +224,11 @@ class PublicEditor : public Gtk::Window, public PBD::StatefulDestructible {
        virtual void select_all_tracks () = 0;
        virtual void set_selected_track (TimeAxisView&, Selection::Operation op = Selection::Set, bool no_remove = false) = 0;
        virtual void set_selected_mixer_strip (TimeAxisView&) = 0;
-       virtual void hide_track_in_display (TimeAxisView& tv, bool temporary = false) = 0;
+       virtual void hide_track_in_display (TimeAxisView* tv, bool temporary = false) = 0;
+
+        virtual void set_stationary_playhead (bool yn) = 0;
+        virtual void toggle_stationary_playhead () = 0;
+        virtual bool stationary_playhead() const = 0;
 
        /** Set whether the editor should follow the playhead.
         * @param yn true to follow playhead, otherwise false.
@@ -249,7 +251,6 @@ class PublicEditor : public Gtk::Window, public PBD::StatefulDestructible {
        virtual void temporal_zoom_step (bool coarser) = 0;
        virtual void scroll_tracks_down_line () = 0;
        virtual void scroll_tracks_up_line () = 0;
-       virtual bool new_regionviews_display_gain () = 0;
        virtual void prepare_for_cleanup () = 0;
        virtual void finish_cleanup () = 0;
        virtual void reset_x_origin (nframes64_t frame) = 0;
@@ -283,6 +284,8 @@ class PublicEditor : public Gtk::Window, public PBD::StatefulDestructible {
        sigc::signal<void> Realized;
        sigc::signal<void,nframes64_t> UpdateAllTransportClocks;
 
+        static sigc::signal<void> DropDownKeys;
+        
        Glib::RefPtr<Gtk::ActionGroup> editor_actions;
 
        virtual void reset_focus () = 0;
@@ -301,6 +304,7 @@ class PublicEditor : public Gtk::Window, public PBD::StatefulDestructible {
        virtual bool canvas_frame_handle_event (GdkEvent* event, ArdourCanvas::Item*, RegionView*) = 0;
        virtual bool canvas_region_view_name_highlight_event (GdkEvent* event, ArdourCanvas::Item*, RegionView*) = 0;
        virtual bool canvas_region_view_name_event (GdkEvent* event, ArdourCanvas::Item*, RegionView*) = 0;
+       virtual bool canvas_feature_line_event (GdkEvent* event, ArdourCanvas::Item*, RegionView*) = 0;
        virtual bool canvas_stream_view_event (GdkEvent* event, ArdourCanvas::Item*, RouteTimeAxisView*) = 0;
        virtual bool canvas_marker_event (GdkEvent* event, ArdourCanvas::Item*, Marker*) = 0;
        virtual bool canvas_zoom_rect_event (GdkEvent* event, ArdourCanvas::Item*) = 0;
@@ -355,12 +359,21 @@ class PublicEditor : public Gtk::Window, public PBD::StatefulDestructible {
        virtual TrackViewList axis_views_from_routes (boost::shared_ptr<ARDOUR::RouteList>) const = 0;
        virtual TrackViewList const & get_track_views () = 0;
        
+       virtual Gtkmm2ext::TearOff* mouse_mode_tearoff () const = 0;
+       virtual Gtkmm2ext::TearOff* tools_tearoff () const = 0;
+
+       virtual DragManager* drags () const = 0;
+       virtual void maybe_autoscroll (bool, bool) = 0;
+       virtual void stop_canvas_autoscroll () = 0;
+
        /// Singleton instance, set up by Editor::Editor()
 
        static PublicEditor* _instance;
 
        friend bool relay_key_press (GdkEventKey*, Gtk::Window*);
        friend bool forward_key_press (GdkEventKey*);
+
+       PBD::Signal0<void> SnapChanged;
 };
 
 #endif // __gtk_ardour_public_editor_h__