X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fexport_timespan_selector.h;h=91a53e5fb274ab6d7388c2da76559715355a810e;hb=a2c0b10d8a6cf4ab5a0fdcdfe157c35c0ed9a709;hp=1c4a952913dc283822229543487c2affe9edbfcc;hpb=52003be3695ab703b936163d7284e208790d5363;p=ardour.git diff --git a/gtk2_ardour/export_timespan_selector.h b/gtk2_ardour/export_timespan_selector.h index 1c4a952913..91a53e5fb2 100644 --- a/gtk2_ardour/export_timespan_selector.h +++ b/gtk2_ardour/export_timespan_selector.h @@ -25,9 +25,14 @@ #include +#ifdef interface +#undef interface +#endif + #include #include + #include "ardour/types.h" #include "ardour/session_handle.h" #include "ardour/export_profile_manager.h" @@ -55,11 +60,12 @@ class ExportTimespanSelector : public Gtk::VBox, public ARDOUR::SessionHandlePtr 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; @@ -67,11 +73,14 @@ class ExportTimespanSelector : public Gtk::VBox, public ARDOUR::SessionHandlePtr 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 (); @@ -88,8 +97,9 @@ class ExportTimespanSelector : public Gtk::VBox, public ARDOUR::SessionHandlePtr /*** 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 */ @@ -115,10 +125,11 @@ class ExportTimespanSelector : public Gtk::VBox, public ARDOUR::SessionHandlePtr Gtk::TreeModelColumn location; Gtk::TreeModelColumn label; Gtk::TreeModelColumn selected; + Gtk::TreeModelColumn realtime; Gtk::TreeModelColumn name; Gtk::TreeModelColumn length; - RangeCols () { add (location); add(label); add(selected); add(name); add(length); } + RangeCols () { add (location); add(label); add(selected); add(realtime); add(name); add(length); } }; RangeCols range_cols; @@ -134,6 +145,8 @@ class ExportTimespanSelectorMultiple : public ExportTimespanSelector public: ExportTimespanSelectorMultiple (ARDOUR::Session * session, ProfileManagerPtr manager); + void allow_realtime_export (bool); + private: virtual void fill_range_list (); @@ -149,9 +162,12 @@ class ExportTimespanSelectorSingle : public ExportTimespanSelector public: ExportTimespanSelectorSingle (ARDOUR::Session * session, ProfileManagerPtr manager, std::string range_id); + void allow_realtime_export (bool); + private: virtual void fill_range_list (); + void update_timespans (); std::string range_id;