Mercurial > hg > svcore
view data/model/WritableWaveFileModel.h @ 183:146eb9e35baa
* Improve output from Profiler class and make it incur less (no) overhead in
release builds with NO_TIMING defined
* Fix a lock contention issue in spectrogram
* Marginal optimisations elsewhere
author | Chris Cannam |
---|---|
date | Tue, 10 Oct 2006 14:51:17 +0000 |
parents | 0ed2b2e26b44 |
children | f86b74d1b143 |
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. */ #ifndef _WRITABLE_WAVE_FILE_MODEL_H_ #define _WRITABLE_WAVE_FILE_MODEL_H_ #include "WaveFileModel.h" class WavFileWriter; class WavFileReader; class WritableWaveFileModel : public RangeSummarisableTimeValueModel { Q_OBJECT public: WritableWaveFileModel(size_t sampleRate, size_t channels, QString path = ""); ~WritableWaveFileModel(); virtual bool addSamples(float **samples, size_t count); virtual void sync(); bool isOK() const; bool isReady(int *) const; const ZoomConstraint *getZoomConstraint() const { static PowerOfSqrtTwoZoomConstraint zc; return &zc; } size_t getFrameCount() const; size_t getChannelCount() const { return m_channels; } size_t getSampleRate() const { return m_sampleRate; } virtual Model *clone() const; float getValueMinimum() const { return -1.0f; } float getValueMaximum() const { return 1.0f; } virtual size_t getStartFrame() const { return 0; } virtual size_t getEndFrame() const { return getFrameCount(); } virtual size_t getValues(int channel, size_t start, size_t end, float *buffer) const; virtual size_t getValues(int channel, size_t start, size_t end, double *buffer) const; virtual RangeBlock getRanges(size_t channel, size_t start, size_t end, size_t &blockSize) const; virtual Range getRange(size_t channel, size_t start, size_t end) const; virtual void toXml(QTextStream &out, QString indent = "", QString extraAttributes = "") const; virtual QString toXmlString(QString indent = "", QString extraAttributes = "") const; protected: WaveFileModel *m_model; WavFileWriter *m_writer; WavFileReader *m_reader; size_t m_sampleRate; size_t m_channels; size_t m_frameCount; }; #endif