Mercurial > hg > svgui
diff 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 |
line wrap: on
line diff
--- a/view/ViewManager.cpp Thu Jun 13 15:35:01 2019 +0100 +++ b/view/ViewManager.cpp Wed Jul 17 14:25:16 2019 +0100 @@ -35,7 +35,6 @@ m_globalCentreFrame(0), m_globalZoom(ZoomLevel::FramesPerPixel, 1024), m_playbackFrame(0), - m_playbackModel(nullptr), m_mainModelSampleRate(0), m_lastLeft(0), m_lastRight(0), @@ -194,14 +193,14 @@ } } -Model * +ModelId ViewManager::getPlaybackModel() const { return m_playbackModel; } void -ViewManager::setPlaybackModel(Model *model) +ViewManager::setPlaybackModel(ModelId model) { m_playbackModel = model; } @@ -212,10 +211,14 @@ #ifdef DEBUG_VIEW_MANAGER cerr << "ViewManager::alignPlaybackFrameToReference(" << frame << "): playback model is " << m_playbackModel << endl; #endif - if (!m_playbackModel || !m_alignMode) { + if (m_playbackModel.isNone() || !m_alignMode) { return frame; } else { - sv_frame_t f = m_playbackModel->alignToReference(frame); + auto playbackModel = ModelById::get(m_playbackModel); + if (!playbackModel) { + return frame; + } + sv_frame_t f = playbackModel->alignToReference(frame); #ifdef DEBUG_VIEW_MANAGER cerr << "aligned frame = " << f << endl; #endif @@ -229,10 +232,14 @@ #ifdef DEBUG_VIEW_MANAGER cerr << "ViewManager::alignReferenceToPlaybackFrame(" << frame << "): playback model is " << m_playbackModel << endl; #endif - if (!m_playbackModel || !m_alignMode) { + if (m_playbackModel.isNone() || !m_alignMode) { return frame; } else { - sv_frame_t f = m_playbackModel->alignFromReference(frame); + auto playbackModel = ModelById::get(m_playbackModel); + if (!playbackModel) { + return frame; + } + sv_frame_t f = playbackModel->alignFromReference(frame); #ifdef DEBUG_VIEW_MANAGER cerr << "aligned frame = " << f << endl; #endif