changeset 47:2e2ad8510e52

* Fix a crash in PortAudio output for mono data * Don't construct a chromagram in TonalChangeDetect plugin ctor * Update layer show/hide/dormancy for multi-view-capable layers -- the dormancy concept doesn't really work with these constraints any more
author Chris Cannam
date Fri, 03 Mar 2006 17:52:21 +0000 (2006-03-03)
parents 2152e19d7db9
children 97b0643bd799
files layer/SpectrogramLayer.cpp layer/SpectrogramLayer.h widgets/PropertyBox.cpp widgets/PropertyBox.h widgets/PropertyStack.cpp widgets/PropertyStack.h
diffstat 6 files changed, 39 insertions(+), 14 deletions(-) [+]
line wrap: on
line diff
--- a/layer/SpectrogramLayer.cpp	Fri Mar 03 17:23:27 2006 +0000
+++ b/layer/SpectrogramLayer.cpp	Fri Mar 03 17:52:21 2006 +0000
@@ -798,14 +798,15 @@
 }
 
 void
-SpectrogramLayer::setLayerDormant(const bool dormant)
+SpectrogramLayer::setLayerDormant(const View *v, bool dormant)
 {
-    if (dormant == m_dormant) return;
+    QMutexLocker locker(&m_mutex);
+
+    if (dormant == m_dormancy[v]) return;
 
     if (dormant) {
 
-	m_mutex.lock();
-	m_dormant = true;
+	m_dormancy[v] = true;
 
 //	delete m_cache;
 //	m_cache = 0;
@@ -815,12 +816,9 @@
 	delete m_pixmapCache;
 	m_pixmapCache = 0;
 	
-	m_mutex.unlock();
-
     } else {
 
-	m_dormant = false;
-	fillCache();
+	m_dormancy[v] = false;
     }
 }
 
@@ -1272,8 +1270,13 @@
 
 //	std::cerr << "SpectrogramLayer::CacheFillThread::run in loop" << std::endl;
 
-	if (m_layer.m_dormant) {
-
+/*!!! Need a way of finding out whether this layer is dormant in 
+      all the views that are currently visible... or not
+
+	if (m_layer.m_dormancy[) {
+*/
+	if (0) { //!!!
+	
 	    if (m_layer.m_cacheInvalid) {
 		delete m_layer.m_cache;
 		m_layer.m_cache = 0;
@@ -1695,7 +1698,7 @@
 	return;
     }
 
-    if (m_dormant) {
+    if (isLayerDormant(v)) {
 	std::cerr << "SpectrogramLayer::paint(): Layer is dormant" << std::endl;
 	return;
     }
--- a/layer/SpectrogramLayer.h	Fri Mar 03 17:23:27 2006 +0000
+++ b/layer/SpectrogramLayer.h	Fri Mar 03 17:52:21 2006 +0000
@@ -179,7 +179,7 @@
 
     void setProperties(const QXmlAttributes &attributes);
 
-    virtual void setLayerDormant(const bool dormant);
+    virtual void setLayerDormant(const View *v, bool dormant);
 
 protected slots:
     void cacheInvalid();
--- a/widgets/PropertyBox.cpp	Fri Mar 03 17:23:27 2006 +0000
+++ b/widgets/PropertyBox.cpp	Fri Mar 03 17:52:21 2006 +0000
@@ -123,8 +123,8 @@
 
 	LEDButton *showButton = new LEDButton(Qt::blue);
 	layout->addWidget(showButton);
-//!!!	connect(showButton, SIGNAL(stateChanged(bool)),
-//		layer, SLOT(showLayer(bool)));
+	connect(showButton, SIGNAL(stateChanged(bool)),
+		this, SIGNAL(showLayer(bool)));
 	layout->setAlignment(showButton, Qt::AlignVCenter);
     }
     
--- a/widgets/PropertyBox.h	Fri Mar 03 17:23:27 2006 +0000
+++ b/widgets/PropertyBox.h	Fri Mar 03 17:52:21 2006 +0000
@@ -35,6 +35,7 @@
     void changePlayGainDial(int);
     void changePlayPan(float);
     void changePlayPanDial(int);
+    void showLayer(bool);
 
 public slots:
     void propertyContainerPropertyChanged(PropertyContainer *);
--- a/widgets/PropertyStack.cpp	Fri Mar 03 17:23:27 2006 +0000
+++ b/widgets/PropertyStack.cpp	Fri Mar 03 17:52:21 2006 +0000
@@ -11,6 +11,7 @@
 #include "PropertyBox.h"
 #include "base/PropertyContainer.h"
 #include "base/View.h"
+#include "base/Layer.h"
 
 #include <QIcon>
 #include <QTabWidget>
@@ -70,6 +71,8 @@
 
 	PropertyBox *box = new PropertyBox(container);
 
+	connect(box, SIGNAL(showLayer(bool)), this, SLOT(showLayer(bool)));
+
 	QIcon icon(QString(":/icons/%1.png").arg(iconName));
 	if (icon.isNull()) {
 	    addTab(box, name);
@@ -138,6 +141,22 @@
 }
 
 void
+PropertyStack::showLayer(bool show)
+{
+    QObject *obj = sender();
+    
+    for (unsigned int i = 0; i < m_boxes.size(); ++i) {
+	if (obj == m_boxes[i]) {
+	    Layer *layer = dynamic_cast<Layer *>(m_boxes[i]->getContainer());
+	    if (layer) {
+		layer->showLayer(m_client, show);
+		return;
+	    }
+	}
+    }
+}
+
+void
 PropertyStack::selectedContainerChanged(int n)
 {
     if (n >= int(m_boxes.size())) return;
--- a/widgets/PropertyStack.h	Fri Mar 03 17:23:27 2006 +0000
+++ b/widgets/PropertyStack.h	Fri Mar 03 17:52:21 2006 +0000
@@ -38,6 +38,8 @@
     void propertyContainerPropertyChanged(PropertyContainer *);
     void propertyContainerNameChanged(PropertyContainer *);
 
+    void showLayer(bool);
+
 protected slots:
     void selectedContainerChanged(int);