X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Feditor_regions.h;h=ae830b0e24f09eb87fee22b8864e0e2b5ab38603;hb=bd80b2f144c012669b56c83821e137be655acfe4;hp=ad0a871aecb10f52fdb7ea80beb01a9950befbad;hpb=40903b19266fb42a49903ad3cbfb8c388704f068;p=ardour.git diff --git a/gtk2_ardour/editor_regions.h b/gtk2_ardour/editor_regions.h index ad0a871aec..ae830b0e24 100644 --- a/gtk2_ardour/editor_regions.h +++ b/gtk2_ardour/editor_regions.h @@ -20,6 +20,7 @@ #define __gtk_ardour_editor_regions_h__ #include "editor_component.h" +#include class EditorRegions : public EditorComponent, public ARDOUR::SessionHandlePtr { @@ -40,20 +41,20 @@ public: void reset_sort_type (Editing::RegionListSortType, bool); void set_selected (RegionSelection &); void selection_mapover (sigc::slot >); - + boost::shared_ptr get_dragged_region (); boost::shared_ptr get_single_selection (); - + Editing::RegionListSortType sort_type () const { return _sort_type; } - + void redisplay (); void suspend_redisplay () { _no_redisplay = true; } - + void resume_redisplay () { _no_redisplay = false; redisplay (); @@ -67,6 +68,8 @@ public: _display.get_selection()->unselect_all (); } + void remove_unused_regions (); + XMLNode& get_state () const; void set_state (const XMLNode &); @@ -80,7 +83,6 @@ private: add (position); add (end); add (length); - add (start); add (sync); add (fadein); add (fadeout); @@ -99,7 +101,6 @@ private: Gtk::TreeModelColumn position; Gtk::TreeModelColumn end; Gtk::TreeModelColumn length; - Gtk::TreeModelColumn start; Gtk::TreeModelColumn sync; Gtk::TreeModelColumn fadein; Gtk::TreeModelColumn fadeout; @@ -114,17 +115,22 @@ private: }; Columns _columns; - + Gtk::TreeModel::RowReference last_row; + void freeze_tree_model (); + void thaw_tree_model (); void region_changed (boost::shared_ptr, PBD::PropertyChange const &); void selection_changed (); - + sigc::connection _change_connection; - - bool set_selected_in_subrow (boost::shared_ptr, Gtk::TreeModel::Row const &, int); + bool selection_filter (const Glib::RefPtr& model, const Gtk::TreeModel::Path& path, bool yn); - + + Gtk::Widget* old_focus; + Gtk::CellEditable* name_editable; + void name_editing_started (Gtk::CellEditable*, const Glib::ustring&); + void name_edit (const std::string&, const std::string&); void locked_changed (std::string const &); void glued_changed (std::string const &); @@ -133,19 +139,24 @@ private: bool key_press (GdkEventKey *); bool button_press (GdkEventButton *); + + bool focus_in (GdkEventFocus*); + bool focus_out (GdkEventFocus*); + bool enter_notify (GdkEventCrossing*); + bool leave_notify (GdkEventCrossing*); + void show_context_menu (int button, int time); int sorter (Gtk::TreeModel::iterator, Gtk::TreeModel::iterator); - void format_position (ARDOUR::framepos_t pos, char* buf, size_t bufsize); + void format_position (ARDOUR::framepos_t pos, char* buf, size_t bufsize, bool onoff = true); void add_region (boost::shared_ptr); - void add_regions (std::vector > & ); - void populate_row (boost::shared_ptr, Gtk::TreeModel::Row const &); + + void populate_row (boost::shared_ptr, Gtk::TreeModel::Row const &, PBD::PropertyChange const &); void populate_row_used (boost::shared_ptr region, Gtk::TreeModel::Row const& row, uint32_t used); void populate_row_position (boost::shared_ptr region, Gtk::TreeModel::Row const& row, uint32_t used); void populate_row_end (boost::shared_ptr region, Gtk::TreeModel::Row const& row, uint32_t used); - void populate_row_start (boost::shared_ptr region, Gtk::TreeModel::Row const& row, uint32_t used); void populate_row_sync (boost::shared_ptr region, Gtk::TreeModel::Row const& row, uint32_t used); void populate_row_fade_in (boost::shared_ptr region, Gtk::TreeModel::Row const& row, uint32_t used, boost::shared_ptr); void populate_row_fade_out (boost::shared_ptr region, Gtk::TreeModel::Row const& row, uint32_t used, boost::shared_ptr); @@ -158,9 +169,8 @@ private: void populate_row_source (boost::shared_ptr region, Gtk::TreeModel::Row const& row); void update_row (boost::shared_ptr); - bool update_subrows (boost::shared_ptr, Gtk::TreeModel::Row const &, int); void update_all_rows (); - void update_all_subrows (Gtk::TreeModel::Row const &, int); + void insert_into_tmp_regionlist (boost::shared_ptr); void drag_data_received ( @@ -172,28 +182,40 @@ private: Glib::RefPtr hide_action () const; Glib::RefPtr show_action () const; + Glib::RefPtr remove_unused_regions_action () const; Glib::RefPtr toggle_full_action () const; Glib::RefPtr toggle_show_auto_regions_action () const; - + Gtk::Menu* _menu; Gtk::ScrolledWindow _scroller; Gtk::Frame _frame; + Gtkmm2ext::DnDTreeView > _display; + Glib::RefPtr _model; + bool _show_automatic_regions; - Editing::RegionListSortType _sort_type; + bool ignore_region_list_selection_change; + bool ignore_selected_region_change; bool _no_redisplay; + + Editing::RegionListSortType _sort_type; + std::list > tmp_region_list; + + typedef boost::unordered_map, Gtk::TreeModel::RowReference> RegionRowMap; + typedef boost::unordered_map RegionSourceMap; + + RegionRowMap region_row_map; + RegionSourceMap parent_regions_sources_map; + PBD::ScopedConnection region_property_connection; PBD::ScopedConnection check_new_region_connection; - bool ignore_region_list_selection_change; - bool ignore_selected_region_change; - bool expanded; - void select_one (Glib::RefPtr, Glib::RefPtr, Gtk::TreeView&, - Gtk::TreeIter, Gtk::TreePath, Gtk::TreeViewColumn*); - void select_next (); - void select_previous (); + PBD::ScopedConnection editor_freeze_connection; + PBD::ScopedConnection editor_thaw_connection; + + bool expanded; }; #endif /* __gtk_ardour_editor_regions_h__ */