changeset 1786:a72921e2194f time-frequency-boxes

Ensure CSV-style export from time-freq box model is in the expected format
author Chris Cannam
date Fri, 20 Sep 2019 11:24:47 +0100 (2019-09-20)
parents 894c2a780444
children 9ab3be243397
files data/model/TimeFrequencyBoxModel.h
diffstat 1 files changed, 31 insertions(+), 11 deletions(-) [+]
line wrap: on
line diff
--- a/data/model/TimeFrequencyBoxModel.h	Thu Sep 19 15:17:56 2019 +0100
+++ b/data/model/TimeFrequencyBoxModel.h	Fri Sep 20 11:24:47 2019 +0100
@@ -208,7 +208,7 @@
     }
 
     int getColumnCount() const override {
-        return 5;
+        return 6;
     }
 
     bool isColumnTimeValue(int column) const override {
@@ -234,8 +234,8 @@
         case 0: return tr("Time");
         case 1: return tr("Frame");
         case 2: return tr("Duration");
-        case 3: return tr("Minimum Frequency");
-        case 4: return tr("Maximum Frequency");
+        case 3: return tr("Min Freq");
+        case 4: return tr("Max Freq");
         case 5: return tr("Label");
         default: return tr("Unknown");
         }
@@ -323,14 +323,34 @@
                                   DataExportOptions options,
                                   sv_frame_t startFrame,
                                   sv_frame_t duration) const override {
-        return m_events.toDelimitedDataString
-            (delimiter,
-             options,
-             startFrame,
-             duration,
-             m_sampleRate,
-             m_resolution,
-             Event().withValue(0.f).withDuration(m_resolution));
+
+        // We need a custom format here
+
+        EventVector ee = m_events.getEventsSpanning(startFrame, duration);
+
+        QString s;
+        
+        for (auto e: ee) {
+
+            QStringList list;
+
+            list << RealTime::frame2RealTime
+                (e.getFrame(), getSampleRate())
+                .toString().c_str()
+                 << RealTime::frame2RealTime
+                (e.getFrame() + e.getDuration(), getSampleRate())
+                .toString().c_str()
+                 << QString("%1").arg(e.getValue())
+                 << QString("%1").arg(e.getValue() + fabsf(e.getLevel()));
+            
+            if (e.getLabel() != "") {
+                list << e.getLabel();
+            }
+
+            s += list.join(delimiter) + "\n";
+        }
+
+        return s;
     }
 
 protected: