X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fexport_timespan_selector.h;h=1e1460db6cc3cdb62aa383351974daf3212c59a5;hb=7d553eea8028977021f1526b8ab538737a21767c;hp=72d5990422a5ed624ae0adaffdf93ce66a87d424;hpb=bb9cc45cd22af67ac275a5e73accbe14fee664d8;p=ardour.git diff --git a/gtk2_ardour/export_timespan_selector.h b/gtk2_ardour/export_timespan_selector.h index 72d5990422..1e1460db6c 100644 --- a/gtk2_ardour/export_timespan_selector.h +++ b/gtk2_ardour/export_timespan_selector.h @@ -21,72 +21,93 @@ #ifndef __export_timespan_selector_h__ #define __export_timespan_selector_h__ -#include "public_editor.h" #include "audio_clock.h" #include -#include +#ifdef interface +#undef interface +#endif + #include +#include +#include +#include +#include +#include +#include +#include +#include +#include + #include "ardour/types.h" +#include "ardour/session_handle.h" #include "ardour/export_profile_manager.h" namespace ARDOUR { class Location; class ExportTimespan; class ExportHandler; - class Session; } using ARDOUR::CDMarkerFormat; +using ARDOUR::framecnt_t; /// Timespan Selector base -class ExportTimespanSelector : public Gtk::VBox { - protected: +class ExportTimespanSelector : public Gtk::VBox, public ARDOUR::SessionHandlePtr +{ +protected: typedef std::list LocationList; typedef boost::shared_ptr HandlerPtr; typedef boost::shared_ptr ProfileManagerPtr; - typedef boost::shared_ptr TimespanPtr; - typedef std::list TimespanList; + typedef std::list TimespanList; typedef boost::shared_ptr TimespanListPtr; typedef ARDOUR::ExportProfileManager::TimespanStatePtr TimespanStatePtr; - public: +public: - ExportTimespanSelector (ARDOUR::Session * session, ProfileManagerPtr manager); + ExportTimespanSelector (ARDOUR::Session * session, ProfileManagerPtr manager, bool multi); virtual ~ExportTimespanSelector (); void sync_with_manager (); + virtual void allow_realtime_export (bool); sigc::signal CriticalSelectionChanged; - protected: +protected: - ARDOUR::Session * session; ProfileManagerPtr manager; TimespanStatePtr state; + bool _realtime_available; virtual void fill_range_list () = 0; + virtual void update_timespans () = 0; - void add_range_to_selection (ARDOUR::Location const * loc); + void add_range_to_selection (ARDOUR::Location const * loc, bool rt); void set_time_format_from_state (); + void toggle_realtime (); void change_time_format (); - Glib::ustring construct_label (ARDOUR::Location const * location) const; - Glib::ustring bbt_str (nframes_t frames) const; - Glib::ustring smpte_str (nframes_t frames) const; - Glib::ustring ms_str (nframes_t frames) const; + std::string construct_label (ARDOUR::Location const * location) const; + std::string construct_length (ARDOUR::Location const * location) const; + std::string bbt_str (framepos_t frames) const; + std::string timecode_str (framecnt_t frames) const; + std::string ms_str (framecnt_t frames) const; + + void update_range_name (std::string const & path, std::string const & new_text); - void update_range_name (Glib::ustring const & path, Glib::ustring const & new_text); + void set_selection_state_of_all_timespans (bool); + int location_sorter(Gtk::TreeModel::iterator a, Gtk::TreeModel::iterator b); /*** GUI components ***/ - Gtk::HBox option_hbox; - Gtk::Label time_format_label; + Gtk::HBox option_hbox; + Gtk::Label time_format_label; + Gtk::CheckButton realtime_checkbutton; /* Time format */ @@ -94,9 +115,9 @@ class ExportTimespanSelector : public Gtk::VBox { struct TimeFormatCols : public Gtk::TreeModelColumnRecord { - public: + public: Gtk::TreeModelColumn format; - Gtk::TreeModelColumn label; + Gtk::TreeModelColumn label; TimeFormatCols () { add(format); add(label); } }; @@ -108,13 +129,15 @@ class ExportTimespanSelector : public Gtk::VBox { struct RangeCols : public Gtk::TreeModelColumnRecord { - public: + public: Gtk::TreeModelColumn location; - Gtk::TreeModelColumn label; - Gtk::TreeModelColumn selected; - Gtk::TreeModelColumn name; + Gtk::TreeModelColumn label; + Gtk::TreeModelColumn selected; + Gtk::TreeModelColumn realtime; + Gtk::TreeModelColumn name; + Gtk::TreeModelColumn length; - RangeCols () { add (location); add(label); add(selected); add(name); } + RangeCols () { add (location); add(label); add(selected); add(realtime); add(name); add(length); } }; RangeCols range_cols; @@ -124,13 +147,15 @@ class ExportTimespanSelector : public Gtk::VBox { Gtk::ScrolledWindow range_scroller; }; -/// Allows seleting multiple timespans +/// Allows selecting multiple timespans class ExportTimespanSelectorMultiple : public ExportTimespanSelector { - public: +public: ExportTimespanSelectorMultiple (ARDOUR::Session * session, ProfileManagerPtr manager); - private: + void allow_realtime_export (bool); + +private: virtual void fill_range_list (); @@ -142,14 +167,17 @@ class ExportTimespanSelectorMultiple : public ExportTimespanSelector /// Displays one timespan class ExportTimespanSelectorSingle : public ExportTimespanSelector { - public: - ExportTimespanSelectorSingle (ARDOUR::Session * session, ProfileManagerPtr manager, Glib::ustring range_id); +public: + ExportTimespanSelectorSingle (ARDOUR::Session * session, ProfileManagerPtr manager, std::string range_id); + + void allow_realtime_export (bool); - private: +private: virtual void fill_range_list (); + void update_timespans (); - Glib::ustring range_id; + std::string range_id; };