Mercurial > hg > svcore
comparison data/model/TextModel.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 |
---|---|
31 struct TextPoint : public XmlExportable | 31 struct TextPoint : public XmlExportable |
32 { | 32 { |
33 public: | 33 public: |
34 TextPoint(sv_frame_t _frame) : frame(_frame), height(0.0f) { } | 34 TextPoint(sv_frame_t _frame) : frame(_frame), height(0.0f) { } |
35 TextPoint(sv_frame_t _frame, float _height, QString _label) : | 35 TextPoint(sv_frame_t _frame, float _height, QString _label) : |
36 frame(_frame), height(_height), label(_label) { } | 36 frame(_frame), height(_height), label(_label) { } |
37 | 37 |
38 int getDimensions() const { return 2; } | 38 int getDimensions() const { return 2; } |
39 | 39 |
40 sv_frame_t frame; | 40 sv_frame_t frame; |
41 float height; | 41 float height; |
44 QString getLabel() const { return label; } | 44 QString getLabel() const { return label; } |
45 | 45 |
46 void toXml(QTextStream &stream, QString indent = "", | 46 void toXml(QTextStream &stream, QString indent = "", |
47 QString extraAttributes = "") const | 47 QString extraAttributes = "") const |
48 { | 48 { |
49 stream << QString("%1<point frame=\"%2\" height=\"%3\" label=\"%4\" %5/>\n") | 49 stream << QString("%1<point frame=\"%2\" height=\"%3\" label=\"%4\" %5/>\n") |
50 .arg(indent).arg(frame).arg(height) | 50 .arg(indent).arg(frame).arg(height) |
51 .arg(encodeEntities(label)).arg(extraAttributes); | 51 .arg(encodeEntities(label)).arg(extraAttributes); |
52 } | 52 } |
53 | 53 |
54 QString toDelimitedDataString(QString delimiter, DataExportOptions, sv_samplerate_t sampleRate) const | 54 QString toDelimitedDataString(QString delimiter, DataExportOptions, sv_samplerate_t sampleRate) const |
55 { | 55 { |
59 if (label != "") list << label; | 59 if (label != "") list << label; |
60 return list.join(delimiter); | 60 return list.join(delimiter); |
61 } | 61 } |
62 | 62 |
63 struct Comparator { | 63 struct Comparator { |
64 bool operator()(const TextPoint &p1, | 64 bool operator()(const TextPoint &p1, |
65 const TextPoint &p2) const { | 65 const TextPoint &p2) const { |
66 if (p1.frame != p2.frame) return p1.frame < p2.frame; | 66 if (p1.frame != p2.frame) return p1.frame < p2.frame; |
67 if (p1.height != p2.height) return p1.height < p2.height; | 67 if (p1.height != p2.height) return p1.height < p2.height; |
68 return p1.label < p2.label; | 68 return p1.label < p2.label; |
69 } | 69 } |
70 }; | 70 }; |
71 | 71 |
72 struct OrderComparator { | 72 struct OrderComparator { |
73 bool operator()(const TextPoint &p1, | 73 bool operator()(const TextPoint &p1, |
74 const TextPoint &p2) const { | 74 const TextPoint &p2) const { |
75 return p1.frame < p2.frame; | 75 return p1.frame < p2.frame; |
76 } | 76 } |
77 }; | 77 }; |
78 }; | 78 }; |
79 | 79 |
80 | 80 |
81 // Make this a class rather than a typedef so it can be predeclared. | 81 // Make this a class rather than a typedef so it can be predeclared. |
84 { | 84 { |
85 Q_OBJECT | 85 Q_OBJECT |
86 | 86 |
87 public: | 87 public: |
88 TextModel(sv_samplerate_t sampleRate, int resolution, bool notifyOnAdd = true) : | 88 TextModel(sv_samplerate_t sampleRate, int resolution, bool notifyOnAdd = true) : |
89 SparseModel<TextPoint>(sampleRate, resolution, notifyOnAdd) | 89 SparseModel<TextPoint>(sampleRate, resolution, notifyOnAdd) |
90 { } | 90 { } |
91 | 91 |
92 virtual void toXml(QTextStream &out, | 92 virtual void toXml(QTextStream &out, |
93 QString indent = "", | 93 QString indent = "", |
94 QString extraAttributes = "") const | 94 QString extraAttributes = "") const |
95 { | 95 { |
96 SparseModel<TextPoint>::toXml | 96 SparseModel<TextPoint>::toXml |
97 (out, | 97 (out, |
98 indent, | 98 indent, |
99 QString("%1 subtype=\"text\"") | 99 QString("%1 subtype=\"text\"") |
100 .arg(extraAttributes)); | 100 .arg(extraAttributes)); |
101 } | 101 } |
102 | 102 |
103 QString getTypeName() const { return tr("Text"); } | 103 QString getTypeName() const { return tr("Text"); } |
104 | 104 |
105 /** | 105 /** |