X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Ftime_axis_view.h;h=1eb193590c9d63f9e775e2b43672c11f899b292d;hb=815ffcd567a65c259b31b41e03c56cf2fc8ad1b6;hp=682514acfae51cf6b2e76bdc6ac84c226bcda795;hpb=ad017365f7a73f8ba57f667cc1aa36478b48c50e;p=ardour.git diff --git a/gtk2_ardour/time_axis_view.h b/gtk2_ardour/time_axis_view.h index 682514acfa..1eb193590c 100644 --- a/gtk2_ardour/time_axis_view.h +++ b/gtk2_ardour/time_axis_view.h @@ -78,6 +78,8 @@ class RegionView; class GhostRegion; class StreamView; class ArdourDialog; +class ItemCounts; +class PasteContext; /** Abstract base class for time-axis views (horizontal editor 'strips') * @@ -98,15 +100,14 @@ class TimeAxisView : public virtual AxisView static PBD::Signal1 CatchDeletion; + static void setup_sizes (); + /** @return index of this TimeAxisView within its parent */ int order () const { return _order; } /** @return maximum allowable value of order */ static int max_order () { return _max_order; } - virtual void enter_internal_edit_mode () {} - virtual void leave_internal_edit_mode () {} - ArdourCanvas::Container* canvas_display () { return _canvas_display; } ArdourCanvas::Container* ghost_group () { return _ghost_group; } @@ -122,7 +123,7 @@ class TimeAxisView : public virtual AxisView uint32_t current_height() const { return height; } - void idle_resize (uint32_t); + void idle_resize (int32_t); virtual guint32 show_at (double y, int& nth, Gtk::VBox *parent); virtual void hide (); @@ -141,7 +142,13 @@ class TimeAxisView : public virtual AxisView virtual void entered () {} virtual void exited () {} - virtual void set_height (uint32_t h); + enum TrackHeightMode { + OnlySelf, + TotalHeight, + HeightPerLane + }; + + virtual void set_height (uint32_t h, TrackHeightMode m = OnlySelf); void set_height_enum (Height, bool apply_to_selection = false); void reset_height(); @@ -165,7 +172,15 @@ class TimeAxisView : public virtual AxisView /* editing operations */ virtual void cut_copy_clear (Selection&, Editing::CutCopyOp) {} - virtual bool paste (ARDOUR::framepos_t, float /*times*/, Selection&, size_t /*nth*/) { return false; } + + /** Paste a selection. + * @param pos Position to paste to (session frames). + * @param selection Selection to paste. + * @param ctx Paste context. + */ + virtual bool paste (ARDOUR::framepos_t pos, + const Selection& selection, + PasteContext& ctx) { return false; } virtual void set_selected_regionviews (RegionSelection&) {} virtual void set_selected_points (PointSelection&) {} @@ -178,7 +193,7 @@ class TimeAxisView : public virtual AxisView void order_selection_trims (ArdourCanvas::Item *item, bool put_start_on_top); - virtual void get_selectables (ARDOUR::framepos_t, ARDOUR::framepos_t, double, double, std::list&); + virtual void get_selectables (ARDOUR::framepos_t, ARDOUR::framepos_t, double, double, std::list&, bool within = false); virtual void get_inverted_selectables (Selection&, std::list& results); void add_ghost (RegionView*); @@ -244,6 +259,7 @@ class TimeAxisView : public virtual AxisView bool name_entry_focus_out (GdkEventFocus *ev); Gtk::Entry* name_entry; + bool ending_name_edit; void begin_name_edit (); void end_name_edit (int); @@ -297,9 +313,10 @@ private: int _order; uint32_t _effective_height; double _resize_drag_start; + bool _did_resize; GdkCursor* _preresize_cursor; bool _have_preresize_cursor; - bool _ebox_release_can_act; + bool _ebox_release_can_act; static uint32_t button_height; static uint32_t extra_height;