X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Ftime_axis_view.h;h=682514acfae51cf6b2e76bdc6ac84c226bcda795;hb=ad017365f7a73f8ba57f667cc1aa36478b48c50e;hp=7dc3ba9494b96403d86bbd79210ba3efbff9bf59;hpb=e2f0c5f91e2579c41d8efc9495b6ebac31a61ba3;p=ardour.git diff --git a/gtk2_ardour/time_axis_view.h b/gtk2_ardour/time_axis_view.h index 7dc3ba9494..682514acfa 100644 --- a/gtk2_ardour/time_axis_view.h +++ b/gtk2_ardour/time_axis_view.h @@ -24,12 +24,14 @@ #include #include +#include #include #include #include #include #include #include +#include #include @@ -40,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" @@ -59,7 +63,7 @@ namespace Gtk { namespace ArdourCanvas { class Canvas; - class Group; + class Container; class Item; } @@ -82,14 +86,13 @@ class ArdourDialog; */ class TimeAxisView : public virtual AxisView { - private: + private: enum NamePackingBits { NameLabelPacked = 0x1, NameEntryPacked = 0x2 }; - public: - + public: TimeAxisView(ARDOUR::Session* sess, PublicEditor& ed, TimeAxisView* parent, ArdourCanvas::Canvas& canvas); virtual ~TimeAxisView (); @@ -101,14 +104,14 @@ class TimeAxisView : public virtual AxisView /** @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 () {} + virtual void enter_internal_edit_mode () {} + virtual void leave_internal_edit_mode () {} - ArdourCanvas::Group* canvas_display () { return _canvas_display; } - ArdourCanvas::Group* ghost_group () { return _ghost_group; } + ArdourCanvas::Container* canvas_display () { return _canvas_display; } + ArdourCanvas::Container* ghost_group () { return _ghost_group; } /** @return effective height (taking children into account) in canvas units, or - 0 if this TimeAxisView has not yet been shown */ + 0 if this TimeAxisView has not yet been shown */ uint32_t effective_height () const { return _effective_height; } /** @return y position, or -1 if hidden */ @@ -144,7 +147,8 @@ class TimeAxisView : public virtual AxisView virtual void reset_visual_state (); - std::pair covers_y_position (double); + std::pair covers_y_position (double) const; + bool covered_by_y_range (double y0, double y1) const; virtual void step_height (bool); @@ -166,11 +170,13 @@ class TimeAxisView : public virtual AxisView virtual void set_selected_regionviews (RegionSelection&) {} virtual void set_selected_points (PointSelection&) {} + virtual void fade_range (TimeSelection&) {} + virtual boost::shared_ptr find_next_region (framepos_t /*pos*/, ARDOUR::RegionPoint, int32_t /*dir*/) { return boost::shared_ptr (); } - void order_selection_trims (ArdourCanvas::Item *item, bool put_start_on_top); + 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_inverted_selectables (Selection&, std::list& results); @@ -193,44 +199,53 @@ class TimeAxisView : public virtual AxisView Children get_child_list (); SelectionRect* get_selection_rect(uint32_t id); - + static uint32_t preset_height (Height); - protected: + 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::HBox controls_hbox; 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; - bool _name_editing; - uint32_t height; /* in canvas units */ + Gtk::Fixed scroomer_placeholder; + bool _name_editing; + uint32_t height; /* in canvas units */ std::string controls_base_unselected_name; std::string controls_base_selected_name; Gtk::Menu* display_menu; /* The standard LHS Track control popup-menus */ TimeAxisView* parent; - ArdourCanvas::Group* selection_group; + ArdourCanvas::Container* selection_group; + ArdourCanvas::Container* _ghost_group; std::list ghosts; std::list free_selection_rects; std::list used_selection_rects; bool _hidden; bool in_destructor; Gtk::Menu* _size_menu; - ArdourCanvas::Group* _canvas_display; + ArdourCanvas::Line* _canvas_separator; + ArdourCanvas::Container* _canvas_display; double _y_position; PublicEditor& _editor; - virtual bool can_edit_name() const; + 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); + Gtk::Entry* name_entry; + void begin_name_edit (); + void end_name_edit (int); /* derived classes can override these */ @@ -278,23 +293,21 @@ class TimeAxisView : public virtual AxisView void build_size_menu (); private: - Gtk::VBox* control_parent; + Gtk::VBox* control_parent; int _order; uint32_t _effective_height; double _resize_drag_start; GdkCursor* _preresize_cursor; bool _have_preresize_cursor; - ArdourCanvas::Group* _ghost_group; - 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; - + void compute_heights (); bool maybe_set_cursor (int y); }; /* class TimeAxisView */ #endif /* __ardour_gtk_time_axis_h__ */ -