X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Ftime_axis_view.h;h=99ed2f37fc8f600812713c66cf51d37d85ad9e18;hb=dc4f730ac95837590e8305f69778d1049e4a545e;hp=5125387e0f6ef58df23391834b472082892af46a;hpb=86eb72955c76575b75a2b9e535162ca7e0612bfd;p=ardour.git diff --git a/gtk2_ardour/time_axis_view.h b/gtk2_ardour/time_axis_view.h index 5125387e0f..99ed2f37fc 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 @@ -32,18 +33,19 @@ #include #include -#include - #include "pbd/stateful.h" #include "pbd/signals.h" +#include "evoral/Parameter.hpp" + #include "ardour/types.h" +#include "ardour/presentation_info.h" #include "ardour/region.h" -#include "evoral/Parameter.hpp" #include "canvas/line.h" -#include "prompter.h" +#include "widgets/focus_entry.h" + #include "axis_view.h" #include "enums.h" #include "editing.h" @@ -54,6 +56,7 @@ namespace ARDOUR { class Session; class RouteGroup; class Playlist; + class Stripable; } namespace Gtk { @@ -77,6 +80,8 @@ class RegionView; class GhostRegion; class StreamView; class ArdourDialog; +class ItemCounts; +class PasteContext; /** Abstract base class for time-axis views (horizontal editor 'strips') * @@ -97,15 +102,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; } @@ -121,7 +125,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 (); @@ -133,6 +137,8 @@ class TimeAxisView : public virtual AxisView void set_selected (bool); + virtual bool selectable() const { return true; } + /** * potential handler for entered events */ @@ -140,7 +146,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(); @@ -164,10 +176,19 @@ 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, + const int32_t sub_num) { return false; } virtual void set_selected_regionviews (RegionSelection&) {} - virtual void set_selected_points (PointSelection&) {} + virtual void set_selected_points (PointSelection&); virtual void fade_range (TimeSelection&) {} @@ -177,7 +198,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*); @@ -195,27 +216,24 @@ class TimeAxisView : public virtual AxisView virtual StreamView* view () const { return 0; } typedef std::vector > Children; - Children get_child_list (); - - SelectionRect* get_selection_rect(uint32_t id); + Children get_child_list () const; static uint32_t preset_height (Height); protected: - static Glib::RefPtr controls_button_size_group; static Glib::RefPtr controls_meters_size_group; - static Glib::RefPtr track_number_v_size_group; + static Glib::RefPtr midi_scroomer_size_group; static unsigned int name_width_px; /* The Standard LHS Controls */ Gtk::Table controls_table; + Glib::RefPtr controls_button_size_group; Gtk::EventBox controls_ebox; Gtk::VBox controls_vbox; Gtk::VBox time_axis_vbox; Gtk::HBox time_axis_hbox; Gtk::Frame time_axis_frame; - 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; @@ -237,17 +255,13 @@ class TimeAxisView : public virtual AxisView virtual bool can_edit_name() const; - bool name_entry_key_release (GdkEventKey *ev); - bool name_entry_key_press (GdkEventKey *ev); - bool name_entry_focus_out (GdkEventFocus *ev); - - Gtk::Entry* name_entry; void begin_name_edit (); - void end_name_edit (int); + void end_name_edit (std::string, int); + virtual std::string name () const { return name_label.get_text (); } /* derived classes can override these */ - virtual void name_entry_changed (); + virtual bool name_entry_changed (std::string const&); /** Handle mouse relaese on our LHS control name ebox. * @@ -276,6 +290,7 @@ class TimeAxisView : public virtual AxisView Children children; bool is_child (TimeAxisView*); + virtual bool propagate_time_selection () const { return false; } virtual void remove_child (boost::shared_ptr); void add_child (boost::shared_ptr); @@ -290,19 +305,22 @@ class TimeAxisView : public virtual AxisView void build_size_menu (); -private: + private: Gtk::VBox* control_parent; 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; static int const _max_order; + SelectionRect* get_selection_rect(uint32_t id); + void compute_heights (); bool maybe_set_cursor (int y);