Merge remote-tracking branch 'remotes/origin/cairocanvas' into windows
[ardour.git] / gtk2_ardour / region_view.h
index 172405d132f5f90ead9c056cc7ebc081a9c96d09..a5d5fddbd08acb5d2be6a0b4b82e0264e52a9a04 100644 (file)
 #ifndef __gtk_ardour_region_view_h__
 #define __gtk_ardour_region_view_h__
 
+#ifdef interface
+#undef interface
+#endif
+
 #include <vector>
 
-#include <libgnomecanvasmm.h>
-#include <libgnomecanvasmm/polygon.h>
 #include <sigc++/signal.h>
 #include "ardour/region.h"
 #include "ardour/beats_frames_converter.h"
 
+#include "canvas/fwd.h"
+
 #include "time_axis_view_item.h"
 #include "automation_line.h"
 #include "enums.h"
-#include "canvas.h"
 
 class TimeAxisView;
 class RegionEditor;
@@ -38,14 +41,20 @@ class GhostRegion;
 class AutomationTimeAxisView;
 class AutomationRegionView;
 
+namespace ArdourCanvas {
+       class Polygon;
+       class Text;
+}
+
 class RegionView : public TimeAxisViewItem
 {
   public:
        RegionView (ArdourCanvas::Group* parent,
                    TimeAxisView&        time_view,
                    boost::shared_ptr<ARDOUR::Region> region,
-                   double               samples_per_unit,
-                   Gdk::Color const &   basic_color);
+                   double               samples_per_pixel,
+                   Gdk::Color const &   basic_color,
+                   bool                 automation = false);
 
        RegionView (const RegionView& other);
        RegionView (const RegionView& other, boost::shared_ptr<ARDOUR::Region> other_region);
@@ -61,21 +70,21 @@ class RegionView : public TimeAxisViewItem
        void set_valid (bool yn) { valid = yn; }
 
        virtual void set_height (double);
-       virtual void set_samples_per_unit (double);
-       virtual bool set_duration (nframes64_t, void*);
+       virtual void set_samples_per_pixel (double);
+       virtual bool set_duration (framecnt_t, void*);
 
        void move (double xdelta, double ydelta);
 
        void raise_to_top ();
        void lower_to_bottom ();
 
-       bool set_position(nframes64_t pos, void* src, double* delta = 0);
+       bool set_position(framepos_t pos, void* src, double* delta = 0);
        void fake_set_opaque (bool yn);
 
-       virtual void show_region_editor () {}
-       virtual void hide_region_editor();
+       virtual void show_region_editor ();
+       void hide_region_editor ();
 
-       virtual void region_changed (PBD::Change);
+       virtual void region_changed (const PBD::PropertyChange&);
 
        virtual GhostRegion* add_ghost (TimeAxisView&) = 0;
        void remove_ghost_in (TimeAxisView&);
@@ -83,73 +92,110 @@ class RegionView : public TimeAxisViewItem
 
        uint32_t get_fill_color ();
 
-       virtual void entered () {}
+       virtual void entered (bool) {}
        virtual void exited () {}
 
-       void enable_display(bool yn) { _enable_display = yn; }
+       virtual void enable_display(bool yn) { _enable_display = yn; }
        virtual void update_coverage_frames (LayerDisplay);
 
        static PBD::Signal1<void,RegionView*> RegionViewGoingAway;
 
+       ARDOUR::BeatsFramesConverter const & region_relative_time_converter () const {
+               return _region_relative_time_converter;
+       }
+
+       ARDOUR::BeatsFramesConverter const & source_relative_time_converter () const {
+               return _source_relative_time_converter;
+       }
+
+       /** Called when a front trim is about to begin */
+       virtual void trim_front_starting () {}
+
+       bool trim_front (framepos_t, bool);
+
+       /** Called when a start trim has finished */
+       virtual void trim_front_ending () {}
+
+       bool trim_end (framepos_t, bool);
+        void move_contents (ARDOUR::frameoffset_t);
+       virtual void thaw_after_trim ();
+
+        void set_silent_frames (const ARDOUR::AudioIntervalResult&, double threshold);
+        void drop_silent_frames ();
+        void hide_silent_frames ();
+
+       ARDOUR::frameoffset_t snap_frame_to_frame (ARDOUR::frameoffset_t) const;
+       
   protected:
 
        /** Allows derived types to specify their visibility requirements
-     * to the TimeAxisViewItem parent class
-     */
-    RegionView (ArdourCanvas::Group *,
-               TimeAxisView&,
-               boost::shared_ptr<ARDOUR::Region>,
-               double samples_per_unit,
-               Gdk::Color const & basic_color,
-               bool recording,
-               TimeAxisViewItem::Visibility);
+        * to the TimeAxisViewItem parent class
+        */
+       RegionView (ArdourCanvas::Group *,
+                   TimeAxisView&,
+                   boost::shared_ptr<ARDOUR::Region>,
+                   double samples_per_pixel,
+                   Gdk::Color const & basic_color,
+                   bool recording,
+                   TimeAxisViewItem::Visibility);
+
+        bool canvas_group_event (GdkEvent*);
 
-    virtual void region_resized (PBD::Change);
-    virtual void region_muted ();
-    void         region_locked ();
-    void         region_opacity ();
-    virtual void region_renamed ();
-    void         region_sync_changed ();
+       virtual void region_resized (const PBD::PropertyChange&);
+       virtual void region_muted ();
+       void         region_locked ();
+       void         region_opacity ();
+       virtual void region_renamed ();
+       void         region_sync_changed ();
 
-    Glib::ustring make_name () const;
+       std::string make_name () const;
 
-    static gint _lock_toggle (ArdourCanvas::Item*, GdkEvent*, void*);
-    void        lock_toggle ();
+       static gint _lock_toggle (ArdourCanvas::Item*, GdkEvent*, void*);
+       void        lock_toggle ();
 
-    virtual void set_colors ();
-    virtual void set_frame_color ();
-    virtual void reset_width_dependent_items (double pixel_width);
+       virtual void set_colors ();
+       virtual void set_frame_color ();
+       virtual void reset_width_dependent_items (double pixel_width);
 
-    virtual void color_handler () {}
+       virtual void color_handler () {}
 
-    boost::shared_ptr<ARDOUR::Region> _region;
+       boost::shared_ptr<ARDOUR::Region> _region;
 
-    ArdourCanvas::Polygon* sync_mark; ///< polgyon for sync position
-    ArdourCanvas::Line* sync_line; ///< polgyon for sync position
+       ArdourCanvas::Polygon* sync_mark; ///< polgyon for sync position
+       ArdourCanvas::Line* sync_line; ///< polgyon for sync position
 
-    RegionEditor* editor;
+       RegionEditor* editor;
 
-    std::vector<ControlPoint *> control_points;
-    double current_visible_sync_position;
+       std::vector<ControlPoint *> control_points;
+       double current_visible_sync_position;
 
-    bool    valid; ///< see StreamView::redisplay_diskstream()
-    bool    _enable_display; ///< see StreamView::redisplay_diskstream()
-    double  _pixel_width;
-    double  _height;
-    bool    in_destructor;
+       bool    valid; ///< see StreamView::redisplay_diskstream()
+       bool    _enable_display; ///< see StreamView::redisplay_diskstream()
+       double  _pixel_width;
+       bool    in_destructor;
 
-    bool             wait_for_data;
-    PBD::ScopedConnection data_ready_connection;
+       bool wait_for_data;
 
-    std::vector<GhostRegion*> ghosts;
+       std::vector<GhostRegion*> ghosts;
 
        /** a list of rectangles which are used in stacked display mode to colour
            different bits of regions according to whether or not they are the one
            that will be played at any given time.
        */
-       std::list<ArdourCanvas::SimpleRect*> _coverage_frames;
+       std::list<ArdourCanvas::Rectangle*> _coverage_frames;
+
+       /** a list of rectangles used to show silent segments
+       */
+       std::list<ArdourCanvas::Rectangle*> _silent_frames;
+       /** a list of rectangles used to show the current silence threshold
+       */
+       std::list<ArdourCanvas::Rectangle*> _silent_threshold_frames;
+        /** a text item to display strip silence statistics
+         */
+        ArdourCanvas::Text* _silence_text;
 
-       ARDOUR::BeatsFramesConverter _time_converter;
+       ARDOUR::BeatsFramesConverter _region_relative_time_converter;
+       ARDOUR::BeatsFramesConverter _source_relative_time_converter;
 };
 
 #endif /* __gtk_ardour_region_view_h__ */