changeset 299:15ce557e1bf8

* Restore (better quality) y-axis interpolation in spectrogram * Make spectrogram x axis interpolation a preference
author Chris Cannam
date Fri, 06 Feb 2009 15:06:23 +0000 (2009-02-06)
parents 7872a95ee530
children f68506fccb62
files main/PreferencesDialog.cpp main/PreferencesDialog.h
diffstat 2 files changed, 34 insertions(+), 3 deletions(-) [+]
line wrap: on
line diff
--- a/main/PreferencesDialog.cpp	Thu Feb 05 17:33:21 2009 +0000
+++ b/main/PreferencesDialog.cpp	Fri Feb 06 15:06:23 2009 +0000
@@ -74,12 +74,12 @@
 
     QComboBox *smoothing = new QComboBox;
     
-    int sm = prefs->getPropertyRangeAndValue("Spectrogram Smoothing", &min, &max,
+    int sm = prefs->getPropertyRangeAndValue("Spectrogram Y Smoothing", &min, &max,
                                              &deflt);
     m_spectrogramSmoothing = sm;
 
     for (i = min; i <= max; ++i) {
-        smoothing->addItem(prefs->getPropertyValueLabel("Spectrogram Smoothing", i));
+        smoothing->addItem(prefs->getPropertyValueLabel("Spectrogram Y Smoothing", i));
     }
 
     smoothing->setCurrentIndex(sm);
@@ -87,6 +87,21 @@
     connect(smoothing, SIGNAL(currentIndexChanged(int)),
             this, SLOT(spectrogramSmoothingChanged(int)));
 
+    QComboBox *xsmoothing = new QComboBox;
+    
+    int xsm = prefs->getPropertyRangeAndValue("Spectrogram X Smoothing", &min, &max,
+                                             &deflt);
+    m_spectrogramXSmoothing = xsm;
+
+    for (i = min; i <= max; ++i) {
+        xsmoothing->addItem(prefs->getPropertyValueLabel("Spectrogram X Smoothing", i));
+    }
+
+    xsmoothing->setCurrentIndex(xsm);
+
+    connect(xsmoothing, SIGNAL(currentIndexChanged(int)),
+            this, SLOT(spectrogramXSmoothingChanged(int)));
+
     QComboBox *propertyLayout = new QComboBox;
     int pl = prefs->getPropertyRangeAndValue("Property Box Layout", &min, &max,
                                          &deflt);
@@ -278,10 +293,15 @@
     subgrid->addWidget(frequency, row++, 1, 1, 2);
 
     subgrid->addWidget(new QLabel(prefs->getPropertyLabel
-                                  ("Spectrogram Smoothing")),
+                                  ("Spectrogram Y Smoothing")),
                        row, 0);
     subgrid->addWidget(smoothing, row++, 1, 1, 2);
 
+    subgrid->addWidget(new QLabel(prefs->getPropertyLabel
+                                  ("Spectrogram X Smoothing")),
+                       row, 0);
+    subgrid->addWidget(xsmoothing, row++, 1, 1, 2);
+
     subgrid->addWidget(new QLabel(tr("%1:").arg(prefs->getPropertyLabel
                                                 ("Window Type"))),
                        row, 0);
@@ -328,6 +348,13 @@
 }
 
 void
+PreferencesDialog::spectrogramXSmoothingChanged(int smoothing)
+{
+    m_spectrogramXSmoothing = smoothing;
+    m_applyButton->setEnabled(true);
+}
+
+void
 PreferencesDialog::propertyLayoutChanged(int layout)
 {
     m_propertyLayout = layout;
@@ -420,6 +447,8 @@
     prefs->setWindowType(WindowType(m_windowType));
     prefs->setSpectrogramSmoothing(Preferences::SpectrogramSmoothing
                                    (m_spectrogramSmoothing));
+    prefs->setSpectrogramXSmoothing(Preferences::SpectrogramXSmoothing
+                                   (m_spectrogramXSmoothing));
     prefs->setPropertyBoxLayout(Preferences::PropertyBoxLayout
                                 (m_propertyLayout));
     prefs->setTuningFrequency(m_tuningFrequency);
--- a/main/PreferencesDialog.h	Thu Feb 05 17:33:21 2009 +0000
+++ b/main/PreferencesDialog.h	Fri Feb 06 15:06:23 2009 +0000
@@ -38,6 +38,7 @@
 protected slots:
     void windowTypeChanged(WindowType type);
     void spectrogramSmoothingChanged(int state);
+    void spectrogramXSmoothingChanged(int state);
     void propertyLayoutChanged(int layout);
     void tuningFrequencyChanged(double freq);
     void audioDeviceChanged(int device);
@@ -62,6 +63,7 @@
     
     WindowType m_windowType;
     int m_spectrogramSmoothing;
+    int m_spectrogramXSmoothing;
     int m_propertyLayout;
     float m_tuningFrequency;
     int m_audioDevice;