comparison data/model/FlexiNoteModel.h @ 935:f960d67ce842 tonioni

Merge from branch warnfix_no_size_t
author Chris Cannam
date Wed, 18 Jun 2014 13:42:01 +0100
parents 06579b8ffb7b
children b14064bd1f97
comparison
equal deleted inserted replaced
925:3efc20c59a94 935:f960d67ce842
41 41
42 struct FlexiNote 42 struct FlexiNote
43 { 43 {
44 public: 44 public:
45 FlexiNote(long _frame) : frame(_frame), value(0.0f), duration(0), level(1.f) { } 45 FlexiNote(long _frame) : frame(_frame), value(0.0f), duration(0), level(1.f) { }
46 FlexiNote(long _frame, float _value, size_t _duration, float _level, QString _label) : 46 FlexiNote(long _frame, float _value, int _duration, float _level, QString _label) :
47 frame(_frame), value(_value), duration(_duration), level(_level), label(_label) { } 47 frame(_frame), value(_value), duration(_duration), level(_level), label(_label) { }
48 48
49 int getDimensions() const { return 3; } 49 int getDimensions() const { return 3; }
50 50
51 long frame; 51 long frame;
52 float value; 52 float value;
53 size_t duration; 53 int duration;
54 float level; 54 float level;
55 QString label; 55 QString label;
56 56
57 QString getLabel() const { return label; } 57 QString getLabel() const { return label; }
58 58
64 QString("%1<point frame=\"%2\" value=\"%3\" duration=\"%4\" level=\"%5\" label=\"%6\" %7/>\n") 64 QString("%1<point frame=\"%2\" value=\"%3\" duration=\"%4\" level=\"%5\" label=\"%6\" %7/>\n")
65 .arg(indent).arg(frame).arg(value).arg(duration).arg(level) 65 .arg(indent).arg(frame).arg(value).arg(duration).arg(level)
66 .arg(XmlExportable::encodeEntities(label)).arg(extraAttributes); 66 .arg(XmlExportable::encodeEntities(label)).arg(extraAttributes);
67 } 67 }
68 68
69 QString toDelimitedDataString(QString delimiter, size_t sampleRate) const 69 QString toDelimitedDataString(QString delimiter, int sampleRate) const
70 { 70 {
71 QStringList list; 71 QStringList list;
72 list << RealTime::frame2RealTime(frame, sampleRate).toString().c_str(); 72 list << RealTime::frame2RealTime(frame, sampleRate).toString().c_str();
73 list << QString("%1").arg(value); 73 list << QString("%1").arg(value);
74 list << RealTime::frame2RealTime(duration, sampleRate).toString().c_str(); 74 list << RealTime::frame2RealTime(duration, sampleRate).toString().c_str();
100 class FlexiNoteModel : public IntervalModel<FlexiNote>, public NoteExportable 100 class FlexiNoteModel : public IntervalModel<FlexiNote>, public NoteExportable
101 { 101 {
102 Q_OBJECT 102 Q_OBJECT
103 103
104 public: 104 public:
105 FlexiNoteModel(size_t sampleRate, size_t resolution, 105 FlexiNoteModel(int sampleRate, int resolution,
106 bool notifyOnAdd = true) : 106 bool notifyOnAdd = true) :
107 IntervalModel<FlexiNote>(sampleRate, resolution, notifyOnAdd), 107 IntervalModel<FlexiNote>(sampleRate, resolution, notifyOnAdd),
108 m_valueQuantization(0) 108 m_valueQuantization(0)
109 { 109 {
110 PlayParameterRepository::getInstance()->addPlayable(this); 110 PlayParameterRepository::getInstance()->addPlayable(this);
111 } 111 }
112 112
113 FlexiNoteModel(size_t sampleRate, size_t resolution, 113 FlexiNoteModel(int sampleRate, int resolution,
114 float valueMinimum, float valueMaximum, 114 float valueMinimum, float valueMaximum,
115 bool notifyOnAdd = true) : 115 bool notifyOnAdd = true) :
116 IntervalModel<FlexiNote>(sampleRate, resolution, 116 IntervalModel<FlexiNote>(sampleRate, resolution,
117 valueMinimum, valueMaximum, 117 valueMinimum, valueMaximum,
118 notifyOnAdd), 118 notifyOnAdd),
226 * NoteExportable methods. 226 * NoteExportable methods.
227 */ 227 */
228 228
229 NoteList getNotes() const 229 NoteList getNotes() const
230 { 230 {
231 return getNotes(getStartFrame(), getEndFrame()); 231 return getNotesWithin(getStartFrame(), getEndFrame());
232 } 232 }
233 233
234 NoteList getNotes(size_t startFrame, size_t endFrame) const 234 NoteList getNotesWithin(int startFrame, int endFrame) const
235 { 235 {
236 PointList points = getPoints(startFrame, endFrame); 236 PointList points = getPoints(startFrame, endFrame);
237 NoteList notes; 237 NoteList notes;
238 for (PointList::iterator pli = points.begin(); pli != points.end(); ++pli) { 238 for (PointList::iterator pli = points.begin(); pli != points.end(); ++pli) {
239 size_t duration = pli->duration; 239 int duration = pli->duration;
240 if (duration == 0 || duration == 1) { 240 if (duration == 0 || duration == 1) {
241 duration = getSampleRate() / 20; 241 duration = getSampleRate() / 20;
242 } 242 }
243 int pitch = lrintf(pli->value); 243 int pitch = lrintf(pli->value);
244 244