From 9b547e6c718146ab73122a1b1f5d1c94e1ce7e3a Mon Sep 17 00:00:00 2001 From: Tomaz Canabrava Date: Tue, 10 Feb 2015 15:51:30 -0200 Subject: Remove the flicker issue and the resize issue. The flicker was caused by removing all widgets (and thus setting the size of the splitter to zero) and then re-adding them. I've added four QStackedWdigets that have a consistent size and the only thing I do now is to set the corresponding widget to visible without removing / readding anything, and thus, not messing with the sizes. Signed-off-by: Tomaz Canabrava Signed-off-by: Dirk Hohndel --- qt-ui/mainwindow.cpp | 36 ++++++++++++++++-------------------- qt-ui/mainwindow.ui | 12 ++++++++---- 2 files changed, 24 insertions(+), 24 deletions(-) (limited to 'qt-ui') diff --git a/qt-ui/mainwindow.cpp b/qt-ui/mainwindow.cpp index 550fd386f..c9915ad22 100644 --- a/qt-ui/mainwindow.cpp +++ b/qt-ui/mainwindow.cpp @@ -1516,6 +1516,18 @@ void MainWindow::checkForUndoAndRedo() void MainWindow::registerApplicationState(const QByteArray& state, QWidget *topLeft, QWidget *bottomLeft, QWidget *topRight, QWidget *bottomRight) { applicationState[state] = WidgetForBorder(topLeft, bottomLeft, topRight, bottomRight); + if (ui.topLeft->indexOf(topLeft) == -1) { + ui.topLeft->addWidget(topLeft); + } + if (ui.topRight->indexOf(topRight) == -1) { + ui.topRight->addWidget(topRight); + } + if (ui.bottomLeft->indexOf(bottomLeft) == -1) { + ui.bottomLeft->addWidget(bottomLeft); + } + if(ui.bottomRight->indexOf(bottomRight) == -1) { + ui.bottomRight->addWidget(bottomRight); + } } void MainWindow::setApplicationState(const QByteArray& state) { @@ -1526,24 +1538,8 @@ void MainWindow::setApplicationState(const QByteArray& state) { return; currentApplicationState = state; - QList topSize = ui.topSplitter->sizes(); - QList bottomSize = ui.bottomSplitter->sizes(); - - // yes, index is zero both times. please don't change it. - if (ui.topSplitter->count() >= 2) { - ui.topSplitter->widget(0)->setParent(NULL); - ui.topSplitter->widget(0)->setParent(NULL); - } - if (ui.bottomSplitter->count() >= 2) { - ui.bottomSplitter->widget(0)->setParent(NULL); - ui.bottomSplitter->widget(0)->setParent(NULL); - } - - WidgetForBorder curr = applicationState[state]; - ui.topSplitter->addWidget(curr.topLeft); - ui.topSplitter->addWidget(curr.topRight); - ui.bottomSplitter->addWidget(curr.bottomLeft); - ui.bottomSplitter->addWidget(curr.bottomRight); - ui.topSplitter->setSizes(topSize); - ui.bottomSplitter->setSizes(bottomSize); + ui.topLeft->setCurrentWidget( applicationState[state].topLeft); + ui.bottomLeft->setCurrentWidget( applicationState[state].bottomLeft); + ui.topRight->setCurrentWidget( applicationState[state].topRight); + ui.bottomRight->setCurrentWidget( applicationState[state].bottomRight); } diff --git a/qt-ui/mainwindow.ui b/qt-ui/mainwindow.ui index ac0e92d94..ced02c964 100644 --- a/qt-ui/mainwindow.ui +++ b/qt-ui/mainwindow.ui @@ -6,8 +6,8 @@ 0 0 - 1682 - 1151 + 861 + 800 @@ -27,11 +27,15 @@ Qt::Horizontal + + Qt::Horizontal + + @@ -45,8 +49,8 @@ 0 0 - 1682 - 25 + 861 + 32 -- cgit v1.2.3-70-g09d2