X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Ftime_axis_view.h;h=baeeb2a92abed5d18558bf72cc7d63381cacb1ce;hb=c809e528c026bcc02471f973c71ba04d8e8a1dce;hp=d14686b4ee19975dc06eeb8d71c9229b4f899ca9;hpb=ba53af1c50417cc28ff4aac8d72ff182d54f0896;p=ardour.git diff --git a/gtk2_ardour/time_axis_view.h b/gtk2_ardour/time_axis_view.h index d14686b4ee..baeeb2a92a 100644 --- a/gtk2_ardour/time_axis_view.h +++ b/gtk2_ardour/time_axis_view.h @@ -24,6 +24,7 @@ #include #include +#include #include #include #include @@ -41,6 +42,8 @@ #include "ardour/region.h" #include "evoral/Parameter.hpp" +#include "canvas/line.h" + #include "prompter.h" #include "axis_view.h" #include "enums.h" @@ -75,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') * @@ -95,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; } @@ -119,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 (); @@ -138,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(); @@ -162,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&) {} @@ -175,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*); @@ -201,6 +219,7 @@ class TimeAxisView : public virtual AxisView protected: static Glib::RefPtr controls_meters_size_group; + static Glib::RefPtr midi_scroomer_size_group; static unsigned int name_width_px; /* The Standard LHS Controls */ Gtk::Table controls_table; @@ -213,6 +232,7 @@ class TimeAxisView : public virtual AxisView Gtk::HBox name_hbox; Gtk::HBox top_hbox; Gtk::Label name_label; + Gtk::Fixed scroomer_placeholder; bool _name_editing; uint32_t height; /* in canvas units */ std::string controls_base_unselected_name; @@ -227,6 +247,7 @@ class TimeAxisView : public virtual AxisView bool _hidden; bool in_destructor; Gtk::Menu* _size_menu; + ArdourCanvas::Line* _canvas_separator; ArdourCanvas::Container* _canvas_display; double _y_position; PublicEditor& _editor; @@ -291,9 +312,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;