Mercurial > hg > svgui
diff layer/Colour3DPlotExporter.cpp @ 1593:32171776fcc9 sensible-delimited-data-strings
Switch to the StringExport api now found in svcore
author | Chris Cannam |
---|---|
date | Fri, 03 Apr 2020 17:12:37 +0100 |
parents | b33b0b06133e |
children |
line wrap: on
line diff
--- a/layer/Colour3DPlotExporter.cpp Fri Apr 03 12:12:47 2020 +0100 +++ b/layer/Colour3DPlotExporter.cpp Fri Apr 03 17:12:37 2020 +0100 @@ -45,9 +45,8 @@ m_sources.provider = nullptr; } -QString -Colour3DPlotExporter::getDelimitedDataHeaderLine(QString delimiter, - DataExportOptions opts) const +QVector<QString> +Colour3DPlotExporter::getStringExportHeaders(DataExportOptions opts) const { auto model = ModelById::getAs<DenseThreeDimensionalModel>(m_sources.source); @@ -74,19 +73,19 @@ if (minbin + nbins > sh) nbins = sh - minbin; } - QStringList list; + QVector<QString> headers; if (opts & DataExportAlwaysIncludeTimestamp) { if (opts & DataExportWriteTimeInFrames) { - list << "FRAME"; + headers << "FRAME"; } else { - list << "TIME"; + headers << "TIME"; } } if (m_params.binDisplay == BinDisplay::PeakFrequencies) { for (int i = 0; i < nbins/4; ++i) { - list << QString("FREQ %1").arg(i+1) + headers << QString("FREQ %1").arg(i+1) << QString("MAG %1").arg(i+1); } } else { @@ -111,18 +110,17 @@ .arg(i+1); } } - list << name; + headers << name; } } - return list.join(delimiter); + return headers; } -QString -Colour3DPlotExporter::toDelimitedDataString(QString delimiter, - DataExportOptions opts, - sv_frame_t startFrame, - sv_frame_t duration) const +QVector<QVector<QString>> +Colour3DPlotExporter::toStringExportRows(DataExportOptions opts, + sv_frame_t startFrame, + sv_frame_t duration) const { QMutexLocker locker(&m_mutex); @@ -161,7 +159,7 @@ int w = model->getWidth(); - QString s; + QVector<QVector<QString>> rows; for (int i = 0; i < w; ++i) { @@ -179,13 +177,13 @@ // The scale factor is always applied column = ColumnOp::applyGain(column, m_params.scaleFactor); - QStringList list; - + QVector<QString> row; + if (opts & DataExportAlwaysIncludeTimestamp) { if (opts & DataExportWriteTimeInFrames) { - list << QString("%1").arg(fr); + row << QString("%1").arg(fr); } else { - list << RealTime::frame2RealTime(fr, model->getSampleRate()) + row << RealTime::frame2RealTime(fr, model->getSampleRate()) .toString().c_str(); } } @@ -216,7 +214,7 @@ double freq = p.second; double value = column[bin - minbin]; - list << QString("%1").arg(freq) << QString("%1").arg(value); + row << QString("%1").arg(freq) << QString("%1").arg(value); } } else { @@ -226,15 +224,15 @@ } for (auto value: column) { - list << QString("%1").arg(value); + row << QString("%1").arg(value); } } - if (!list.empty()) { - s += list.join(delimiter) + "\n"; + if (!row.empty()) { + rows.push_back(row); } } - return s; + return rows; }