comparison data/model/FlexiNoteModel.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 c01cbe41aeb5
comparison
equal deleted inserted replaced
1449:deabf9fd3d28 1450:a12fd0456f0c
42 struct FlexiNote 42 struct FlexiNote
43 { 43 {
44 public: 44 public:
45 FlexiNote(sv_frame_t _frame) : frame(_frame), value(0.0f), duration(0), level(1.f) { } 45 FlexiNote(sv_frame_t _frame) : frame(_frame), value(0.0f), duration(0), level(1.f) { }
46 FlexiNote(sv_frame_t _frame, float _value, sv_frame_t _duration, float _level, QString _label) : 46 FlexiNote(sv_frame_t _frame, float _value, sv_frame_t _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 sv_frame_t frame; 51 sv_frame_t frame;
52 float value; 52 float value;
58 58
59 void toXml(QTextStream &stream, 59 void toXml(QTextStream &stream,
60 QString indent = "", 60 QString indent = "",
61 QString extraAttributes = "") const 61 QString extraAttributes = "") const
62 { 62 {
63 stream << 63 stream <<
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, DataExportOptions opts, sv_samplerate_t sampleRate) const 69 QString toDelimitedDataString(QString delimiter, DataExportOptions opts, sv_samplerate_t sampleRate) const
70 { 70 {
78 if (label != "") list << label; 78 if (label != "") list << label;
79 return list.join(delimiter); 79 return list.join(delimiter);
80 } 80 }
81 81
82 struct Comparator { 82 struct Comparator {
83 bool operator()(const FlexiNote &p1, 83 bool operator()(const FlexiNote &p1,
84 const FlexiNote &p2) const { 84 const FlexiNote &p2) const {
85 if (p1.frame != p2.frame) return p1.frame < p2.frame; 85 if (p1.frame != p2.frame) return p1.frame < p2.frame;
86 if (p1.value != p2.value) return p1.value < p2.value; 86 if (p1.value != p2.value) return p1.value < p2.value;
87 if (p1.duration != p2.duration) return p1.duration < p2.duration; 87 if (p1.duration != p2.duration) return p1.duration < p2.duration;
88 if (p1.level != p2.level) return p1.level < p2.level; 88 if (p1.level != p2.level) return p1.level < p2.level;
89 return p1.label < p2.label; 89 return p1.label < p2.label;
90 } 90 }
91 }; 91 };
92 92
93 struct OrderComparator { 93 struct OrderComparator {
94 bool operator()(const FlexiNote &p1, 94 bool operator()(const FlexiNote &p1,
95 const FlexiNote &p2) const { 95 const FlexiNote &p2) const {
96 return p1.frame < p2.frame; 96 return p1.frame < p2.frame;
97 } 97 }
98 }; 98 };
99 }; 99 };
100 100
101 101
102 class FlexiNoteModel : public IntervalModel<FlexiNote>, public NoteExportable 102 class FlexiNoteModel : public IntervalModel<FlexiNote>, public NoteExportable
104 Q_OBJECT 104 Q_OBJECT
105 105
106 public: 106 public:
107 FlexiNoteModel(sv_samplerate_t sampleRate, int resolution, 107 FlexiNoteModel(sv_samplerate_t sampleRate, int resolution,
108 bool notifyOnAdd = true) : 108 bool notifyOnAdd = true) :
109 IntervalModel<FlexiNote>(sampleRate, resolution, notifyOnAdd), 109 IntervalModel<FlexiNote>(sampleRate, resolution, notifyOnAdd),
110 m_valueQuantization(0) 110 m_valueQuantization(0)
111 { 111 {
112 PlayParameterRepository::getInstance()->addPlayable(this); 112 PlayParameterRepository::getInstance()->addPlayable(this);
113 } 113 }
114 114
115 FlexiNoteModel(sv_samplerate_t sampleRate, int resolution, 115 FlexiNoteModel(sv_samplerate_t sampleRate, int resolution,
116 float valueMinimum, float valueMaximum, 116 float valueMinimum, float valueMaximum,
117 bool notifyOnAdd = true) : 117 bool notifyOnAdd = true) :
118 IntervalModel<FlexiNote>(sampleRate, resolution, 118 IntervalModel<FlexiNote>(sampleRate, resolution,
119 valueMinimum, valueMaximum, 119 valueMinimum, valueMaximum,
120 notifyOnAdd), 120 notifyOnAdd),
121 m_valueQuantization(0) 121 m_valueQuantization(0)
122 { 122 {
123 PlayParameterRepository::getInstance()->addPlayable(this); 123 PlayParameterRepository::getInstance()->addPlayable(this);
124 } 124 }
125 125
126 virtual ~FlexiNoteModel() 126 virtual ~FlexiNoteModel()
127 { 127 {
128 PlayParameterRepository::getInstance()->removePlayable(this); 128 PlayParameterRepository::getInstance()->removePlayable(this);
148 { 148 {
149 std::cerr << "FlexiNoteModel::toXml: extraAttributes = \"" 149 std::cerr << "FlexiNoteModel::toXml: extraAttributes = \""
150 << extraAttributes.toStdString() << std::endl; 150 << extraAttributes.toStdString() << std::endl;
151 151
152 IntervalModel<FlexiNote>::toXml 152 IntervalModel<FlexiNote>::toXml
153 (out, 153 (out,
154 indent, 154 indent,
155 QString("%1 subtype=\"flexinote\" valueQuantization=\"%2\"") 155 QString("%1 subtype=\"flexinote\" valueQuantization=\"%2\"")
156 .arg(extraAttributes).arg(m_valueQuantization)); 156 .arg(extraAttributes).arg(m_valueQuantization));
157 } 157 }
158 158
159 /** 159 /**
160 * TabularModel methods. 160 * TabularModel methods.
161 */ 161 */
233 return getNotesWithin(getStartFrame(), getEndFrame()); 233 return getNotesWithin(getStartFrame(), getEndFrame());
234 } 234 }
235 235
236 NoteList getNotesWithin(sv_frame_t startFrame, sv_frame_t endFrame) const 236 NoteList getNotesWithin(sv_frame_t startFrame, sv_frame_t endFrame) const
237 { 237 {
238 PointList points = getPoints(startFrame, endFrame); 238 PointList points = getPoints(startFrame, endFrame);
239 NoteList notes; 239 NoteList notes;
240 for (PointList::iterator pli = points.begin(); pli != points.end(); ++pli) { 240 for (PointList::iterator pli = points.begin(); pli != points.end(); ++pli) {
241 sv_frame_t duration = pli->duration; 241 sv_frame_t duration = pli->duration;
242 if (duration == 0 || duration == 1) { 242 if (duration == 0 || duration == 1) {
243 duration = sv_frame_t(getSampleRate() / 20); 243 duration = sv_frame_t(getSampleRate() / 20);
244 } 244 }
245 int pitch = int(lrintf(pli->value)); 245 int pitch = int(lrintf(pli->value));
246 246