Mercurial > hg > svcore
view base/PlayParameterRepository.cpp @ 115:90ade4fa63be
* Fix serious failure to reload "imported" (i.e. all non-derived non-main)
models from .sv file
* Give a short playback duration to notes with formal duration of 0 or 1
* Show crosshairs on spectrogram even when there is another layer on top
(if it isn't opaque)
* Always paste to the same time in the layer as the cut/copy was from, rather
than to the playback pointer -- less flexible, but more predictable and
less annoying. We probably need a way to get the old behaviour if pasting
from somewhere else in the future (e.g. from a text file), but we can't do
that yet anyway
* Use a compound operation for dragging and resizing selections, so as to
ensure a single undo operation works
* Use a note model as the target for feature extraction plugins that output
variable samplerate data with more than one value per feature
* Avoid possible crashes in cut/paste if a layer proves to have no model
author | Chris Cannam |
---|---|
date | Thu, 11 May 2006 11:35:46 +0000 |
parents | b2067aff8cd6 |
children | c30728d5625c |
line wrap: on
line source
/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */ /* Sonic Visualiser An audio file viewer and annotation editor. Centre for Digital Music, Queen Mary, University of London. This file copyright 2006 Chris Cannam. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. See the file COPYING included with this distribution for more information. */ #include "PlayParameterRepository.h" #include "PlayParameters.h" //!!! shouldn't be including this here -- restructure needed //!!! should the AudioGenerator actually implement all this stuff itself? do we even want this class? #include "audioio/AudioGenerator.h" #include <iostream> PlayParameterRepository * PlayParameterRepository::m_instance = new PlayParameterRepository; PlayParameterRepository * PlayParameterRepository::instance() { return m_instance; } PlayParameterRepository::~PlayParameterRepository() { } void PlayParameterRepository::addModel(const Model *model) { std::cerr << "PlayParameterRepository:addModel " << model << std::endl; if (!getPlayParameters(model)) { // Give all models the same type of play parameters for the // moment, provided they can be played at all if (AudioGenerator::canPlay(model)) { std::cerr << "PlayParameterRepository: Adding play parameters for " << model << std::endl; PlayParameters *params = new PlayParameters; m_playParameters[model] = params; params->setPlayPluginId (AudioGenerator::getDefaultPlayPluginId(model)); params->setPlayPluginConfiguration (AudioGenerator::getDefaultPlayPluginConfiguration(model)); connect(params, SIGNAL(playParametersChanged()), this, SLOT(playParametersChanged())); connect(params, SIGNAL(playPluginIdChanged(QString)), this, SLOT(playPluginIdChanged(QString))); connect(params, SIGNAL(playPluginConfigurationChanged(QString)), this, SLOT(playPluginConfigurationChanged(QString))); std::cerr << "Connected play parameters " << params << " for model " << model << " to this " << this << std::endl; } else { std::cerr << "PlayParameterRepository: Model " << model << " not playable" << std::endl; } } } void PlayParameterRepository::removeModel(const Model *model) { delete m_playParameters[model]; m_playParameters.erase(model); } PlayParameters * PlayParameterRepository::getPlayParameters(const Model *model) const { if (m_playParameters.find(model) == m_playParameters.end()) return 0; return m_playParameters.find(model)->second; } void PlayParameterRepository::playParametersChanged() { PlayParameters *params = dynamic_cast<PlayParameters *>(sender()); emit playParametersChanged(params); } void PlayParameterRepository::playPluginIdChanged(QString id) { PlayParameters *params = dynamic_cast<PlayParameters *>(sender()); for (ModelParameterMap::iterator i = m_playParameters.begin(); i != m_playParameters.end(); ++i) { if (i->second == params) { emit playPluginIdChanged(i->first, id); return; } } } void PlayParameterRepository::playPluginConfigurationChanged(QString config) { PlayParameters *params = dynamic_cast<PlayParameters *>(sender()); std::cerr << "PlayParameterRepository::playPluginConfigurationChanged" << std::endl; for (ModelParameterMap::iterator i = m_playParameters.begin(); i != m_playParameters.end(); ++i) { if (i->second == params) { emit playPluginConfigurationChanged(i->first, config); return; } } } void PlayParameterRepository::clear() { std::cerr << "PlayParameterRepository: PlayParameterRepository::clear" << std::endl; while (!m_playParameters.empty()) { delete m_playParameters.begin()->second; m_playParameters.erase(m_playParameters.begin()); } }