Mercurial > hg > svcore
comparison data/model/RegionModel.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 |
---|---|
37 { | 37 { |
38 public: | 38 public: |
39 RegionRec() : frame(0), value(0.f), duration(0) { } | 39 RegionRec() : frame(0), value(0.f), duration(0) { } |
40 RegionRec(sv_frame_t _frame) : frame(_frame), value(0.0f), duration(0) { } | 40 RegionRec(sv_frame_t _frame) : frame(_frame), value(0.0f), duration(0) { } |
41 RegionRec(sv_frame_t _frame, float _value, sv_frame_t _duration, QString _label) : | 41 RegionRec(sv_frame_t _frame, float _value, sv_frame_t _duration, QString _label) : |
42 frame(_frame), value(_value), duration(_duration), label(_label) { } | 42 frame(_frame), value(_value), duration(_duration), label(_label) { } |
43 | 43 |
44 int getDimensions() const { return 3; } | 44 int getDimensions() const { return 3; } |
45 | 45 |
46 sv_frame_t frame; | 46 sv_frame_t frame; |
47 float value; | 47 float value; |
52 | 52 |
53 void toXml(QTextStream &stream, | 53 void toXml(QTextStream &stream, |
54 QString indent = "", | 54 QString indent = "", |
55 QString extraAttributes = "") const | 55 QString extraAttributes = "") const |
56 { | 56 { |
57 stream << | 57 stream << |
58 QString("%1<point frame=\"%2\" value=\"%3\" duration=\"%4\" label=\"%5\" %6/>\n") | 58 QString("%1<point frame=\"%2\" value=\"%3\" duration=\"%4\" label=\"%5\" %6/>\n") |
59 .arg(indent).arg(frame).arg(value).arg(duration) | 59 .arg(indent).arg(frame).arg(value).arg(duration) |
60 .arg(XmlExportable::encodeEntities(label)).arg(extraAttributes); | 60 .arg(XmlExportable::encodeEntities(label)).arg(extraAttributes); |
61 } | 61 } |
62 | 62 |
63 QString toDelimitedDataString(QString delimiter, DataExportOptions, sv_samplerate_t sampleRate) const | 63 QString toDelimitedDataString(QString delimiter, DataExportOptions, sv_samplerate_t sampleRate) const |
64 { | 64 { |
69 if (label != "") list << label; | 69 if (label != "") list << label; |
70 return list.join(delimiter); | 70 return list.join(delimiter); |
71 } | 71 } |
72 | 72 |
73 struct Comparator { | 73 struct Comparator { |
74 bool operator()(const RegionRec &p1, | 74 bool operator()(const RegionRec &p1, |
75 const RegionRec &p2) const { | 75 const RegionRec &p2) const { |
76 if (p1.frame != p2.frame) return p1.frame < p2.frame; | 76 if (p1.frame != p2.frame) return p1.frame < p2.frame; |
77 if (p1.value != p2.value) return p1.value < p2.value; | 77 if (p1.value != p2.value) return p1.value < p2.value; |
78 if (p1.duration != p2.duration) return p1.duration < p2.duration; | 78 if (p1.duration != p2.duration) return p1.duration < p2.duration; |
79 return p1.label < p2.label; | 79 return p1.label < p2.label; |
80 } | 80 } |
81 }; | 81 }; |
82 | 82 |
83 struct OrderComparator { | 83 struct OrderComparator { |
84 bool operator()(const RegionRec &p1, | 84 bool operator()(const RegionRec &p1, |
85 const RegionRec &p2) const { | 85 const RegionRec &p2) const { |
86 return p1.frame < p2.frame; | 86 return p1.frame < p2.frame; |
87 } | 87 } |
88 }; | 88 }; |
89 }; | 89 }; |
90 | 90 |
91 | 91 |
92 class RegionModel : public IntervalModel<RegionRec> | 92 class RegionModel : public IntervalModel<RegionRec> |
94 Q_OBJECT | 94 Q_OBJECT |
95 | 95 |
96 public: | 96 public: |
97 RegionModel(sv_samplerate_t sampleRate, int resolution, | 97 RegionModel(sv_samplerate_t sampleRate, int resolution, |
98 bool notifyOnAdd = true) : | 98 bool notifyOnAdd = true) : |
99 IntervalModel<RegionRec>(sampleRate, resolution, notifyOnAdd), | 99 IntervalModel<RegionRec>(sampleRate, resolution, notifyOnAdd), |
100 m_valueQuantization(0), | 100 m_valueQuantization(0), |
101 m_haveDistinctValues(false) | 101 m_haveDistinctValues(false) |
102 { | 102 { |
103 } | 103 } |
104 | 104 |
105 RegionModel(sv_samplerate_t sampleRate, int resolution, | 105 RegionModel(sv_samplerate_t sampleRate, int resolution, |
106 float valueMinimum, float valueMaximum, | 106 float valueMinimum, float valueMaximum, |
107 bool notifyOnAdd = true) : | 107 bool notifyOnAdd = true) : |
108 IntervalModel<RegionRec>(sampleRate, resolution, | 108 IntervalModel<RegionRec>(sampleRate, resolution, |
109 valueMinimum, valueMaximum, | 109 valueMinimum, valueMaximum, |
110 notifyOnAdd), | 110 notifyOnAdd), |
111 m_valueQuantization(0), | 111 m_valueQuantization(0), |
112 m_haveDistinctValues(false) | 112 m_haveDistinctValues(false) |
113 { | 113 { |
114 } | 114 } |
115 | 115 |
116 virtual ~RegionModel() | 116 virtual ~RegionModel() |
130 { | 130 { |
131 std::cerr << "RegionModel::toXml: extraAttributes = \"" | 131 std::cerr << "RegionModel::toXml: extraAttributes = \"" |
132 << extraAttributes.toStdString() << std::endl; | 132 << extraAttributes.toStdString() << std::endl; |
133 | 133 |
134 IntervalModel<RegionRec>::toXml | 134 IntervalModel<RegionRec>::toXml |
135 (out, | 135 (out, |
136 indent, | 136 indent, |
137 QString("%1 subtype=\"region\" valueQuantization=\"%2\"") | 137 QString("%1 subtype=\"region\" valueQuantization=\"%2\"") |
138 .arg(extraAttributes).arg(m_valueQuantization)); | 138 .arg(extraAttributes).arg(m_valueQuantization)); |
139 } | 139 } |
140 | 140 |
141 /** | 141 /** |
142 * TabularModel methods. | 142 * TabularModel methods. |
143 */ | 143 */ |