Mercurial > hg > svcore
view data/model/NoteData.h @ 1308:80c77916fe85 mp3-gapless
Update m4a files to exports from CoreAudio, rather than FAAC; update tests accordingly, and add test for spurious data after end of decode
author | Chris Cannam <cannam@all-day-breakfast.com> |
---|---|
date | Tue, 29 Nov 2016 14:25:57 +0000 |
parents | cc27f35aa75c |
children | 48e9f538e6e9 |
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 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 NOTE_DATA_H #define NOTE_DATA_H #include <vector> #include "base/Pitch.h" struct NoteData { NoteData(sv_frame_t _start, sv_frame_t _dur, int _mp, int _vel) : start(_start), duration(_dur), midiPitch(_mp), frequency(0), isMidiPitchQuantized(true), velocity(_vel), channel(0) { }; sv_frame_t start; // audio sample frame sv_frame_t duration; // in audio sample frames int midiPitch; // 0-127 float frequency; // Hz, to be used if isMidiPitchQuantized false bool isMidiPitchQuantized; int velocity; // MIDI-style 0-127 int channel; // MIDI 0-15 float getFrequency() const { if (isMidiPitchQuantized) { return float(Pitch::getFrequencyForPitch(midiPitch)); } else { return frequency; } } }; typedef std::vector<NoteData> NoteList; class NoteExportable { public: virtual NoteList getNotes() const = 0; virtual NoteList getNotesWithin(sv_frame_t startFrame, sv_frame_t endFrame) const = 0; }; #endif