Mercurial > hg > svcore
comparison data/model/ImageModel.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 |
---|---|
45 | 45 |
46 void toXml(QTextStream &stream, | 46 void toXml(QTextStream &stream, |
47 QString indent = "", | 47 QString indent = "", |
48 QString extraAttributes = "") const | 48 QString extraAttributes = "") const |
49 { | 49 { |
50 stream << | 50 stream << |
51 QString("%1<point frame=\"%2\" image=\"%3\" label=\"%4\" %5/>\n") | 51 QString("%1<point frame=\"%2\" image=\"%3\" label=\"%4\" %5/>\n") |
52 .arg(indent).arg(frame) | 52 .arg(indent).arg(frame) |
53 .arg(encodeEntities(image)) | 53 .arg(encodeEntities(image)) |
54 .arg(encodeEntities(label)) | 54 .arg(encodeEntities(label)) |
55 .arg(extraAttributes); | 55 .arg(extraAttributes); |
56 } | 56 } |
57 | 57 |
63 if (label != "") list << label; | 63 if (label != "") list << label; |
64 return list.join(delimiter); | 64 return list.join(delimiter); |
65 } | 65 } |
66 | 66 |
67 struct Comparator { | 67 struct Comparator { |
68 bool operator()(const ImagePoint &p1, | 68 bool operator()(const ImagePoint &p1, |
69 const ImagePoint &p2) const { | 69 const ImagePoint &p2) const { |
70 if (p1.frame != p2.frame) return p1.frame < p2.frame; | 70 if (p1.frame != p2.frame) return p1.frame < p2.frame; |
71 if (p1.label != p2.label) return p1.label < p2.label; | 71 if (p1.label != p2.label) return p1.label < p2.label; |
72 return p1.image < p2.image; | 72 return p1.image < p2.image; |
73 } | 73 } |
74 }; | 74 }; |
75 | 75 |
76 struct OrderComparator { | 76 struct OrderComparator { |
77 bool operator()(const ImagePoint &p1, | 77 bool operator()(const ImagePoint &p1, |
78 const ImagePoint &p2) const { | 78 const ImagePoint &p2) const { |
79 return p1.frame < p2.frame; | 79 return p1.frame < p2.frame; |
80 } | 80 } |
81 }; | 81 }; |
82 }; | 82 }; |
83 | 83 |
84 | 84 |
85 // Make this a class rather than a typedef so it can be predeclared. | 85 // Make this a class rather than a typedef so it can be predeclared. |
88 { | 88 { |
89 Q_OBJECT | 89 Q_OBJECT |
90 | 90 |
91 public: | 91 public: |
92 ImageModel(sv_samplerate_t sampleRate, int resolution, bool notifyOnAdd = true) : | 92 ImageModel(sv_samplerate_t sampleRate, int resolution, bool notifyOnAdd = true) : |
93 SparseModel<ImagePoint>(sampleRate, resolution, notifyOnAdd) | 93 SparseModel<ImagePoint>(sampleRate, resolution, notifyOnAdd) |
94 { } | 94 { } |
95 | 95 |
96 QString getTypeName() const { return tr("Image"); } | 96 QString getTypeName() const { return tr("Image"); } |
97 | 97 |
98 virtual void toXml(QTextStream &out, | 98 virtual void toXml(QTextStream &out, |
99 QString indent = "", | 99 QString indent = "", |
100 QString extraAttributes = "") const | 100 QString extraAttributes = "") const |
101 { | 101 { |
102 SparseModel<ImagePoint>::toXml | 102 SparseModel<ImagePoint>::toXml |
103 (out, | 103 (out, |
104 indent, | 104 indent, |
105 QString("%1 subtype=\"image\"") | 105 QString("%1 subtype=\"image\"") |
106 .arg(extraAttributes)); | 106 .arg(extraAttributes)); |
107 } | 107 } |
108 | 108 |
109 /** | 109 /** |
110 * Command to change the image for a point. | 110 * Command to change the image for a point. |
111 */ | 111 */ |
114 public: | 114 public: |
115 ChangeImageCommand(ImageModel *model, | 115 ChangeImageCommand(ImageModel *model, |
116 const ImagePoint &point, | 116 const ImagePoint &point, |
117 QString newImage, | 117 QString newImage, |
118 QString newLabel) : | 118 QString newLabel) : |
119 m_model(model), m_oldPoint(point), m_newPoint(point) { | 119 m_model(model), m_oldPoint(point), m_newPoint(point) { |
120 m_newPoint.image = newImage; | 120 m_newPoint.image = newImage; |
121 m_newPoint.label = newLabel; | 121 m_newPoint.label = newLabel; |
122 } | 122 } |
123 | 123 |
124 virtual QString getName() const { return tr("Edit Image"); } | 124 virtual QString getName() const { return tr("Edit Image"); } |
125 | 125 |
126 virtual void execute() { | 126 virtual void execute() { |
127 m_model->deletePoint(m_oldPoint); | 127 m_model->deletePoint(m_oldPoint); |
128 m_model->addPoint(m_newPoint); | 128 m_model->addPoint(m_newPoint); |
129 std::swap(m_oldPoint, m_newPoint); | 129 std::swap(m_oldPoint, m_newPoint); |
130 } | 130 } |
131 | 131 |
132 virtual void unexecute() { execute(); } | 132 virtual void unexecute() { execute(); } |
133 | 133 |
134 private: | 134 private: |
135 ImageModel *m_model; | 135 ImageModel *m_model; |
136 ImagePoint m_oldPoint; | 136 ImagePoint m_oldPoint; |
137 ImagePoint m_newPoint; | 137 ImagePoint m_newPoint; |
138 }; | 138 }; |
139 | 139 |
140 /** | 140 /** |
141 * TabularModel methods. | 141 * TabularModel methods. |
142 */ | 142 */ |