X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=gtk2_ardour%2Fcrossfade_view.h;h=c283a92b62dae71214043a5080f5d2654bc7c769;hb=84b4dd94e34afea47dcb6b411215d5b86f112e25;hp=610fa92e0e2e84775a4aef8f462ccc7a2a70af8a;hpb=fa701b8c065251d242342b86a54d91826d2290a0;p=ardour.git diff --git a/gtk2_ardour/crossfade_view.h b/gtk2_ardour/crossfade_view.h index 610fa92e0e..c283a92b62 100644 --- a/gtk2_ardour/crossfade_view.h +++ b/gtk2_ardour/crossfade_view.h @@ -30,55 +30,56 @@ 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 (); - - boost::shared_ptr crossfade; // ok, let 'em have it - - AudioRegionView& left_view; // and these too - AudioRegionView& right_view; - - void set_height (double); - - bool valid() const { return _valid; } - bool visible() const { return _visible; } - void set_valid (bool yn); - - static PBD::Signal1 CatchDeletion; - - AudioRegionView& upper_regionview () const; - - void fake_hide (); - void hide (); - void show (); - - protected: - void reset_width_dependent_items (double pixel_width); - - private: - bool _valid; - bool _visible; - - double spu; - double _height; - - ArdourCanvas::Item *overlap_rect; - ArdourCanvas::Line *fade_in; - ArdourCanvas::Line *fade_out; - ArdourCanvas::Item *active_button; - - void crossfade_changed (const PBD::PropertyChange&); - void active_changed (); - void redraw_curves (); - void color_handler (); +public: + CrossfadeView (ArdourCanvas::Group*, + RouteTimeAxisView&, + boost::shared_ptr, + double initial_samples_per_unit, + Gdk::Color& basic_color, + AudioRegionView& leftview, + AudioRegionView& rightview); + + ~CrossfadeView (); + + boost::shared_ptr crossfade; // ok, let 'em have it + + AudioRegionView& left_view; // and these too + AudioRegionView& right_view; + + void set_height (double); + + bool valid() const { return _valid; } + bool visible() const { return _visible; } + void set_valid (bool yn); + + static PBD::Signal1 CatchDeletion; + + AudioRegionView& upper_regionview () const; + + void fake_hide (); + void hide (); + void show (); + void horizontal_position_changed (); + +protected: + void reset_width_dependent_items (double pixel_width); + +private: + bool _valid; + bool _visible; + bool _all_in_view; + + ArdourCanvas::Line *fade_in; + ArdourCanvas::Line *fade_out; + ArdourCanvas::Item *active_button; + + 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__ */