annotate data/model/NoteModel.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.
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 _NOTE_MODEL_H_
lbajardsilogic@0 17 #define _NOTE_MODEL_H_
lbajardsilogic@0 18
lbajardsilogic@0 19 #include "SparseValueModel.h"
lbajardsilogic@0 20 #include "base/PlayParameterRepository.h"
lbajardsilogic@0 21 #include "base/RealTime.h"
lbajardsilogic@0 22
lbajardsilogic@0 23 /**
lbajardsilogic@0 24 * Note type for use in a SparseModel or SparseValueModel. All we
lbajardsilogic@0 25 * mean by a "note" is something that has an onset time, a single
lbajardsilogic@0 26 * value, and a duration. Like other points, it can also have a
lbajardsilogic@0 27 * label. With this point type, the model can be thought of as
lbajardsilogic@0 28 * representing a simple MIDI-type piano roll, except that the y
lbajardsilogic@0 29 * coordinates (values) do not have to be discrete integers.
lbajardsilogic@0 30 */
lbajardsilogic@0 31
lbajardsilogic@0 32 struct Note
lbajardsilogic@0 33 {
lbajardsilogic@0 34 public:
lbajardsilogic@0 35 Note(long _frame) : frame(_frame), value(0.0f), duration(0) { }
lbajardsilogic@0 36 Note(long _frame, float _value, size_t _duration, QString _label) :
lbajardsilogic@0 37 frame(_frame), value(_value), duration(_duration), label(_label) { }
lbajardsilogic@0 38
lbajardsilogic@0 39 int getDimensions() const { return 3; }
lbajardsilogic@0 40
lbajardsilogic@0 41 long frame;
lbajardsilogic@0 42 float value;
lbajardsilogic@0 43 size_t duration;
lbajardsilogic@0 44 QString label;
lbajardsilogic@0 45
lbajardsilogic@0 46 QString toXmlString(QString indent = "",
lbajardsilogic@0 47 QString extraAttributes = "") const
lbajardsilogic@0 48 {
lbajardsilogic@0 49 return QString("%1<point frame=\"%2\" value=\"%3\" duration=\"%4\" label=\"%5\" %6/>\n")
lbajardsilogic@0 50 .arg(indent).arg(frame).arg(value).arg(duration).arg(label).arg(extraAttributes);
lbajardsilogic@0 51 }
lbajardsilogic@0 52
lbajardsilogic@0 53 QString toDelimitedDataString(QString delimiter, size_t sampleRate) const
lbajardsilogic@0 54 {
lbajardsilogic@0 55 QStringList list;
lbajardsilogic@0 56 list << RealTime::frame2RealTime(frame, sampleRate).toString().c_str();
lbajardsilogic@0 57 list << QString("%1").arg(value);
lbajardsilogic@0 58 list << QString("%1").arg(duration);
lbajardsilogic@0 59 list << label;
lbajardsilogic@0 60 return list.join(delimiter);
lbajardsilogic@0 61 }
lbajardsilogic@0 62
lbajardsilogic@0 63 struct Comparator {
lbajardsilogic@0 64 bool operator()(const Note &p1,
lbajardsilogic@0 65 const Note &p2) const {
lbajardsilogic@0 66 if (p1.frame != p2.frame) return p1.frame < p2.frame;
lbajardsilogic@0 67 if (p1.value != p2.value) return p1.value < p2.value;
lbajardsilogic@0 68 if (p1.duration != p2.duration) return p1.duration < p2.duration;
lbajardsilogic@0 69 return p1.label < p2.label;
lbajardsilogic@0 70 }
lbajardsilogic@0 71 };
lbajardsilogic@0 72
lbajardsilogic@0 73 struct OrderComparator {
lbajardsilogic@0 74 bool operator()(const Note &p1,
lbajardsilogic@0 75 const Note &p2) const {
lbajardsilogic@0 76 return p1.frame < p2.frame;
lbajardsilogic@0 77 }
lbajardsilogic@0 78 };
lbajardsilogic@0 79 };
lbajardsilogic@0 80
lbajardsilogic@0 81
lbajardsilogic@0 82 class NoteModel : public SparseValueModel<Note>
lbajardsilogic@0 83 {
lbajardsilogic@0 84 public:
lbajardsilogic@0 85 NoteModel(size_t sampleRate, size_t resolution,
lbajardsilogic@0 86 bool notifyOnAdd = true) :
lbajardsilogic@0 87 SparseValueModel<Note>(sampleRate, resolution,
lbajardsilogic@0 88 notifyOnAdd),
lbajardsilogic@0 89 m_valueQuantization(0)
lbajardsilogic@0 90 {
lbajardsilogic@0 91 PlayParameterRepository::getInstance()->addModel(this);
lbajardsilogic@0 92 }
lbajardsilogic@0 93
lbajardsilogic@0 94 NoteModel(size_t sampleRate, size_t resolution,
lbajardsilogic@0 95 float valueMinimum, float valueMaximum,
lbajardsilogic@0 96 bool notifyOnAdd = true) :
lbajardsilogic@0 97 SparseValueModel<Note>(sampleRate, resolution,
lbajardsilogic@0 98 valueMinimum, valueMaximum,
lbajardsilogic@0 99 notifyOnAdd),
lbajardsilogic@0 100 m_valueQuantization(0)
lbajardsilogic@0 101 {
lbajardsilogic@0 102 PlayParameterRepository::getInstance()->addModel(this);
lbajardsilogic@0 103 }
lbajardsilogic@0 104
lbajardsilogic@0 105 float getValueQuantization() const { return m_valueQuantization; }
lbajardsilogic@0 106 void setValueQuantization(float q) { m_valueQuantization = q; }
lbajardsilogic@0 107
lbajardsilogic@0 108 /**
lbajardsilogic@0 109 * Notes have a duration, so this returns all points that span any
lbajardsilogic@0 110 * of the given range (as well as the usual additional few before
lbajardsilogic@0 111 * and after). Consequently this can be very slow (optimised data
lbajardsilogic@0 112 * structures still to be done!).
lbajardsilogic@0 113 */
lbajardsilogic@0 114 virtual PointList getPoints(long start, long end) const;
lbajardsilogic@0 115
lbajardsilogic@0 116 /**
lbajardsilogic@0 117 * Notes have a duration, so this returns all points that span the
lbajardsilogic@0 118 * given frame. Consequently this can be very slow (optimised
lbajardsilogic@0 119 * data structures still to be done!).
lbajardsilogic@0 120 */
lbajardsilogic@0 121 virtual PointList getPoints(long frame) const;
lbajardsilogic@0 122
lbajardsilogic@0 123 virtual QString toXmlString(QString indent = "",
lbajardsilogic@0 124 QString extraAttributes = "") const
lbajardsilogic@0 125 {
lbajardsilogic@0 126 return SparseValueModel<Note>::toXmlString
lbajardsilogic@0 127 (indent,
lbajardsilogic@0 128 QString("%1 valueQuantization=\"%2\"")
lbajardsilogic@0 129 .arg(extraAttributes).arg(m_valueQuantization));
lbajardsilogic@0 130 }
lbajardsilogic@0 131
lbajardsilogic@0 132 protected:
lbajardsilogic@0 133 float m_valueQuantization;
lbajardsilogic@0 134 };
lbajardsilogic@0 135
lbajardsilogic@0 136 #endif