Mercurial > hg > sonic-visualiser
changeset 1987:fbf8ce45fcad import-audio-data
Use CSV format dialog for importing audio data, + some text changes
author | Chris Cannam |
---|---|
date | Thu, 06 Sep 2018 12:35:11 +0100 (2018-09-06) |
parents | bb9cf19e0b67 |
children | 17c58d48acfe |
files | main/MainWindow.cpp |
diffstat | 1 files changed, 20 insertions(+), 10 deletions(-) [+] |
line wrap: on
line diff
--- a/main/MainWindow.cpp Wed Sep 05 11:57:10 2018 +0100 +++ b/main/MainWindow.cpp Thu Sep 06 12:35:11 2018 +0100 @@ -59,6 +59,7 @@ #include "widgets/ActivityLog.h" #include "widgets/UnitConverter.h" #include "widgets/ProgressDialog.h" +#include "widgets/CSVFormatDialog.h" #include "audio/AudioCallbackPlaySource.h" #include "audio/AudioCallbackRecordTarget.h" #include "audio/PlaySpeedRangeMapper.h" @@ -606,12 +607,12 @@ menu->addSeparator(); - action = new QAction(tr("Import Audio Data from CSV..."), this); + action = new QAction(tr("Import Audio from Data File..."), this); action->setStatusTip(tr("Import audio sample values from a CSV data file")); connect(action, SIGNAL(triggered()), this, SLOT(importAudioData())); menu->addAction(action); - action = new QAction(tr("Export Audio Data to CSV..."), this); + action = new QAction(tr("Export Audio to Data File..."), this); action->setStatusTip(tr("Export audio from selection into a CSV data file")); connect(action, SIGNAL(triggered()), this, SLOT(exportAudioData())); connect(this, SIGNAL(canExportAudio(bool)), action, SLOT(setEnabled(bool))); @@ -2898,24 +2899,33 @@ format.setTimingType(CSVFormat::ImplicitTiming); format.setTimeUnits(CSVFormat::TimeAudioFrames); for (int i = 0; i < format.getColumnCount(); ++i) { - if (format.getColumnQualities()[i] & CSVFormat::ColumnNumeric) { + if (format.isColumnNumeric(CSVFormat::ColumnNumeric)) { format.setColumnPurpose(i, CSVFormat::ColumnValue); } } + { + CSVFormatDialog *dialog = new CSVFormatDialog(this, format); + if (dialog->exec() != QDialog::Accepted) { + delete dialog; + return; + } + format = dialog->getFormat(); + delete dialog; + } + FileOpenStatus status = FileOpenSucceeded; - ProgressDialog *dialog = new ProgressDialog(tr("Importing audio data..."), - true, 0, this, - Qt::ApplicationModal); + ProgressDialog *progress = new ProgressDialog + (tr("Importing audio data..."), true, 0, this, Qt::ApplicationModal); WaveFileModel *model = qobject_cast<WaveFileModel *> (DataFileReaderFactory::loadCSV (path, format, getMainModel() ? getMainModel()->getSampleRate() : rate, - dialog)); - - if (dialog->wasCancelled()) { + progress)); + + if (progress->wasCancelled()) { delete model; status = FileOpenCancelled; @@ -2934,7 +2944,7 @@ false); } - delete dialog; + delete progress; if (status == FileOpenFailed) { emit hideSplash();