annotate data/model/WritableWaveFileModel.h @ 1517:925d205c39b4 import-audio-data

Handle sample range specification for CSV import
author Chris Cannam
date Sat, 08 Sep 2018 20:43:14 +0100
parents 3dcd83595bc8
children 954d0cf29ca7
rev   line source
Chris@175 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
Chris@175 2
Chris@175 3 /*
Chris@175 4 Sonic Visualiser
Chris@175 5 An audio file viewer and annotation editor.
Chris@175 6 Centre for Digital Music, Queen Mary, University of London.
Chris@202 7 This file copyright 2006 QMUL.
Chris@175 8
Chris@175 9 This program is free software; you can redistribute it and/or
Chris@175 10 modify it under the terms of the GNU General Public License as
Chris@175 11 published by the Free Software Foundation; either version 2 of the
Chris@175 12 License, or (at your option) any later version. See the file
Chris@175 13 COPYING included with this distribution for more information.
Chris@175 14 */
Chris@175 15
Chris@1122 16 #ifndef WRITABLE_WAVE_FILE_MODEL_H
Chris@1122 17 #define WRITABLE_WAVE_FILE_MODEL_H
Chris@175 18
Chris@175 19 #include "WaveFileModel.h"
Chris@1122 20 #include "ReadOnlyWaveFileModel.h"
Chris@1122 21 #include "PowerOfSqrtTwoZoomConstraint.h"
Chris@175 22
Chris@175 23 class WavFileWriter;
Chris@175 24 class WavFileReader;
Chris@175 25
Chris@1122 26 class WritableWaveFileModel : public WaveFileModel
Chris@175 27 {
Chris@175 28 Q_OBJECT
Chris@175 29
Chris@175 30 public:
Chris@1517 31 WritableWaveFileModel(sv_samplerate_t sampleRate,
Chris@1517 32 int channels,
Chris@1517 33 QString path = "",
Chris@1517 34 bool normaliseOnRead = false);
Chris@175 35 ~WritableWaveFileModel();
Chris@175 36
Chris@188 37 /**
Chris@188 38 * Call addSamples to append a block of samples to the end of the
Chris@1337 39 * file.
Chris@1337 40 *
Chris@1337 41 * This function only appends the samples to the file being
Chris@1337 42 * written; it does not update the model's view of the samples in
Chris@1337 43 * that file. That is, it updates the file on disc but the model
Chris@1337 44 * itself does not change its content. This is because re-reading
Chris@1337 45 * the file to update the model may be more expensive than adding
Chris@1337 46 * the samples in the first place. If you are writing small
Chris@1337 47 * numbers of samples repeatedly, you probably only want the model
Chris@1337 48 * to update periodically rather than after every write.
Chris@1337 49 *
Chris@1337 50 * Call updateModel() periodically to tell the model to update its
Chris@1337 51 * own view of the samples in the file being written.
Chris@1337 52 *
Chris@1337 53 * Call setWriteProportion() periodically if the file being
Chris@1337 54 * written has known duration and you want the model to be able to
Chris@1337 55 * report the write progress as a percentage.
Chris@1337 56 *
Chris@1337 57 * Call writeComplete() when the file has been completely written.
Chris@188 58 */
Chris@1325 59 virtual bool addSamples(const float *const *samples, sv_frame_t count);
Chris@1133 60
Chris@1133 61 /**
Chris@1337 62 * Tell the model to update its own (read) view of the (written)
Chris@1337 63 * file. May cause modelChanged() and modelChangedWithin() to be
Chris@1337 64 * emitted. See the comment to addSamples above for rationale.
Chris@1337 65 */
Chris@1337 66 void updateModel();
Chris@1337 67
Chris@1337 68 /**
Chris@1133 69 * Set the proportion of the file which has been written so far,
Chris@1133 70 * as a percentage. This may be used to indicate progress.
Chris@1133 71 *
Chris@1133 72 * Note that this differs from the "completion" percentage
Chris@1133 73 * reported through isReady()/getCompletion(). That percentage is
Chris@1133 74 * updated when "internal processing has advanced... but the model
Chris@1133 75 * has not changed externally", i.e. it reports progress in
Chris@1133 76 * calculating the initial state of a model. In contrast, an
Chris@1133 77 * update to setWriteProportion corresponds to a change in the
Chris@1133 78 * externally visible state of the model (i.e. it contains more
Chris@1133 79 * data than before).
Chris@1133 80 */
Chris@1133 81 void setWriteProportion(int proportion);
Chris@1133 82
Chris@1133 83 /**
Chris@1133 84 * Indicate that writing is complete. You should call this even if
Chris@1337 85 * you have never called setWriteProportion() or updateModel().
Chris@1133 86 */
Chris@1133 87 void writeComplete();
Chris@1133 88
Chris@1133 89 static const int PROPORTION_UNKNOWN;
Chris@1133 90
Chris@1133 91 /**
Chris@1133 92 * Get the proportion of the file which has been written so far,
Chris@1133 93 * as a percentage. Return PROPORTION_UNKNOWN if unknown.
Chris@1133 94 */
Chris@1133 95 int getWriteProportion() const;
Chris@175 96
Chris@175 97 bool isOK() const;
Chris@175 98 bool isReady(int *) const;
Chris@1133 99
Chris@1133 100 /**
Chris@1133 101 * Return the generation completion percentage of this model. This
Chris@1133 102 * is always 100, because the model is always in a complete state
Chris@1133 103 * -- it just contains varying amounts of data depending on how
Chris@1133 104 * much has been written.
Chris@1133 105 */
Chris@1133 106 virtual int getCompletion() const { return 100; }
Chris@188 107
Chris@179 108 const ZoomConstraint *getZoomConstraint() const {
Chris@179 109 static PowerOfSqrtTwoZoomConstraint zc;
Chris@179 110 return &zc;
Chris@179 111 }
Chris@179 112
Chris@1038 113 sv_frame_t getFrameCount() const;
Chris@929 114 int getChannelCount() const { return m_channels; }
Chris@1040 115 sv_samplerate_t getSampleRate() const { return m_sampleRate; }
Chris@1122 116 sv_samplerate_t getNativeRate() const { return m_sampleRate; }
Chris@1122 117
Chris@1122 118 QString getTitle() const {
Chris@1122 119 if (m_model) return m_model->getTitle();
Chris@1122 120 else return "";
Chris@1122 121 }
Chris@1122 122 QString getMaker() const {
Chris@1122 123 if (m_model) return m_model->getMaker();
Chris@1122 124 else return "";
Chris@1122 125 }
Chris@1122 126 QString getLocation() const {
Chris@1122 127 if (m_model) return m_model->getLocation();
Chris@1122 128 else return "";
Chris@1122 129 }
Chris@175 130
Chris@175 131 float getValueMinimum() const { return -1.0f; }
Chris@175 132 float getValueMaximum() const { return 1.0f; }
Chris@175 133
Chris@1038 134 virtual sv_frame_t getStartFrame() const { return m_startFrame; }
Chris@1038 135 virtual sv_frame_t getEndFrame() const { return m_startFrame + getFrameCount(); }
Chris@175 136
Chris@1038 137 void setStartFrame(sv_frame_t startFrame);
Chris@175 138
Chris@1326 139 virtual floatvec_t getData(int channel, sv_frame_t start, sv_frame_t count) const;
Chris@175 140
Chris@1326 141 virtual std::vector<floatvec_t> getMultiChannelData(int fromchannel, int tochannel, sv_frame_t start, sv_frame_t count) const;
Chris@363 142
Chris@929 143 virtual int getSummaryBlockSize(int desired) const;
Chris@377 144
Chris@1038 145 virtual void getSummaries(int channel, sv_frame_t start, sv_frame_t count,
Chris@929 146 RangeBlock &ranges, int &blockSize) const;
Chris@300 147
Chris@1038 148 virtual Range getSummary(int channel, sv_frame_t start, sv_frame_t count) const;
Chris@175 149
Chris@345 150 QString getTypeName() const { return tr("Writable Wave File"); }
Chris@345 151
Chris@175 152 virtual void toXml(QTextStream &out,
Chris@175 153 QString indent = "",
Chris@175 154 QString extraAttributes = "") const;
Chris@175 155
Chris@175 156 protected:
Chris@1122 157 ReadOnlyWaveFileModel *m_model;
Chris@175 158 WavFileWriter *m_writer;
Chris@175 159 WavFileReader *m_reader;
Chris@1040 160 sv_samplerate_t m_sampleRate;
Chris@929 161 int m_channels;
Chris@1038 162 sv_frame_t m_frameCount;
Chris@1038 163 sv_frame_t m_startFrame;
Chris@1133 164 int m_proportion;
Chris@175 165 };
Chris@175 166
Chris@175 167 #endif
Chris@175 168