annotate data/model/WaveFileModel.h @ 169:603991c63ff6

...
author Chris Cannam
date Mon, 25 Sep 2006 20:32:44 +0000
parents 4148ad087959
children b0f4555b625e
rev   line source
Chris@147 1 /* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */
Chris@147 2
Chris@147 3 /*
Chris@147 4 Sonic Visualiser
Chris@147 5 An audio file viewer and annotation editor.
Chris@147 6 Centre for Digital Music, Queen Mary, University of London.
Chris@147 7 This file copyright 2006 Chris Cannam.
Chris@147 8
Chris@147 9 This program is free software; you can redistribute it and/or
Chris@147 10 modify it under the terms of the GNU General Public License as
Chris@147 11 published by the Free Software Foundation; either version 2 of the
Chris@147 12 License, or (at your option) any later version. See the file
Chris@147 13 COPYING included with this distribution for more information.
Chris@147 14 */
Chris@147 15
Chris@147 16 #ifndef _WAVE_FILE_MODEL_H_
Chris@147 17 #define _WAVE_FILE_MODEL_H_
Chris@147 18
Chris@150 19 #include "base/Thread.h"
Chris@147 20 #include <QMutex>
Chris@147 21 #include <QTimer>
Chris@147 22
Chris@147 23 #include "RangeSummarisableTimeValueModel.h"
Chris@147 24 #include "PowerOfSqrtTwoZoomConstraint.h"
Chris@147 25
Chris@147 26 #include <stdlib.h>
Chris@147 27
Chris@147 28 class AudioFileReader;
Chris@147 29
Chris@147 30 class WaveFileModel : public RangeSummarisableTimeValueModel,
Chris@147 31 virtual public PowerOfSqrtTwoZoomConstraint
Chris@147 32 {
Chris@147 33 Q_OBJECT
Chris@147 34
Chris@147 35 public:
Chris@147 36 WaveFileModel(QString path);
Chris@147 37 ~WaveFileModel();
Chris@147 38
Chris@147 39 bool isOK() const;
Chris@147 40 bool isReady(int *) const;
Chris@147 41
Chris@147 42 size_t getFrameCount() const;
Chris@147 43 size_t getChannelCount() const;
Chris@147 44 size_t getSampleRate() const;
Chris@147 45
Chris@147 46 virtual Model *clone() const;
Chris@147 47
Chris@147 48 float getValueMinimum() const { return -1.0f; }
Chris@147 49 float getValueMaximum() const { return 1.0f; }
Chris@147 50
Chris@147 51 virtual size_t getStartFrame() const { return 0; }
Chris@147 52 virtual size_t getEndFrame() const { return getFrameCount(); }
Chris@147 53
Chris@147 54 virtual size_t getValues(int channel, size_t start, size_t end,
Chris@147 55 float *buffer) const;
Chris@147 56
Chris@147 57 virtual size_t getValues(int channel, size_t start, size_t end,
Chris@147 58 double *buffer) const;
Chris@147 59
Chris@147 60 virtual RangeBlock getRanges(size_t channel, size_t start, size_t end,
Chris@147 61 size_t &blockSize) const;
Chris@147 62
Chris@147 63 virtual Range getRange(size_t channel, size_t start, size_t end) const;
Chris@147 64
Chris@163 65 virtual void toXml(QTextStream &out,
Chris@163 66 QString indent = "",
Chris@163 67 QString extraAttributes = "") const;
Chris@163 68
Chris@147 69 virtual QString toXmlString(QString indent = "",
Chris@147 70 QString extraAttributes = "") const;
Chris@147 71
Chris@147 72 protected slots:
Chris@147 73 void fillTimerTimedOut();
Chris@147 74 void cacheFilled();
Chris@147 75
Chris@147 76 protected:
Chris@147 77 void initialize();
Chris@147 78
Chris@147 79 class RangeCacheFillThread : public Thread
Chris@147 80 {
Chris@147 81 public:
Chris@147 82 RangeCacheFillThread(WaveFileModel &model) :
Chris@147 83 m_model(model), m_fillExtent(0) { }
Chris@147 84
Chris@147 85 size_t getFillExtent() const { return m_fillExtent; }
Chris@147 86 virtual void run();
Chris@147 87
Chris@147 88 protected:
Chris@147 89 WaveFileModel &m_model;
Chris@147 90 size_t m_fillExtent;
Chris@147 91 };
Chris@147 92
Chris@147 93 void fillCache();
Chris@147 94
Chris@147 95 QString m_path;
Chris@147 96 AudioFileReader *m_reader;
Chris@147 97
Chris@147 98 RangeBlock m_cache[2]; // interleaved at two base resolutions
Chris@147 99 mutable QMutex m_mutex;
Chris@147 100 RangeCacheFillThread *m_fillThread;
Chris@147 101 QTimer *m_updateTimer;
Chris@147 102 size_t m_lastFillExtent;
Chris@147 103 bool m_exiting;
Chris@147 104 };
Chris@147 105
Chris@147 106 #endif