X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=gtk2_ardour%2Fstreamview.h;h=b3ae34e4d4fd683742f63d144af9c2745d2897b3;hb=dfbc9da79aef9cc05808d29a20c6d12c5d553a80;hp=3268519534194eb9530455bdc4f129b72880f562;hpb=2c72f58aa19c169752e6c09310c7d7917b63c3eb;p=ardour.git diff --git a/gtk2_ardour/streamview.h b/gtk2_ardour/streamview.h index 3268519534..b3ae34e4d4 100644 --- a/gtk2_ardour/streamview.h +++ b/gtk2_ardour/streamview.h @@ -26,24 +26,27 @@ #include "ardour/location.h" #include "enums.h" -#include "simplerect.h" -#include "canvas.h" namespace Gdk { class Color; } namespace ARDOUR { - class Route; class Crossfade; - class PeakData; class Region; + class Route; class Source; class Track; + struct PeakData; +} + +namespace ArdourCanvas { + class Rectangle; + class Container; } struct RecBoxInfo { - ArdourCanvas::SimpleRect* rectangle; + ArdourCanvas::Rectangle* rectangle; framepos_t start; ARDOUR::framecnt_t length; }; @@ -70,26 +73,25 @@ public: int set_position (gdouble x, gdouble y); virtual int set_height (double); - virtual int set_samples_per_unit (gdouble spp); - gdouble get_samples_per_unit () { return _samples_per_unit; } - virtual void horizontal_position_changed () {} + virtual int set_samples_per_pixel (double); + gdouble get_samples_per_pixel () const { return _samples_per_pixel; } - virtual void enter_internal_edit_mode () {} - virtual void leave_internal_edit_mode () {} + virtual void enter_internal_edit_mode (); + virtual void leave_internal_edit_mode (); void set_layer_display (LayerDisplay); LayerDisplay layer_display () const { return _layer_display; } - ArdourCanvas::Group* background_group() { return _background_group; } - ArdourCanvas::Group* canvas_item() { return _canvas_group; } + ArdourCanvas::Container* canvas_item() { return _canvas_group; } enum ColorTarget { RegionColor, StreamBaseColor }; - Gdk::Color get_region_color () const { return region_color; } - void apply_color (Gdk::Color&, ColorTarget t); + uint32_t get_region_color () const { return region_color; } + void apply_color (uint32_t, ColorTarget t); + void apply_color (Gdk::Color const &, ColorTarget t); uint32_t num_selected_regionviews () const; @@ -117,12 +119,16 @@ public: } void check_record_layers (boost::shared_ptr, ARDOUR::framepos_t); + + virtual void playlist_layered (boost::weak_ptr); sigc::signal RegionViewAdded; sigc::signal RegionViewRemoved; + /** Emitted when the height of regions has changed */ + sigc::signal ContentsHeightChanged; protected: - StreamView (RouteTimeAxisView&, ArdourCanvas::Group* background_group = 0, ArdourCanvas::Group* canvas_group = 0); + StreamView (RouteTimeAxisView&, ArdourCanvas::Container* canvas_group = 0); void transport_changed(); void transport_looped(); @@ -140,22 +146,18 @@ protected: void diskstream_changed (); void layer_regions (); - virtual void playlist_switched (boost::weak_ptr); - virtual void playlist_layered (boost::weak_ptr); + void playlist_switched (boost::weak_ptr); virtual void color_handler () = 0; RouteTimeAxisView& _trackview; - bool owns_background_group; - bool owns_canvas_group; - ArdourCanvas::Group* _background_group; - ArdourCanvas::Group* _canvas_group; - ArdourCanvas::SimpleRect* canvas_rect; /* frame around the whole thing */ + ArdourCanvas::Container* _canvas_group; + ArdourCanvas::Rectangle* canvas_rect; /* frame around the whole thing */ typedef std::list RegionViewList; RegionViewList region_views; - double _samples_per_unit; + double _samples_per_pixel; sigc::connection screen_update_connection; std::vector rec_rects; @@ -163,8 +165,8 @@ protected: bool rec_updating; bool rec_active; - Gdk::Color region_color; ///< Contained region color - uint32_t stream_base_color; ///< Background color + uint32_t region_color; ///< Contained region color + uint32_t stream_base_color; ///< Background color PBD::ScopedConnectionList playlist_connections; PBD::ScopedConnection playlist_switched_connection; @@ -182,7 +184,7 @@ protected: */ framepos_t _new_rec_layer_time; void setup_new_rec_layer_time (boost::shared_ptr); - + private: void update_coverage_frames (); };