Mercurial > hg > svgui
diff view/PaneStack.cpp @ 1606:d6976d231efb
Reduce heights of alignment views if (they are visible and) we are squashed for space
author | Chris Cannam |
---|---|
date | Wed, 06 May 2020 09:08:37 +0100 |
parents | 01a41a37bd26 |
children | c6f5c822b10d |
line wrap: on
line diff
--- a/view/PaneStack.cpp Thu Apr 30 14:47:13 2020 +0100 +++ b/view/PaneStack.cpp Wed May 06 09:08:37 2020 +0100 @@ -32,6 +32,7 @@ #include <QPushButton> #include <QSplitter> #include <QStackedWidget> +#include <QResizeEvent> #include <iostream> @@ -225,6 +226,8 @@ av->show(); } } + + adjustAlignmentViewHeights(size().height()); } void @@ -239,6 +242,44 @@ } void +PaneStack::resizeEvent(QResizeEvent *ev) +{ + adjustAlignmentViewHeights(ev->size().height()); +} + +void +PaneStack::adjustAlignmentViewHeights(int forMyHeight) +{ + if (!(m_options & int(Option::ShowAlignmentViews))) return; + if (!(m_options & int(Option::NoUserResize))) return; + if (!isVisible()) return; + + int heightPerPane = forMyHeight / int(m_panes.size()); + + SVCERR << "heightPerPane = " << heightPerPane << " (" + << forMyHeight << "/" << m_panes.size() << ")" << endl; + + int roomForAlignmentView = heightPerPane / 4; + int min = ViewManager::scalePixelSize(6); + int max = ViewManager::scalePixelSize(25); + int alignmentHeight = roomForAlignmentView; + if (alignmentHeight < min) { + alignmentHeight = min; + } + if (alignmentHeight > max) { + alignmentHeight = max; + } + + SVCERR << "alignmentHeight = " << alignmentHeight << endl; + + for (int i = 0; in_range_for(m_panes, i); ++i) { + auto av = m_panes[i].alignmentView; + if (!av) continue; + av->setFixedHeight(alignmentHeight); + } +} + +void PaneStack::setPropertyStackMinWidth(int mw) { for (std::vector<PaneRec>::iterator i = m_panes.begin();