1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
|
/* -*- 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 and QMUL.
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 SV_WAVE_FILE_MODEL_H
#define SV_WAVE_FILE_MODEL_H
#include "RangeSummarisableTimeValueModel.h"
#include <stdlib.h>
namespace sv {
class WaveFileModel : public RangeSummarisableTimeValueModel
{
Q_OBJECT
public:
virtual ~WaveFileModel();
QString getValueUnit() const override {
return "V";
}
virtual sv_frame_t getFrameCount() const = 0;
virtual void setStartFrame(sv_frame_t startFrame) = 0;
int getChannelCount() const override = 0;
sv_samplerate_t getSampleRate() const override = 0;
sv_samplerate_t getNativeRate() const override = 0;
QString getTitle() const override = 0;
QString getMaker() const override = 0;
QString getLocation() const override = 0;
sv_frame_t getStartFrame() const override = 0;
sv_frame_t getTrueEndFrame() const override = 0;
protected:
WaveFileModel() { } // only accessible from subclasses
};
} // end namespace sv
#endif
|