changeset 147:e2ad3543c8a1

* stepsize/blocksize from plugin dialog actually working, though with some puzzlement
author Chris Cannam
date Wed, 20 Sep 2006 14:50:40 +0000 (2006-09-20)
parents a1f7d265ac79
children 4e7980e3b48e
files widgets/PluginParameterDialog.cpp
diffstat 1 files changed, 41 insertions(+), 14 deletions(-) [+]
line wrap: on
line diff
--- a/widgets/PluginParameterDialog.cpp	Tue Sep 19 14:37:06 2006 +0000
+++ b/widgets/PluginParameterDialog.cpp	Wed Sep 20 14:50:40 2006 +0000
@@ -19,6 +19,7 @@
 #include "WindowTypeSelector.h"
 
 #include "vamp-sdk/Plugin.h"
+#include "vamp-sdk/PluginHostAdapter.h"
 
 #include <QGridLayout>
 #include <QLabel>
@@ -75,7 +76,7 @@
 
     if (output != "") {
 
-        Vamp::Plugin *fePlugin = dynamic_cast<Vamp::Plugin *>(plugin);
+        Vamp::PluginHostAdapter *fePlugin = dynamic_cast<Vamp::PluginHostAdapter *>(m_plugin);
 
         if (fePlugin) {
 
@@ -92,8 +93,6 @@
                     }
                 }
             }
-        } else {
-            std::cerr << "Plugin " << plugin << " is not a feature extraction plugin" << std::endl;//!!!
         }
     }
 
@@ -108,26 +107,38 @@
     typeLabel->setWordWrap(true);
     typeLabel->setFont(font);
 
-    subgrid->addWidget(new QLabel(tr("Name:")), 0, 0);
+    QLabel *label = new QLabel(tr("Name:"));
+    label->setAlignment(Qt::AlignTop | Qt::AlignLeft);
+    subgrid->addWidget(label, 0, 0);
     subgrid->addWidget(nameLabel, 0, 1);
 
-    subgrid->addWidget(new QLabel(tr("Type:")), 1, 0);
+    label = new QLabel(tr("Type:"));
+    label->setAlignment(Qt::AlignTop | Qt::AlignLeft);
+    subgrid->addWidget(label, 1, 0);
     subgrid->addWidget(typeLabel, 1, 1);
 
     int outputOffset = 0;
     if (outputLabel) {
-        subgrid->addWidget(new QLabel(tr("Output:")), 2, 0);
+        label = new QLabel(tr("Output:"));
+        label->setAlignment(Qt::AlignTop | Qt::AlignLeft);
+        subgrid->addWidget(label, 2, 0);
         subgrid->addWidget(outputLabel, 2, 1);
         outputOffset = 1;
     }
 
-    subgrid->addWidget(new QLabel(tr("Maker:")), 2 + outputOffset, 0);
+    label = new QLabel(tr("Maker:"));
+    label->setAlignment(Qt::AlignTop | Qt::AlignLeft);
+    subgrid->addWidget(label, 2 + outputOffset, 0);
     subgrid->addWidget(makerLabel, 2 + outputOffset, 1);
 
-    subgrid->addWidget(new QLabel(tr("Copyright:  ")), 3 + outputOffset, 0);
+    label = new QLabel(tr("Copyright:  "));
+    label->setAlignment(Qt::AlignTop | Qt::AlignLeft);
+    subgrid->addWidget(label, 3 + outputOffset, 0);
     subgrid->addWidget(copyrightLabel, 3 + outputOffset, 1);
 
-    subgrid->addWidget(new QLabel(tr("Version:")), 4 + outputOffset, 0);
+    label = new QLabel(tr("Version:"));
+    label->setAlignment(Qt::AlignTop | Qt::AlignLeft);
+    subgrid->addWidget(label, 4 + outputOffset, 0);
     subgrid->addWidget(versionLabel, 4 + outputOffset, 1);
 
     subgrid->setColumnStretch(1, 2);
@@ -206,7 +217,7 @@
 
     if (showWindowSize) {
 
-        Vamp::Plugin *fePlugin = dynamic_cast<Vamp::Plugin *>(plugin);
+        Vamp::PluginHostAdapter *fePlugin = dynamic_cast<Vamp::PluginHostAdapter *>(m_plugin);
         int size = 1024;
         int increment = 1024;
         if (fePlugin) {
@@ -222,7 +233,7 @@
                 }
             }
         } else {
-            std::cerr << "Plugin " << plugin << " is not a feature extraction plugin" << std::endl;//!!!
+            std::cerr << "Plugin " << plugin << " is not a feature extraction plugin (it's a " << typeid(*plugin).name() << ")" << std::endl;//!!!
         }
 
         QGroupBox *windowBox = new QGroupBox;
@@ -246,10 +257,18 @@
 
         QComboBox *blockSizeCombo = new QComboBox;
         blockSizeCombo->setEditable(true);
+        bool found = false;
         for (int i = 0; i < 14; ++i) {
             int val = pow(2, i + 3);
             blockSizeCombo->addItem(QString("%1").arg(val));
-            if (val == size) blockSizeCombo->setCurrentIndex(i);
+            if (val == size) {
+                blockSizeCombo->setCurrentIndex(i);
+                found = true;
+            }
+        }
+        if (!found) {
+            blockSizeCombo->addItem(QString("%1").arg(size));
+            blockSizeCombo->setCurrentIndex(blockSizeCombo->count() - 1);
         }
         blockSizeCombo->setValidator(new QIntValidator(1, pow(2, 18), this));
         connect(blockSizeCombo, SIGNAL(textChanged(QString)),
@@ -262,10 +281,18 @@
         
             QComboBox *incrementCombo = new QComboBox;
             incrementCombo->setEditable(true);
+            found = false;
             for (int i = 0; i < 14; ++i) {
                 int val = pow(2, i + 3);
                 incrementCombo->addItem(QString("%1").arg(val));
-                if (val == increment) incrementCombo->setCurrentIndex(i);
+                if (val == increment) {
+                    incrementCombo->setCurrentIndex(i);
+                    found = true;
+                }
+            }
+            if (!found) {
+                incrementCombo->addItem(QString("%1").arg(increment));
+                incrementCombo->setCurrentIndex(incrementCombo->count() - 1);
             }
             incrementCombo->setValidator(new QIntValidator(1, pow(2, 18), this));
             connect(incrementCombo, SIGNAL(textChanged(QString)),
@@ -349,7 +376,7 @@
 {
     m_stepSize = text.toInt();
     //!!! rename increment to step size throughout
-    std::cerr << "Increment changed to " << m_blockSize << std::endl;
+    std::cerr << "Increment changed to " << m_stepSize << std::endl;
 }
 
 void