Mercurial > hg > svgui
view view/AlignmentView.cpp @ 882:c0549bf12973 alignment_view
Fix misalignment in alignment view
author | Chris Cannam |
---|---|
date | Fri, 21 Nov 2014 14:50:27 +0000 |
parents | 6a590241d8ad |
children | f2c63ec85901 |
line wrap: on
line source
/* -*- c-basic-offset: 4 indent-tabs-mode: nil -*- vi:set ts=8 sts=4 sw=4: */ /* Sonic Visualiser An audio file viewer and annotation editor. Centre for Digital Music, Queen Mary, University of London. This file copyright 2006-2014 Chris Cannam and QMUL. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. See the file COPYING included with this distribution for more information. */ #include "AlignmentView.h" #include <QPainter> #include "data/model/SparseOneDimensionalModel.h" #include "layer/TimeInstantLayer.h" using std::vector; AlignmentView::AlignmentView(QWidget *w) : View(w, false), m_above(0), m_below(0) { setObjectName(tr("AlignmentView")); } void AlignmentView::globalCentreFrameChanged(int f) { View::globalCentreFrameChanged(f); update(); } void AlignmentView::viewCentreFrameChanged(View *v, int f) { View::viewCentreFrameChanged(v, f); if (v == m_above) { m_centreFrame = f; update(); } else if (v == m_below) { update(); } } void AlignmentView::viewManagerPlaybackFrameChanged(int) { update(); } void AlignmentView::viewAboveZoomLevelChanged(int level, bool) { m_zoomLevel = level; update(); } void AlignmentView::viewBelowZoomLevelChanged(int, bool) { update(); } void AlignmentView::setViewAbove(View *v) { if (m_above) { disconnect(m_above, 0, this, 0); } m_above = v; if (m_above) { connect(m_above, SIGNAL(zoomLevelChanged(int, bool)), this, SLOT(viewAboveZoomLevelChanged(int, bool))); } } void AlignmentView::setViewBelow(View *v) { if (m_below) { disconnect(m_below, 0, this, 0); } m_below = v; if (m_below) { connect(m_below, SIGNAL(zoomLevelChanged(int, bool)), this, SLOT(viewBelowZoomLevelChanged(int, bool))); } } void AlignmentView::paintEvent(QPaintEvent *) { if (m_above == 0 || m_below == 0 || !m_manager) return; bool darkPalette = false; if (m_manager) darkPalette = m_manager->getGlobalDarkBackground(); QColor fg, bg; if (darkPalette) { fg = Qt::gray; bg = Qt::black; } else { fg = Qt::black; bg = Qt::gray; } QPainter paint(this); paint.setPen(QPen(fg, 2)); paint.setBrush(Qt::NoBrush); paint.setRenderHint(QPainter::Antialiasing, true); paint.fillRect(rect(), bg); vector<int> keyFrames = getKeyFrames(); foreach (int f, keyFrames) { int ax = m_above->getXForFrame(f); int rf = m_above->alignToReference(f); int bf = m_below->alignFromReference(rf); int bx = m_below->getXForFrame(bf); paint.drawLine(ax, 0, bx, height()); } paint.end(); } vector<int> AlignmentView::getKeyFrames() { if (!m_above) { return getDefaultKeyFrames(); } SparseOneDimensionalModel *m = 0; // get the topmost such for (int i = 0; i < m_above->getLayerCount(); ++i) { if (qobject_cast<TimeInstantLayer *>(m_above->getLayer(i))) { SparseOneDimensionalModel *mm = qobject_cast<SparseOneDimensionalModel *> (m_above->getLayer(i)->getModel()); if (mm) m = mm; } } if (!m) { return getDefaultKeyFrames(); } vector<int> keyFrames; const SparseOneDimensionalModel::PointList pp = m->getPoints(); for (SparseOneDimensionalModel::PointList::const_iterator pi = pp.begin(); pi != pp.end(); ++pi) { keyFrames.push_back(pi->frame); } return keyFrames; } vector<int> AlignmentView::getDefaultKeyFrames() { vector<int> keyFrames; if (!m_above || !m_manager) return keyFrames; int rate = m_manager->getMainModelSampleRate(); if (rate == 0) return keyFrames; for (int f = m_above->getModelsStartFrame(); f <= m_above->getModelsEndFrame(); f += rate * 5) { keyFrames.push_back(f); } return keyFrames; }