Mercurial > hg > svcore
comparison data/model/SparseOneDimensionalModel.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 |
---|---|
39 void toXml(QTextStream &stream, | 39 void toXml(QTextStream &stream, |
40 QString indent = "", | 40 QString indent = "", |
41 QString extraAttributes = "") const | 41 QString extraAttributes = "") const |
42 { | 42 { |
43 stream << QString("%1<point frame=\"%2\" label=\"%3\" %4/>\n") | 43 stream << QString("%1<point frame=\"%2\" label=\"%3\" %4/>\n") |
44 .arg(indent).arg(frame).arg(XmlExportable::encodeEntities(label)) | 44 .arg(indent).arg(frame).arg(XmlExportable::encodeEntities(label)) |
45 .arg(extraAttributes); | 45 .arg(extraAttributes); |
46 } | 46 } |
47 | 47 |
48 QString toDelimitedDataString(QString delimiter, DataExportOptions, sv_samplerate_t sampleRate) const | 48 QString toDelimitedDataString(QString delimiter, DataExportOptions, sv_samplerate_t sampleRate) const |
49 { | 49 { |
52 if (label != "") list << label; | 52 if (label != "") list << label; |
53 return list.join(delimiter); | 53 return list.join(delimiter); |
54 } | 54 } |
55 | 55 |
56 struct Comparator { | 56 struct Comparator { |
57 bool operator()(const OneDimensionalPoint &p1, | 57 bool operator()(const OneDimensionalPoint &p1, |
58 const OneDimensionalPoint &p2) const { | 58 const OneDimensionalPoint &p2) const { |
59 if (p1.frame != p2.frame) return p1.frame < p2.frame; | 59 if (p1.frame != p2.frame) return p1.frame < p2.frame; |
60 return p1.label < p2.label; | 60 return p1.label < p2.label; |
61 } | 61 } |
62 }; | 62 }; |
63 | 63 |
64 struct OrderComparator { | 64 struct OrderComparator { |
65 bool operator()(const OneDimensionalPoint &p1, | 65 bool operator()(const OneDimensionalPoint &p1, |
66 const OneDimensionalPoint &p2) const { | 66 const OneDimensionalPoint &p2) const { |
67 return p1.frame < p2.frame; | 67 return p1.frame < p2.frame; |
68 } | 68 } |
69 }; | 69 }; |
70 }; | 70 }; |
71 | 71 |
72 | 72 |
73 class SparseOneDimensionalModel : public SparseModel<OneDimensionalPoint>, | 73 class SparseOneDimensionalModel : public SparseModel<OneDimensionalPoint>, |
75 { | 75 { |
76 Q_OBJECT | 76 Q_OBJECT |
77 | 77 |
78 public: | 78 public: |
79 SparseOneDimensionalModel(sv_samplerate_t sampleRate, int resolution, | 79 SparseOneDimensionalModel(sv_samplerate_t sampleRate, int resolution, |
80 bool notifyOnAdd = true) : | 80 bool notifyOnAdd = true) : |
81 SparseModel<OneDimensionalPoint>(sampleRate, resolution, notifyOnAdd) | 81 SparseModel<OneDimensionalPoint>(sampleRate, resolution, notifyOnAdd) |
82 { | 82 { |
83 PlayParameterRepository::getInstance()->addPlayable(this); | 83 PlayParameterRepository::getInstance()->addPlayable(this); |
84 } | 84 } |
85 | 85 |
86 virtual ~SparseOneDimensionalModel() | 86 virtual ~SparseOneDimensionalModel() |
87 { | 87 { |
88 PlayParameterRepository::getInstance()->removePlayable(this); | 88 PlayParameterRepository::getInstance()->removePlayable(this); |
95 return "tap"; | 95 return "tap"; |
96 } | 96 } |
97 | 97 |
98 int getIndexOf(const Point &point) | 98 int getIndexOf(const Point &point) |
99 { | 99 { |
100 // slow | 100 // slow |
101 int i = 0; | 101 int i = 0; |
102 Point::Comparator comparator; | 102 Point::Comparator comparator; |
103 for (PointList::const_iterator j = m_points.begin(); | 103 for (PointList::const_iterator j = m_points.begin(); |
104 j != m_points.end(); ++j, ++i) { | 104 j != m_points.end(); ++j, ++i) { |
105 if (!comparator(*j, point) && !comparator(point, *j)) return i; | 105 if (!comparator(*j, point) && !comparator(point, *j)) return i; |
106 } | 106 } |
107 return -1; | 107 return -1; |
108 } | 108 } |
109 | 109 |
110 QString getTypeName() const { return tr("Sparse 1-D"); } | 110 QString getTypeName() const { return tr("Sparse 1-D"); } |
111 | 111 |
112 /** | 112 /** |
187 return getNotesWithin(getStartFrame(), getEndFrame()); | 187 return getNotesWithin(getStartFrame(), getEndFrame()); |
188 } | 188 } |
189 | 189 |
190 NoteList getNotesWithin(sv_frame_t startFrame, sv_frame_t endFrame) const { | 190 NoteList getNotesWithin(sv_frame_t startFrame, sv_frame_t endFrame) const { |
191 | 191 |
192 PointList points = getPoints(startFrame, endFrame); | 192 PointList points = getPoints(startFrame, endFrame); |
193 NoteList notes; | 193 NoteList notes; |
194 | 194 |
195 for (PointList::iterator pli = | 195 for (PointList::iterator pli = |
196 points.begin(); pli != points.end(); ++pli) { | 196 points.begin(); pli != points.end(); ++pli) { |
197 | 197 |
198 notes.push_back | 198 notes.push_back |
199 (NoteData(pli->frame, | 199 (NoteData(pli->frame, |
200 sv_frame_t(getSampleRate() / 6), // arbitrary short duration | 200 sv_frame_t(getSampleRate() / 6), // arbitrary short duration |
201 64, // default pitch | 201 64, // default pitch |