annotate data/model/WaveFileModel.h @ 297:c022976d18e8

* Merge from sv-match-alignment branch (excluding alignment-specific document). - add aggregate wave model (not yet complete enough to be added as a true model in a layer, but there's potential) - add play solo mode - add alignment model -- unused in plain SV - fix two plugin leaks - add m3u playlist support (opens all files at once, potentially hazardous) - fix retrieval of pre-encoded URLs - add ability to resample audio files on import, so as to match rates with other files previously loaded; add preference for same - add preliminary support in transform code for range and rate of transform input - reorganise preferences dialog, move dark-background option to preferences, add option for temporary directory location
author Chris Cannam
date Fri, 28 Sep 2007 13:56:38 +0000
parents 7b96b3bd4bae
children 5877d68815c7
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@202 7 This file copyright 2006 Chris Cannam and QMUL.
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@179 30 class WaveFileModel : public RangeSummarisableTimeValueModel
Chris@147 31 {
Chris@147 32 Q_OBJECT
Chris@147 33
Chris@147 34 public:
Chris@297 35 WaveFileModel(QString path, size_t targetRate = 0);
Chris@297 36 WaveFileModel(QString path, QString originalLocation, size_t targetRate = 0);
Chris@211 37 WaveFileModel(QString originalLocation, AudioFileReader *reader);
Chris@147 38 ~WaveFileModel();
Chris@147 39
Chris@147 40 bool isOK() const;
Chris@147 41 bool isReady(int *) const;
Chris@147 42
Chris@179 43 const ZoomConstraint *getZoomConstraint() const { return &m_zoomConstraint; }
Chris@179 44
Chris@147 45 size_t getFrameCount() const;
Chris@147 46 size_t getChannelCount() const;
Chris@147 47 size_t getSampleRate() const;
Chris@297 48 size_t getNativeRate() const;
Chris@147 49
Chris@147 50 virtual Model *clone() const;
Chris@147 51
Chris@147 52 float getValueMinimum() const { return -1.0f; }
Chris@147 53 float getValueMaximum() const { return 1.0f; }
Chris@147 54
Chris@147 55 virtual size_t getStartFrame() const { return 0; }
Chris@147 56 virtual size_t getEndFrame() const { return getFrameCount(); }
Chris@147 57
Chris@147 58 virtual size_t getValues(int channel, size_t start, size_t end,
Chris@147 59 float *buffer) const;
Chris@147 60
Chris@147 61 virtual size_t getValues(int channel, size_t start, size_t end,
Chris@147 62 double *buffer) const;
Chris@147 63
Chris@225 64 virtual void getRanges(size_t channel, size_t start, size_t end,
Chris@225 65 RangeBlock &ranges,
Chris@225 66 size_t &blockSize) const;
Chris@147 67
Chris@147 68 virtual Range getRange(size_t channel, size_t start, size_t end) const;
Chris@147 69
Chris@163 70 virtual void toXml(QTextStream &out,
Chris@163 71 QString indent = "",
Chris@163 72 QString extraAttributes = "") const;
Chris@163 73
Chris@239 74 signals:
Chris@239 75 void modelChanged();
Chris@258 76 void modelChanged(size_t, size_t);
Chris@239 77 void completionChanged();
Chris@239 78
Chris@147 79 protected slots:
Chris@147 80 void fillTimerTimedOut();
Chris@147 81 void cacheFilled();
Chris@147 82
Chris@147 83 protected:
Chris@147 84 void initialize();
Chris@147 85
Chris@147 86 class RangeCacheFillThread : public Thread
Chris@147 87 {
Chris@147 88 public:
Chris@147 89 RangeCacheFillThread(WaveFileModel &model) :
Chris@175 90 m_model(model), m_fillExtent(0),
Chris@175 91 m_frameCount(model.getFrameCount()) { }
Chris@147 92
Chris@147 93 size_t getFillExtent() const { return m_fillExtent; }
Chris@147 94 virtual void run();
Chris@147 95
Chris@147 96 protected:
Chris@147 97 WaveFileModel &m_model;
Chris@147 98 size_t m_fillExtent;
Chris@175 99 size_t m_frameCount;
Chris@147 100 };
Chris@147 101
Chris@147 102 void fillCache();
Chris@147 103
Chris@147 104 QString m_path;
Chris@147 105 AudioFileReader *m_reader;
Chris@175 106 bool m_myReader;
Chris@147 107
Chris@147 108 RangeBlock m_cache[2]; // interleaved at two base resolutions
Chris@147 109 mutable QMutex m_mutex;
Chris@147 110 RangeCacheFillThread *m_fillThread;
Chris@147 111 QTimer *m_updateTimer;
Chris@147 112 size_t m_lastFillExtent;
Chris@147 113 bool m_exiting;
Chris@179 114 static PowerOfSqrtTwoZoomConstraint m_zoomConstraint;
Chris@147 115 };
Chris@147 116
Chris@147 117 #endif