lyx_mirror/src/frontends/qt4/LyXToolBox.cpp
Guillaume Munch 6bd70011e9 LyXToolBox: a QToolBox with minimum size management
The purpose of this custom widget is to allow the use of a QToolBox in a limited
area. The stock QToolBox does not provide a minimum size hint that depends on
the size of the pages; it assumes that there is enough room.  This subclass sets
the minimal size of the QToolbox. Without this, the size of the QToolbox is only
determined by values in the ui file and therefore causes portability and
localisation issues. Note that the computation of the minimum size hint depends
on the minimum size hints of the page widgets. Therefore page widgets must have
a layout with layoutSizeContraint = SetMinimumSize or similar.
2016-05-29 17:55:41 -04:00

57 lines
1.4 KiB
C++

// -*- C++ -*-
/**
* \file LyXToolBox.cpp
* This file is part of LyX, the document processor.
* Licence details can be found in the file COPYING.
*
* \author Guillaume Munch
*
* Full author contact details are available in file CREDITS.
*/
#include <config.h>
#include "LyXToolBox.h"
#include <QApplication>
#include <QLayout>
#include "support/debug.h"
namespace lyx {
namespace frontend {
QSize LyXToolBox::minimumSizeHint() const
{
QSize s(0,0);
// Compute the max of the minimal sizes of the pages
QWidget * page;
for (int i = 0; (page = widget(i)); ++i)
s = s.expandedTo(page->minimumSizeHint());
// Add the height of the tabs
if (currentWidget())
s.rheight() += height() - currentWidget()->height();
return s;
}
void LyXToolBox::showEvent(QShowEvent * e)
{
// Computation of the tab height might be incorrect yet (the proper sizes of
// the pages have only been computed now).
// It might still be incorrect after this. All this would be unnecessary if
// QToolBox made our life easier and exposed more information; for instance
// let us access the scroll areas enclosing the pages (from which one can
// deduce the real tab height).
layout()->invalidate();
// proceed with geometry update to avoid flicker
qApp->processEvents(QEventLoop::ExcludeUserInputEvents, 50);
QToolBox::showEvent(e);
}
} // namespace frontend
} // namespace lyx
#include "moc_LyXToolBox.cpp"