Mercurial > hg > svgui
diff view/PaneStack.cpp @ 1530:34311e135695
Don't create alignment views at all if not requested (now that the request is made only at construction time)
author | Chris Cannam |
---|---|
date | Mon, 07 Oct 2019 14:30:13 +0100 |
parents | adbc3f1c4c4e |
children | 01a41a37bd26 |
line wrap: on
line diff
--- a/view/PaneStack.cpp Mon Oct 07 14:08:23 2019 +0100 +++ b/view/PaneStack.cpp Mon Oct 07 14:30:13 2019 +0100 @@ -91,18 +91,20 @@ QGridLayout *layout = new QGridLayout; layout->setMargin(0); layout->setHorizontalSpacing(m_viewManager->scalePixelSize(2)); + + AlignmentView *av = nullptr; + if (m_options & int(Option::ShowAlignmentViews)) { layout->setVerticalSpacing(0); + av = new AlignmentView(frame); + av->setFixedHeight(ViewManager::scalePixelSize(20)); + av->setViewManager(m_viewManager); + av->setVisible(false); // for now + layout->addWidget(av, 0, 1); } else { layout->setVerticalSpacing(m_viewManager->scalePixelSize(2)); } - AlignmentView *av = new AlignmentView(frame); - av->setFixedHeight(ViewManager::scalePixelSize(20)); - av->setViewManager(m_viewManager); - av->setVisible(false); // for now - layout->addWidget(av, 0, 1); - QPushButton *xButton = new QPushButton(frame); xButton->setIcon(IconLoader().load("cross")); xButton->setFixedSize(QSize(16, 16)); @@ -208,14 +210,17 @@ PaneStack::relinkAlignmentViews() { if (m_panes.empty()) return; - m_panes[0].alignmentView->hide(); + auto av = m_panes[0].alignmentView; + if (av) av->hide(); for (int i = 1; in_range_for(m_panes, i); ++i) { + av = m_panes[i].alignmentView; + if (!av) continue; if (!(m_options & int(Option::ShowAlignmentViews))) { - m_panes[i].alignmentView->hide(); + av->hide(); } else { - m_panes[i].alignmentView->setViewAbove(m_panes[i-1].pane); - m_panes[i].alignmentView->setViewBelow(m_panes[i].pane); - m_panes[i].alignmentView->show(); + av->setViewAbove(m_panes[i-1].pane); + av->setViewBelow(m_panes[i].pane); + av->show(); } } } @@ -224,8 +229,10 @@ PaneStack::unlinkAlignmentViews() { for (int i = 0; in_range_for(m_panes, i); ++i) { - m_panes[i].alignmentView->setViewAbove(nullptr); - m_panes[i].alignmentView->setViewBelow(nullptr); + auto av = m_panes[i].alignmentView; + if (!av) continue; + av->setViewAbove(nullptr); + av->setViewBelow(nullptr); } }