Mercurial > hg > svgui
comparison view/ViewManager.cpp @ 1486:ac0a8addabcf
Merge from branch by-id
author | Chris Cannam |
---|---|
date | Wed, 17 Jul 2019 14:25:16 +0100 |
parents | 9bf8aa2916e9 |
children | 4e466690bf20 |
comparison
equal
deleted
inserted
replaced
1468:de41a11cabc2 | 1486:ac0a8addabcf |
---|---|
33 m_playSource(nullptr), | 33 m_playSource(nullptr), |
34 m_recordTarget(nullptr), | 34 m_recordTarget(nullptr), |
35 m_globalCentreFrame(0), | 35 m_globalCentreFrame(0), |
36 m_globalZoom(ZoomLevel::FramesPerPixel, 1024), | 36 m_globalZoom(ZoomLevel::FramesPerPixel, 1024), |
37 m_playbackFrame(0), | 37 m_playbackFrame(0), |
38 m_playbackModel(nullptr), | |
39 m_mainModelSampleRate(0), | 38 m_mainModelSampleRate(0), |
40 m_lastLeft(0), | 39 m_lastLeft(0), |
41 m_lastRight(0), | 40 m_lastRight(0), |
42 m_inProgressExclusive(true), | 41 m_inProgressExclusive(true), |
43 m_toolMode(NavigateMode), | 42 m_toolMode(NavigateMode), |
192 m_playSource->play(f); | 191 m_playSource->play(f); |
193 } | 192 } |
194 } | 193 } |
195 } | 194 } |
196 | 195 |
197 Model * | 196 ModelId |
198 ViewManager::getPlaybackModel() const | 197 ViewManager::getPlaybackModel() const |
199 { | 198 { |
200 return m_playbackModel; | 199 return m_playbackModel; |
201 } | 200 } |
202 | 201 |
203 void | 202 void |
204 ViewManager::setPlaybackModel(Model *model) | 203 ViewManager::setPlaybackModel(ModelId model) |
205 { | 204 { |
206 m_playbackModel = model; | 205 m_playbackModel = model; |
207 } | 206 } |
208 | 207 |
209 sv_frame_t | 208 sv_frame_t |
210 ViewManager::alignPlaybackFrameToReference(sv_frame_t frame) const | 209 ViewManager::alignPlaybackFrameToReference(sv_frame_t frame) const |
211 { | 210 { |
212 #ifdef DEBUG_VIEW_MANAGER | 211 #ifdef DEBUG_VIEW_MANAGER |
213 cerr << "ViewManager::alignPlaybackFrameToReference(" << frame << "): playback model is " << m_playbackModel << endl; | 212 cerr << "ViewManager::alignPlaybackFrameToReference(" << frame << "): playback model is " << m_playbackModel << endl; |
214 #endif | 213 #endif |
215 if (!m_playbackModel || !m_alignMode) { | 214 if (m_playbackModel.isNone() || !m_alignMode) { |
216 return frame; | 215 return frame; |
217 } else { | 216 } else { |
218 sv_frame_t f = m_playbackModel->alignToReference(frame); | 217 auto playbackModel = ModelById::get(m_playbackModel); |
218 if (!playbackModel) { | |
219 return frame; | |
220 } | |
221 sv_frame_t f = playbackModel->alignToReference(frame); | |
219 #ifdef DEBUG_VIEW_MANAGER | 222 #ifdef DEBUG_VIEW_MANAGER |
220 cerr << "aligned frame = " << f << endl; | 223 cerr << "aligned frame = " << f << endl; |
221 #endif | 224 #endif |
222 return f; | 225 return f; |
223 } | 226 } |
227 ViewManager::alignReferenceToPlaybackFrame(sv_frame_t frame) const | 230 ViewManager::alignReferenceToPlaybackFrame(sv_frame_t frame) const |
228 { | 231 { |
229 #ifdef DEBUG_VIEW_MANAGER | 232 #ifdef DEBUG_VIEW_MANAGER |
230 cerr << "ViewManager::alignReferenceToPlaybackFrame(" << frame << "): playback model is " << m_playbackModel << endl; | 233 cerr << "ViewManager::alignReferenceToPlaybackFrame(" << frame << "): playback model is " << m_playbackModel << endl; |
231 #endif | 234 #endif |
232 if (!m_playbackModel || !m_alignMode) { | 235 if (m_playbackModel.isNone() || !m_alignMode) { |
233 return frame; | 236 return frame; |
234 } else { | 237 } else { |
235 sv_frame_t f = m_playbackModel->alignFromReference(frame); | 238 auto playbackModel = ModelById::get(m_playbackModel); |
239 if (!playbackModel) { | |
240 return frame; | |
241 } | |
242 sv_frame_t f = playbackModel->alignFromReference(frame); | |
236 #ifdef DEBUG_VIEW_MANAGER | 243 #ifdef DEBUG_VIEW_MANAGER |
237 cerr << "aligned frame = " << f << endl; | 244 cerr << "aligned frame = " << f << endl; |
238 #endif | 245 #endif |
239 return f; | 246 return f; |
240 } | 247 } |