comparison view/AlignmentView.cpp @ 1486:ac0a8addabcf

Merge from branch by-id
author Chris Cannam
date Wed, 17 Jul 2019 14:25:16 +0100
parents 84c4ddb38415
children c5589d94b731
comparison
equal deleted inserted replaced
1468:de41a11cabc2 1486:ac0a8addabcf
145 { 145 {
146 if (!m_above) { 146 if (!m_above) {
147 return getDefaultKeyFrames(); 147 return getDefaultKeyFrames();
148 } 148 }
149 149
150 SparseOneDimensionalModel *m = nullptr; 150 ModelId m;
151 151
152 // get the topmost such 152 // get the topmost such
153 for (int i = 0; i < m_above->getLayerCount(); ++i) { 153 for (int i = 0; i < m_above->getLayerCount(); ++i) {
154 if (qobject_cast<TimeInstantLayer *>(m_above->getLayer(i))) { 154 if (qobject_cast<TimeInstantLayer *>(m_above->getLayer(i))) {
155 SparseOneDimensionalModel *mm = 155 ModelId mm = m_above->getLayer(i)->getModel();
156 qobject_cast<SparseOneDimensionalModel *> 156 if (ModelById::isa<SparseOneDimensionalModel>(mm)) {
157 (m_above->getLayer(i)->getModel()); 157 m = mm;
158 if (mm) m = mm; 158 }
159 } 159 }
160 } 160 }
161 161
162 if (!m) { 162 auto model = ModelById::getAs<SparseOneDimensionalModel>(m);
163 if (!model) {
163 return getDefaultKeyFrames(); 164 return getDefaultKeyFrames();
164 } 165 }
165 166
166 vector<sv_frame_t> keyFrames; 167 vector<sv_frame_t> keyFrames;
167 168
168 EventVector pp = m->getAllEvents(); 169 EventVector pp = model->getAllEvents();
169 for (EventVector::const_iterator pi = pp.begin(); pi != pp.end(); ++pi) { 170 for (EventVector::const_iterator pi = pp.begin(); pi != pp.end(); ++pi) {
170 keyFrames.push_back(pi->getFrame()); 171 keyFrames.push_back(pi->getFrame());
171 } 172 }
172 173
173 return keyFrames; 174 return keyFrames;