annotate audioio/AudioGenerator.h @ 196:29c356da4ae4

* Make XmlExportable::toXml the function that is universally overridden (and pure virtual) instead of toXmlString. Tidies up some classes, notably the model classes, significantly. Closes #1794561.
author Chris Cannam
date Thu, 18 Oct 2007 10:15:07 +0000
parents 98ba77e0d897
children
rev   line source
Chris@0 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
Chris@0 2
Chris@0 3 /*
Chris@0 4 Sonic Visualiser
Chris@0 5 An audio file viewer and annotation editor.
Chris@0 6 Centre for Digital Music, Queen Mary, University of London.
Chris@0 7 This file copyright 2006 Chris Cannam.
Chris@0 8
Chris@0 9 This program is free software; you can redistribute it and/or
Chris@0 10 modify it under the terms of the GNU General Public License as
Chris@0 11 published by the Free Software Foundation; either version 2 of the
Chris@0 12 License, or (at your option) any later version. See the file
Chris@0 13 COPYING included with this distribution for more information.
Chris@0 14 */
Chris@0 15
Chris@0 16 #ifndef _AUDIO_GENERATOR_H_
Chris@0 17 #define _AUDIO_GENERATOR_H_
Chris@0 18
Chris@0 19 class Model;
Chris@0 20 class NoteModel;
Chris@0 21 class DenseTimeValueModel;
Chris@0 22 class SparseOneDimensionalModel;
Chris@0 23 class RealTimePluginInstance;
Chris@0 24
Chris@0 25 #include <QObject>
Chris@0 26 #include <QMutex>
Chris@0 27
Chris@0 28 #include <set>
Chris@0 29 #include <map>
Chris@0 30
Chris@0 31 class AudioGenerator : public QObject
Chris@0 32 {
Chris@0 33 Q_OBJECT
Chris@0 34
Chris@0 35 public:
Chris@0 36 AudioGenerator();
Chris@0 37 virtual ~AudioGenerator();
Chris@0 38
Chris@0 39 /**
Chris@0 40 * Return true if the given model is of a type that we generally
Chris@0 41 * know how to play. This doesn't guarantee that a specific
Chris@0 42 * AudioGenerator will actually produce sounds for it (for
Chris@0 43 * example, it may turn out that a vital plugin is missing).
Chris@0 44 */
Chris@0 45 static bool canPlay(const Model *model);
Chris@0 46
Chris@0 47 static QString getDefaultPlayPluginId(const Model *model);
Chris@0 48 static QString getDefaultPlayPluginConfiguration(const Model *model);
Chris@0 49
Chris@0 50 /**
Chris@0 51 * Add a data model to be played from and initialise any necessary
Chris@0 52 * audio generation code. Returns true if the model will be
Chris@0 53 * played. (The return value test here is stricter than that for
Chris@0 54 * canPlay, above.) The model will be added regardless of the
Chris@0 55 * return value.
Chris@0 56 */
Chris@0 57 virtual bool addModel(Model *model);
Chris@0 58
Chris@0 59 /**
Chris@0 60 * Remove a model.
Chris@0 61 */
Chris@0 62 virtual void removeModel(Model *model);
Chris@0 63
Chris@0 64 /**
Chris@0 65 * Remove all models.
Chris@0 66 */
Chris@0 67 virtual void clearModels();
Chris@0 68
Chris@0 69 /**
Chris@0 70 * Reset playback, clearing plugins and the like.
Chris@0 71 */
Chris@0 72 virtual void reset();
Chris@0 73
Chris@0 74 /**
Chris@0 75 * Set the target channel count. The buffer parameter to mixModel
Chris@0 76 * must always point to at least this number of arrays.
Chris@0 77 */
Chris@0 78 virtual void setTargetChannelCount(size_t channelCount);
Chris@0 79
Chris@0 80 /**
Chris@0 81 * Return the internal processing block size. The frameCount
Chris@0 82 * argument to all mixModel calls must be a multiple of this
Chris@0 83 * value.
Chris@0 84 */
Chris@0 85 virtual size_t getBlockSize() const;
Chris@0 86
Chris@0 87 /**
Chris@0 88 * Mix a single model into an output buffer.
Chris@0 89 */
Chris@0 90 virtual size_t mixModel(Model *model, size_t startFrame, size_t frameCount,
Chris@0 91 float **buffer, size_t fadeIn = 0, size_t fadeOut = 0);
Chris@0 92
Chris@180 93 /**
Chris@180 94 * Specify that only the given set of models should be played.
Chris@180 95 */
Chris@180 96 virtual void setSoloModelSet(std::set<Model *>s);
Chris@180 97
Chris@180 98 /**
Chris@180 99 * Specify that all models should be played as normal (if not
Chris@180 100 * muted).
Chris@180 101 */
Chris@180 102 virtual void clearSoloModelSet();
Chris@180 103
Chris@0 104 protected slots:
Chris@0 105 void playPluginIdChanged(const Model *, QString);
Chris@0 106 void playPluginConfigurationChanged(const Model *, QString);
Chris@0 107
Chris@0 108 protected:
Chris@0 109 size_t m_sourceSampleRate;
Chris@0 110 size_t m_targetChannelCount;
Chris@0 111
Chris@180 112 bool m_soloing;
Chris@180 113 std::set<Model *> m_soloModelSet;
Chris@180 114
Chris@0 115 struct NoteOff {
Chris@0 116
Chris@0 117 int pitch;
Chris@0 118 size_t frame;
Chris@0 119
Chris@0 120 struct Comparator {
Chris@0 121 bool operator()(const NoteOff &n1, const NoteOff &n2) const {
Chris@0 122 return n1.frame < n2.frame;
Chris@0 123 }
Chris@0 124 };
Chris@0 125 };
Chris@0 126
Chris@0 127 typedef std::map<const Model *, RealTimePluginInstance *> PluginMap;
Chris@0 128
Chris@0 129 typedef std::set<NoteOff, NoteOff::Comparator> NoteOffSet;
Chris@0 130 typedef std::map<const Model *, NoteOffSet> NoteOffMap;
Chris@0 131
Chris@0 132 QMutex m_mutex;
Chris@0 133 PluginMap m_synthMap;
Chris@0 134 NoteOffMap m_noteOffs;
Chris@0 135 static QString m_sampleDir;
Chris@0 136
Chris@0 137 virtual RealTimePluginInstance *loadPluginFor(const Model *model);
Chris@0 138 virtual RealTimePluginInstance *loadPlugin(QString id, QString program);
Chris@0 139 static QString getSampleDir();
Chris@0 140 static void setSampleDir(RealTimePluginInstance *plugin);
Chris@0 141
Chris@0 142 virtual size_t mixDenseTimeValueModel
Chris@0 143 (DenseTimeValueModel *model, size_t startFrame, size_t frameCount,
Chris@0 144 float **buffer, float gain, float pan, size_t fadeIn, size_t fadeOut);
Chris@0 145
Chris@0 146 virtual size_t mixSparseOneDimensionalModel
Chris@0 147 (SparseOneDimensionalModel *model, size_t startFrame, size_t frameCount,
Chris@0 148 float **buffer, float gain, float pan, size_t fadeIn, size_t fadeOut);
Chris@0 149
Chris@0 150 virtual size_t mixNoteModel
Chris@0 151 (NoteModel *model, size_t startFrame, size_t frameCount,
Chris@0 152 float **buffer, float gain, float pan, size_t fadeIn, size_t fadeOut);
Chris@0 153
Chris@0 154 static const size_t m_pluginBlockSize;
Chris@0 155 };
Chris@0 156
Chris@0 157 #endif
Chris@0 158