Mercurial > hg > sonic-visualiser
changeset 148:0c22273a1d8c
* Enable threaded decoding for Ogg and MP3 files.
Needs some work on reducing updates to the overview widget
author | Chris Cannam |
---|---|
date | Wed, 06 Jun 2007 16:24:55 +0000 (2007-06-06) |
parents | 140ea2569bcc |
children | 37cb005f7c40 |
files | audioio/AudioCallbackPlaySource.cpp audioio/AudioCallbackPlaySource.h transform/FeatureExtractionPluginTransform.cpp |
diffstat | 3 files changed, 21 insertions(+), 1 deletions(-) [+] |
line wrap: on
line diff
--- a/audioio/AudioCallbackPlaySource.cpp Wed Jun 06 14:42:41 2007 +0000 +++ b/audioio/AudioCallbackPlaySource.cpp Wed Jun 06 16:24:55 2007 +0000 @@ -214,10 +214,20 @@ emit modelReplaced(); } + connect(model, SIGNAL(modelChanged(size_t, size_t)), + this, SLOT(modelChanged(size_t, size_t))); + m_condition.wakeAll(); } void +AudioCallbackPlaySource::modelChanged(size_t startFrame, size_t endFrame) +{ + std::cerr << "AudioCallbackPlaySource::modelChanged(" << startFrame << "," << endFrame << ")" << std::endl; + if (endFrame > m_lastModelEndFrame) m_lastModelEndFrame = endFrame; +} + +void AudioCallbackPlaySource::removeModel(Model *model) { m_mutex.lock(); @@ -226,6 +236,9 @@ std::cout << "AudioCallbackPlaySource::removeModel(" << model << ")" << std::endl; #endif + disconnect(model, SIGNAL(modelChanged(size_t, size_t)), + this, SLOT(modelChanged(size_t, size_t))); + m_models.erase(model); if (m_models.empty()) {
--- a/audioio/AudioCallbackPlaySource.h Wed Jun 06 14:42:41 2007 +0000 +++ b/audioio/AudioCallbackPlaySource.h Wed Jun 06 16:24:55 2007 +0000 @@ -233,6 +233,7 @@ void playSelectionModeChanged(); void playParametersChanged(PlayParameters *); void preferenceChanged(PropertyContainer::PropertyName); + void modelChanged(size_t startFrame, size_t endFrame); protected: ViewManager *m_viewManager;
--- a/transform/FeatureExtractionPluginTransform.cpp Wed Jun 06 14:42:41 2007 +0000 +++ b/transform/FeatureExtractionPluginTransform.cpp Wed Jun 06 16:24:55 2007 +0000 @@ -242,7 +242,13 @@ if (!input) return; while (!input->isReady()) { - if (dynamic_cast<WaveFileModel *>(input)) break; // no need to wait +/* + if (dynamic_cast<WaveFileModel *>(input)) { + std::cerr << "FeatureExtractionPluginTransform::run: Model is not ready, but it's not a WaveFileModel (it's a " << typeid(input).name() << "), so that's OK" << std::endl; + sleep(2); + break; // no need to wait + } +*/ std::cerr << "FeatureExtractionPluginTransform::run: Waiting for input model to be ready..." << std::endl; sleep(1); }