X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fcrossfade_view.h;h=a042611cc9172d45caad943087e5c7140afcbd15;hb=a2c0b10d8a6cf4ab5a0fdcdfe157c35c0ed9a709;hp=6f77a3043c5706550d5972fb3b7d5f984fe949a0;hpb=156f5e4a4258437fa1136dcb78780828de961dbf;p=ardour.git diff --git a/gtk2_ardour/crossfade_view.h b/gtk2_ardour/crossfade_view.h index 6f77a3043c..a042611cc9 100644 --- a/gtk2_ardour/crossfade_view.h +++ b/gtk2_ardour/crossfade_view.h @@ -21,7 +21,6 @@ #define __gtk_ardour_crossfade_view_h__ #include -#include #include "pbd/signals.h" #include "ardour/crossfade.h" @@ -30,54 +29,58 @@ class RouteTimeAxisView; class AudioRegionView; -struct CrossfadeView : public TimeAxisViewItem +namespace ArdourCanvas { + class PolyLine; +} + +class CrossfadeView : public TimeAxisViewItem { - CrossfadeView (ArdourCanvas::Group*, - RouteTimeAxisView&, - boost::shared_ptr, - double initial_samples_per_unit, - Gdk::Color& basic_color, - AudioRegionView& leftview, - AudioRegionView& rightview); - ~CrossfadeView (); +public: + CrossfadeView (ArdourCanvas::Container*, + RouteTimeAxisView&, + boost::shared_ptr, + double initial_samples_per_pixel, + Gdk::Color& basic_color, + AudioRegionView& leftview, + AudioRegionView& rightview); - boost::shared_ptr crossfade; // ok, let 'em have it + ~CrossfadeView (); - AudioRegionView& left_view; // and these too - AudioRegionView& right_view; + boost::shared_ptr crossfade; // ok, let 'em have it - void set_height (double); + AudioRegionView& left_view; // and these too + AudioRegionView& right_view; - bool valid() const { return _valid; } - bool visible() const { return _visible; } - void set_valid (bool yn); + void set_heights (double, double); - static PBD::Signal1 CatchDeletion; + bool valid() const { return _valid; } + bool visible() const { return _visible; } + void set_valid (bool yn); - AudioRegionView& upper_regionview () const; + static PBD::Signal1 CatchDeletion; - void fake_hide (); - void hide (); - void show (); - void horizontal_position_changed (); + void fake_hide (); + void hide (); + void show (); + void horizontal_position_changed (); - protected: - void reset_width_dependent_items (double pixel_width); +protected: + void reset_width_dependent_items (double pixel_width); - private: - bool _valid; - bool _visible; - bool _all_in_view; +private: + bool _valid; + bool _visible; + bool _all_in_view; + double _child_height; - ArdourCanvas::Line *fade_in; - ArdourCanvas::Line *fade_out; - ArdourCanvas::Item *active_button; + ArdourCanvas::PolyLine *fade_in; + ArdourCanvas::PolyLine *fade_out; - void crossfade_changed (const PBD::PropertyChange&); - void crossfade_fades_changed (); - void active_changed (); - void redraw_curves (); - void color_handler (); + void crossfade_changed (const PBD::PropertyChange&); + void crossfade_fades_changed (); + void active_changed (); + void redraw_curves (); + void color_handler (); }; #endif /* __gtk_ardour_crossfade_view_h__ */