Mercurial > hg > svcore
comparison data/model/NoteModel.h @ 1450:a12fd0456f0c streaming-csv-writer
Merge from default branch
author | Chris Cannam |
---|---|
date | Tue, 17 Apr 2018 10:35:42 +0100 |
parents | 48e9f538e6e9 |
children | 6965c83c8fa7 |
comparison
equal
deleted
inserted
replaced
1449:deabf9fd3d28 | 1450:a12fd0456f0c |
---|---|
38 struct Note | 38 struct Note |
39 { | 39 { |
40 public: | 40 public: |
41 Note(sv_frame_t _frame) : frame(_frame), value(0.0f), duration(0), level(1.f) { } | 41 Note(sv_frame_t _frame) : frame(_frame), value(0.0f), duration(0), level(1.f) { } |
42 Note(sv_frame_t _frame, float _value, sv_frame_t _duration, float _level, QString _label) : | 42 Note(sv_frame_t _frame, float _value, sv_frame_t _duration, float _level, QString _label) : |
43 frame(_frame), value(_value), duration(_duration), level(_level), label(_label) { } | 43 frame(_frame), value(_value), duration(_duration), level(_level), label(_label) { } |
44 | 44 |
45 int getDimensions() const { return 3; } | 45 int getDimensions() const { return 3; } |
46 | 46 |
47 sv_frame_t frame; | 47 sv_frame_t frame; |
48 float value; | 48 float value; |
54 | 54 |
55 void toXml(QTextStream &stream, | 55 void toXml(QTextStream &stream, |
56 QString indent = "", | 56 QString indent = "", |
57 QString extraAttributes = "") const | 57 QString extraAttributes = "") const |
58 { | 58 { |
59 stream << | 59 stream << |
60 QString("%1<point frame=\"%2\" value=\"%3\" duration=\"%4\" level=\"%5\" label=\"%6\" %7/>\n") | 60 QString("%1<point frame=\"%2\" value=\"%3\" duration=\"%4\" level=\"%5\" label=\"%6\" %7/>\n") |
61 .arg(indent).arg(frame).arg(value).arg(duration).arg(level) | 61 .arg(indent).arg(frame).arg(value).arg(duration).arg(level) |
62 .arg(XmlExportable::encodeEntities(label)).arg(extraAttributes); | 62 .arg(XmlExportable::encodeEntities(label)).arg(extraAttributes); |
63 } | 63 } |
64 | 64 |
65 QString toDelimitedDataString(QString delimiter, DataExportOptions opts, sv_samplerate_t sampleRate) const { | 65 QString toDelimitedDataString(QString delimiter, DataExportOptions opts, sv_samplerate_t sampleRate) const { |
66 QStringList list; | 66 QStringList list; |
73 if (label != "") list << label; | 73 if (label != "") list << label; |
74 return list.join(delimiter); | 74 return list.join(delimiter); |
75 } | 75 } |
76 | 76 |
77 struct Comparator { | 77 struct Comparator { |
78 bool operator()(const Note &p1, | 78 bool operator()(const Note &p1, |
79 const Note &p2) const { | 79 const Note &p2) const { |
80 if (p1.frame != p2.frame) return p1.frame < p2.frame; | 80 if (p1.frame != p2.frame) return p1.frame < p2.frame; |
81 if (p1.value != p2.value) return p1.value < p2.value; | 81 if (p1.value != p2.value) return p1.value < p2.value; |
82 if (p1.duration != p2.duration) return p1.duration < p2.duration; | 82 if (p1.duration != p2.duration) return p1.duration < p2.duration; |
83 if (p1.level != p2.level) return p1.level < p2.level; | 83 if (p1.level != p2.level) return p1.level < p2.level; |
84 return p1.label < p2.label; | 84 return p1.label < p2.label; |
85 } | 85 } |
86 }; | 86 }; |
87 | 87 |
88 struct OrderComparator { | 88 struct OrderComparator { |
89 bool operator()(const Note &p1, | 89 bool operator()(const Note &p1, |
90 const Note &p2) const { | 90 const Note &p2) const { |
91 return p1.frame < p2.frame; | 91 return p1.frame < p2.frame; |
92 } | 92 } |
93 }; | 93 }; |
94 }; | 94 }; |
95 | 95 |
96 | 96 |
97 class NoteModel : public IntervalModel<Note>, public NoteExportable | 97 class NoteModel : public IntervalModel<Note>, public NoteExportable |
98 { | 98 { |
99 Q_OBJECT | 99 Q_OBJECT |
100 | 100 |
101 public: | 101 public: |
102 NoteModel(sv_samplerate_t sampleRate, int resolution, | 102 NoteModel(sv_samplerate_t sampleRate, int resolution, |
103 bool notifyOnAdd = true) : | 103 bool notifyOnAdd = true) : |
104 IntervalModel<Note>(sampleRate, resolution, notifyOnAdd), | 104 IntervalModel<Note>(sampleRate, resolution, notifyOnAdd), |
105 m_valueQuantization(0) | 105 m_valueQuantization(0) |
106 { | 106 { |
107 PlayParameterRepository::getInstance()->addPlayable(this); | 107 PlayParameterRepository::getInstance()->addPlayable(this); |
108 } | 108 } |
109 | 109 |
110 NoteModel(sv_samplerate_t sampleRate, int resolution, | 110 NoteModel(sv_samplerate_t sampleRate, int resolution, |
111 float valueMinimum, float valueMaximum, | 111 float valueMinimum, float valueMaximum, |
112 bool notifyOnAdd = true) : | 112 bool notifyOnAdd = true) : |
113 IntervalModel<Note>(sampleRate, resolution, | 113 IntervalModel<Note>(sampleRate, resolution, |
114 valueMinimum, valueMaximum, | 114 valueMinimum, valueMaximum, |
115 notifyOnAdd), | 115 notifyOnAdd), |
116 m_valueQuantization(0) | 116 m_valueQuantization(0) |
117 { | 117 { |
118 PlayParameterRepository::getInstance()->addPlayable(this); | 118 PlayParameterRepository::getInstance()->addPlayable(this); |
119 } | 119 } |
120 | 120 |
121 virtual ~NoteModel() | 121 virtual ~NoteModel() |
122 { | 122 { |
123 PlayParameterRepository::getInstance()->removePlayable(this); | 123 PlayParameterRepository::getInstance()->removePlayable(this); |
141 { | 141 { |
142 std::cerr << "NoteModel::toXml: extraAttributes = \"" | 142 std::cerr << "NoteModel::toXml: extraAttributes = \"" |
143 << extraAttributes.toStdString() << std::endl; | 143 << extraAttributes.toStdString() << std::endl; |
144 | 144 |
145 IntervalModel<Note>::toXml | 145 IntervalModel<Note>::toXml |
146 (out, | 146 (out, |
147 indent, | 147 indent, |
148 QString("%1 subtype=\"note\" valueQuantization=\"%2\"") | 148 QString("%1 subtype=\"note\" valueQuantization=\"%2\"") |
149 .arg(extraAttributes).arg(m_valueQuantization)); | 149 .arg(extraAttributes).arg(m_valueQuantization)); |
150 } | 150 } |
151 | 151 |
152 /** | 152 /** |
153 * TabularModel methods. | 153 * TabularModel methods. |
154 */ | 154 */ |
225 return getNotesWithin(getStartFrame(), getEndFrame()); | 225 return getNotesWithin(getStartFrame(), getEndFrame()); |
226 } | 226 } |
227 | 227 |
228 NoteList getNotesWithin(sv_frame_t startFrame, sv_frame_t endFrame) const { | 228 NoteList getNotesWithin(sv_frame_t startFrame, sv_frame_t endFrame) const { |
229 | 229 |
230 PointList points = getPoints(startFrame, endFrame); | 230 PointList points = getPoints(startFrame, endFrame); |
231 NoteList notes; | 231 NoteList notes; |
232 | 232 |
233 for (PointList::iterator pli = | 233 for (PointList::iterator pli = |
234 points.begin(); pli != points.end(); ++pli) { | 234 points.begin(); pli != points.end(); ++pli) { |
235 | 235 |
236 sv_frame_t duration = pli->duration; | 236 sv_frame_t duration = pli->duration; |
237 if (duration == 0 || duration == 1) { | 237 if (duration == 0 || duration == 1) { |
238 duration = sv_frame_t(getSampleRate() / 20); | 238 duration = sv_frame_t(getSampleRate() / 20); |
239 } | 239 } |
240 | 240 |
241 int pitch = int(lrintf(pli->value)); | 241 int pitch = int(lrintf(pli->value)); |