[Summary] Progressing Tracks specific export dialog.

This commit is contained in:
VKamyshniy 2015-01-16 07:52:24 +02:00
parent 360692e838
commit 0729ff3f8e
5 changed files with 156 additions and 17 deletions

View file

@ -45,6 +45,7 @@
#include "audio_region_view.h" #include "audio_region_view.h"
#include "audio_time_axis.h" #include "audio_time_axis.h"
#include "editor.h" #include "editor.h"
#include "waves_export_dialog.h"
#include "export_dialog.h" #include "export_dialog.h"
#include "midi_export_dialog.h" #include "midi_export_dialog.h"
#include "midi_region_view.h" #include "midi_region_view.h"
@ -63,6 +64,10 @@ using namespace Gtk;
void void
Editor::export_audio () Editor::export_audio ()
{ {
{
WavesExportDialog export_dialog (_("Export"), _session, ExportProfileManager::RegularExport);
export_dialog.run();
}
ExportDialog dialog (*this, _("Export"), ExportProfileManager::RegularExport); ExportDialog dialog (*this, _("Export"), ExportProfileManager::RegularExport);
dialog.set_session (_session); dialog.set_session (_session);
dialog.run(); dialog.run();

View file

@ -18,11 +18,16 @@
*/ */
#include "waves_export_dialog.h" #include "waves_export_dialog.h"
WavesExportDialog::WavesExportDialog (const std::string &title, ARDOUR::ExportProfileManager::ExportType type)
WavesExportDialog::WavesExportDialog (const std::string &title, ARDOUR::Session* session, ARDOUR::ExportProfileManager::ExportType type)
: WavesDialog ("waves_export_dialog.xml", true, false ) : WavesDialog ("waves_export_dialog.xml", true, false )
, _export_button (get_waves_button ("export_button")) , _export_button (get_waves_button ("export_button"))
, _cancel_button (get_waves_button ("cancel_button")) , _cancel_button (get_waves_button ("cancel_button"))
, _stop_export_button (get_waves_button ("stop_export_button"))
, _export_progress_bar (get_progressbar ("export_progress_bar"))
, _export_type (type)
, _previous_progress (0)
{ {
set_title (title); set_title (title);
init (); init (session);
} }

View file

@ -21,23 +21,19 @@
#define __waves_export_dialog_h__ #define __waves_export_dialog_h__
#include "ardour/export_profile_manager.h" #include "ardour/export_profile_manager.h"
#include "public_editor.h"
#include "export_timespan_selector.h"
#include "export_channel_selector.h"
#include "export_file_notebook.h"
#include "export_preset_selector.h"
#include "soundcloud_export_selector.h"
#include "waves_dialog.h" #include "waves_dialog.h"
class WavesExportDialog : public WavesDialog class WavesExportDialog : public WavesDialog
{ {
public: public:
WavesExportDialog(const std::string &title, ARDOUR::ExportProfileManager::ExportType type); WavesExportDialog(const std::string &title, ARDOUR::Session* session, ARDOUR::ExportProfileManager::ExportType type);
protected: protected:
WavesButton& _export_button; WavesButton& _export_button;
WavesButton& _cancel_button; WavesButton& _cancel_button;
WavesButton& _stop_export_button;
Gtk::ProgressBar &_export_progress_bar;
private: private:
#include "waves_export_dialog.logic.h" #include "waves_export_dialog.logic.h"

View file

@ -17,23 +17,135 @@
*/ */
#include "ardour/audioregion.h"
#include "ardour/export_status.h"
#include "ardour/export_handler.h"
#include "waves_export_dialog.h" #include "waves_export_dialog.h"
#include "public_editor.h"
#include "ardour_ui.h"
#include "time_selection.h"
#include "i18n.h"
void void
WavesExportDialog::init () WavesExportDialog::init (ARDOUR::Session* session)
{ {
_export_button.signal_clicked.connect (sigc::mem_fun (*this, &WavesExportDialog::_on_export_button_clicked)); _export_button.signal_clicked.connect (sigc::mem_fun (*this, &WavesExportDialog::_on_export_button_clicked));
_cancel_button.signal_clicked.connect (sigc::mem_fun (*this, &WavesExportDialog::_on_export_button_clicked)); _cancel_button.signal_clicked.connect (sigc::mem_fun (*this, &WavesExportDialog::_on_cancel_button_clicked));
SessionHandlePtr::set_session (session);
if (!_session) {
return;
}
/* Init handler and profile manager */
_export_handler = _session->get_export_handler ();
_export_status = _session->get_export_status ();
_profile_manager.reset (new ARDOUR::ExportProfileManager (*_session, _export_type));
TimeSelection const & time (ARDOUR_UI::instance()->the_editor ().get_selection().time);
if (!time.empty()) {
_profile_manager->set_selection_range (time.front().start, time.front().end);
} else {
_profile_manager->set_selection_range ();
}
}
void
WavesExportDialog::_show_progress ()
{
_export_status->running = true;
_cancel_button.hide ();
_stop_export_button.show ();
_export_progress_bar.set_fraction (0.0);
_export_progress_bar.show ();
_progress_connection = Glib::signal_timeout().connect (sigc::mem_fun(*this, &WavesExportDialog::_on_progress_timeout), 100);
gtk_main_iteration ();
while (_export_status->running) {
if (gtk_events_pending()) {
gtk_main_iteration ();
} else {
Glib::usleep (10000);
}
}
if (_export_status->aborted()) {
_notify_errors ();
}
_export_status->finish ();
}
void
WavesExportDialog::_notify_errors (bool force)
{
if (force || _export_status->errors()) {
std::string txt = _("Export has been aborted due to an error!\nSee the Log for details.");
WavesMessageDialog msg ("", txt);
msg.run();
}
} }
void void
WavesExportDialog::_on_export_button_clicked (WavesButton*) WavesExportDialog::_on_export_button_clicked (WavesButton*)
{ {
response (Gtk::RESPONSE_OK); _export_error.clear ();
_previous_progress = 0;
try {
_profile_manager->prepare_for_export ();
_export_handler->soundcloud_make_public = false;
_export_handler->soundcloud_open_page = false;
_export_handler->soundcloud_downloadable = false;
_export_handler->do_export ();
_show_progress ();
} catch(std::exception & e) {
_export_error << string_compose (_("Export initialization failed: %1"), e.what()) << endmsg;
_notify_errors(true);
}
} }
void void
WavesExportDialog::_on_cancel_button_clicked (WavesButton*) WavesExportDialog::_on_cancel_button_clicked (WavesButton*)
{ {
if (_export_status->running) {
_export_status->abort();
}
hide ();
set_modal (false);
response (Gtk::RESPONSE_CANCEL); response (Gtk::RESPONSE_CANCEL);
} }
gint
WavesExportDialog::_on_progress_timeout ()
{
std::string status_text;
float progress = 0.0;
if (_export_status->normalizing) {
status_text = string_compose (_("Normalizing '%3' (timespan %1 of %2)"),
_export_status->timespan, _export_status->total_timespans, _export_status->timespan_name);
progress = ((float) _export_status->current_normalize_cycle) / _export_status->total_normalize_cycles;
} else {
status_text = string_compose (_("Exporting '%3' (timespan %1 of %2)"),
_export_status->timespan, _export_status->total_timespans, _export_status->timespan_name);
progress = ((float) _export_status->processed_frames_current_timespan) / _export_status->total_frames_current_timespan;
}
_export_progress_bar.set_text (status_text);
if (progress < _previous_progress) {
// Work around gtk bug
_export_progress_bar.hide();
_export_progress_bar.show();
}
_previous_progress = progress;
_export_progress_bar.set_fraction (progress);
return TRUE;
}

View file

@ -19,8 +19,29 @@
//class WavesExportDialog : public WavesDialog //class WavesExportDialog : public WavesDialog
//{ //{
private: protected:
void init ();
void _on_export_button_clicked (WavesButton*); typedef boost::shared_ptr<ARDOUR::ExportHandler> HandlerPtr;
void _on_cancel_button_clicked (WavesButton*); HandlerPtr _export_handler;
typedef boost::shared_ptr<ARDOUR::ExportProfileManager> ManagerPtr;
ManagerPtr _profile_manager;
typedef boost::shared_ptr<ARDOUR::ExportStatus> StatusPtr;
StatusPtr _export_status;
ARDOUR::ExportProfileManager::ExportType _export_type;
sigc::connection _progress_connection;
std::stringstream _export_error;
float _previous_progress; // Needed for gtk bug workaround.
void init (ARDOUR::Session* session);
void _show_progress ();
void _notify_errors (bool force = false);
void _on_export_button_clicked (WavesButton*);
void _on_cancel_button_clicked (WavesButton*);
gint _on_progress_timeout ();
//}; //};