X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fcrossfade_view.h;h=75544f50a9520f6fff6c6fa88fbb36304e25a375;hb=80972784e348aa51522e562b3d6b250745c489f0;hp=e141a30cb10649e7a4cbf29efed8318bd564b2ea;hpb=3c00a7ca2ae34cb65c8d3394d9a012f20c69ee77;p=ardour.git diff --git a/gtk2_ardour/crossfade_view.h b/gtk2_ardour/crossfade_view.h index e141a30cb1..75544f50a9 100644 --- a/gtk2_ardour/crossfade_view.h +++ b/gtk2_ardour/crossfade_view.h @@ -30,53 +30,54 @@ class RouteTimeAxisView; class AudioRegionView; -struct CrossfadeView : public TimeAxisViewItem +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::Group*, + RouteTimeAxisView&, + boost::shared_ptr, + double initial_samples_per_unit, + 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_height (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 (); + AudioRegionView& upper_regionview () const; - protected: - void reset_width_dependent_items (double pixel_width); + void fake_hide (); + void hide (); + void show (); + void horizontal_position_changed (); - private: - bool _valid; - bool _visible; +protected: + void reset_width_dependent_items (double pixel_width); - double spu; - double _height; +private: + bool _valid; + bool _visible; + bool _all_in_view; - ArdourCanvas::Item *overlap_rect; - ArdourCanvas::Line *fade_in; - ArdourCanvas::Line *fade_out; - ArdourCanvas::Item *active_button; + ArdourCanvas::Line *fade_in; + ArdourCanvas::Line *fade_out; + ArdourCanvas::Item *active_button; - void crossfade_changed (PBD::Change); - void active_changed (); + void crossfade_changed (const PBD::PropertyChange&); + void crossfade_fades_changed (); + void active_changed (); void redraw_curves (); void color_handler (); };