changeset 180:29f01de27db4

* Add vertical zooming and snap-to-selection for OSC control; add a demo script
author Chris Cannam
date Wed, 15 Nov 2006 18:22:26 +0000 (2006-11-15)
parents 6a0d54f3f21a
children c4d407272010
files layer/Layer.h layer/SpectrogramLayer.cpp view/PaneStack.cpp view/PaneStack.h view/View.cpp view/ViewManager.cpp view/ViewManager.h
diffstat 7 files changed, 28 insertions(+), 11 deletions(-) [+]
line wrap: on
line diff
--- a/layer/Layer.h	Tue Nov 14 16:06:00 2006 +0000
+++ b/layer/Layer.h	Wed Nov 15 18:22:26 2006 +0000
@@ -127,9 +127,9 @@
      * calls to editStart etc.
      *
      * Return true if a suitable feature was found and frame adjusted
-     * accordingly.  Return false if no suitable feature was
-     * available.  Also return the resolution of the model in this
-     * layer in sample frames.
+     * accordingly.  Return false if no suitable feature was available
+     * (and leave frame unmodified).  Also return the resolution of
+     * the model in this layer in sample frames.
      */
     virtual bool snapToFeatureFrame(View *   /* v */,
 				    int &    /* frame */,
@@ -301,7 +301,11 @@
      * If vertical zooming is not available, return 0.  The meaning of
      * "zooming" is entirely up to the layer -- changing the zoom
      * level may cause the layer to reset its display extents or
-     * change another property such as display gain.
+     * change another property such as display gain.  However, layers
+     * are advised for consistency to treat smaller zoom steps as
+     * "more distant" or "zoomed out" and larger ones as "closer" or
+     * "zoomed in".
+     * 
      * Layers that provide this facility should also emit the
      * verticalZoomChanged signal if their vertical zoom changes
      * due to factors other than setVerticalZoomStep being called.
--- a/layer/SpectrogramLayer.cpp	Tue Nov 14 16:06:00 2006 +0000
+++ b/layer/SpectrogramLayer.cpp	Wed Nov 15 18:22:26 2006 +0000
@@ -2188,8 +2188,8 @@
         return;
     }
 
-    std::cerr << "SpectrogramLayer: illuminateLocalFeatures("
-              << localPos.x() << "," << localPos.y() << ")" << std::endl;
+//    std::cerr << "SpectrogramLayer: illuminateLocalFeatures("
+//              << localPos.x() << "," << localPos.y() << ")" << std::endl;
 
     float s0, s1;
     float f0, f1;
@@ -2206,8 +2206,8 @@
         int y1 = getYForFrequency(v, f1);
         int y0 = getYForFrequency(v, f0);
         
-        std::cerr << "SpectrogramLayer: illuminate "
-                  << x0 << "," << y1 << " -> " << x1 << "," << y0 << std::endl;
+//        std::cerr << "SpectrogramLayer: illuminate "
+//                  << x0 << "," << y1 << " -> " << x1 << "," << y0 << std::endl;
         
         paint.setPen(Qt::white);
 
--- a/view/PaneStack.cpp	Tue Nov 14 16:06:00 2006 +0000
+++ b/view/PaneStack.cpp	Wed Nov 15 18:22:26 2006 +0000
@@ -426,6 +426,8 @@
 	if (!m_panes[i].propertyStack) continue;
 	m_panes[i].propertyStack->setMinimumWidth(setWidth);
     }
+
+    emit propertyStacksResized();
 }
     
 
--- a/view/PaneStack.h	Tue Nov 14 16:06:00 2006 +0000
+++ b/view/PaneStack.h	Wed Nov 15 18:22:26 2006 +0000
@@ -67,6 +67,7 @@
     void currentPaneChanged(Pane *pane);
     void currentLayerChanged(Pane *pane, Layer *layer);
     void rightButtonMenuRequested(Pane *pane, QPoint position);
+    void propertyStacksResized();
 
 public slots:
     void propertyContainerAdded(PropertyContainer *);
--- a/view/View.cpp	Tue Nov 14 16:06:00 2006 +0000
+++ b/view/View.cpp	Wed Nov 15 18:22:26 2006 +0000
@@ -771,7 +771,7 @@
 
     case PlaybackScrollContinuous:
 	if (QApplication::mouseButtons() == Qt::NoButton) {
-	    setCentreFrame(f, false);
+	    setCentreFrame(f, true); //!!!
 	}
 	break;
 
@@ -1451,7 +1451,7 @@
 	}
 
 	if (sampleRate && shouldLabelSelections() && m_manager &&
-            m_manager->getOverlayMode() != ViewManager::NoOverlays) {
+            m_manager->getOverlayMode() == ViewManager::AllOverlays) {
 	    
 	    QString startText = QString("%1 / %2")
 		.arg(QString::fromStdString
--- a/view/ViewManager.cpp	Tue Nov 14 16:06:00 2006 +0000
+++ b/view/ViewManager.cpp	Wed Nov 15 18:22:26 2006 +0000
@@ -22,7 +22,7 @@
 
 #include <iostream>
 
-// #define DEBUG_VIEW_MANAGER 1
+//#define DEBUG_VIEW_MANAGER 1
 
 ViewManager::ViewManager() :
     m_playSource(0),
@@ -69,6 +69,15 @@
     return m_globalCentreFrame;
 }
 
+void
+ViewManager::setGlobalCentreFrame(unsigned long f)
+{
+#ifdef DEBUG_VIEW_MANAGER
+    std::cout << "ViewManager::setGlobalCentreFrame to " << f << std::endl;
+#endif
+    m_globalCentreFrame = f;
+}
+
 unsigned long
 ViewManager::getGlobalZoom() const
 {
--- a/view/ViewManager.h	Tue Nov 14 16:06:00 2006 +0000
+++ b/view/ViewManager.h	Wed Nov 15 18:22:26 2006 +0000
@@ -50,6 +50,7 @@
     bool isPlaying() const;
 
     unsigned long getGlobalCentreFrame() const;
+    void setGlobalCentreFrame(unsigned long);
     unsigned long getGlobalZoom() const;
 
     unsigned long getPlaybackFrame() const;