annotate data/model/WaveFileModel.h @ 282:d9319859a4cf tip

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