From ce94cb38ec38ce5a304b3bab1b9a2d903e1d15e9 Mon Sep 17 00:00:00 2001 From: Aleks Kissinger Date: Fri, 25 Jan 2019 14:56:15 +0100 Subject: set window geometry after showing it for the first time --- src/gui/mainwindow.cpp | 33 +++++++++++++++++++++------------ src/gui/mainwindow.h | 1 + src/gui/previewwindow.cpp | 23 ++++++++++++++++------- src/gui/previewwindow.h | 2 ++ 4 files changed, 40 insertions(+), 19 deletions(-) (limited to 'src/gui') diff --git a/src/gui/mainwindow.cpp b/src/gui/mainwindow.cpp index 71fea63..71b9070 100644 --- a/src/gui/mainwindow.cpp +++ b/src/gui/mainwindow.cpp @@ -46,19 +46,7 @@ MainWindow::MainWindow(QWidget *parent) : _menu->setParent(this); setMenuBar(_menu); - QVariant geom = settings.value(QString("geometry-main-qt") + qVersion()); - QVariant state = settings.value(QString("windowState-main-qt") + qVersion()); - - if (geom.isValid()) { - restoreGeometry(geom.toByteArray()); - } - if (state.isValid()) { - restoreState(state.toByteArray(), 2); - } else { - addDockWidget(Qt::RightDockWidgetArea, _stylePalette); - resizeDocks({_stylePalette}, {130}, Qt::Horizontal); - } // initially, the source view should be collapsed QList sz = ui->splitter->sizes(); @@ -76,6 +64,15 @@ MainWindow::MainWindow(QWidget *parent) : #else ui->tikzSource->setTabStopWidth(20); #endif + + + QVariant state = settings.value(QString("windowState-main-qt") + qVersion()); + if (state.isValid()) { + restoreState(state.toByteArray(), 2); + } else { + addDockWidget(Qt::RightDockWidgetArea, _stylePalette); + resizeDocks({_stylePalette}, {130}, Qt::Horizontal); + } } MainWindow::~MainWindow() @@ -84,6 +81,18 @@ MainWindow::~MainWindow() delete ui; } +void MainWindow::restorePosition() +{ + QSettings settings("tikzit", "tikzit"); + QVariant geom = settings.value(QString("geometry-main-qt") + qVersion()); + + if (geom.isValid()) { + restoreGeometry(geom.toByteArray()); + } + + +} + void MainWindow::open(QString fileName) { _tikzDocument->open(fileName); diff --git a/src/gui/mainwindow.h b/src/gui/mainwindow.h index 21fbd5a..48a88dd 100644 --- a/src/gui/mainwindow.h +++ b/src/gui/mainwindow.h @@ -29,6 +29,7 @@ public: explicit MainWindow(QWidget *parent = 0); ~MainWindow(); + void restorePosition(); void open(QString fileName); int windowId() const; TikzView *tikzView() const; diff --git a/src/gui/previewwindow.cpp b/src/gui/previewwindow.cpp index acce1a1..4906484 100644 --- a/src/gui/previewwindow.cpp +++ b/src/gui/previewwindow.cpp @@ -41,15 +41,10 @@ PreviewWindow::PreviewWindow(QWidget *parent) : QDialog(parent), ui(new Ui::PreviewWindow) { - QSettings settings("tikzit", "tikzit"); - ui->setupUi(this); - QVariant geom = settings.value(QString("geometry-preview-qt") + qVersion()); - - if (geom.isValid()) { - restoreGeometry(geom.toByteArray()); - } + ui->setupUi(this); + _positionRestored = false; _doc = nullptr; _loader = new QLabel(ui->tabWidget->tabBar()); @@ -90,6 +85,20 @@ PreviewWindow::~PreviewWindow() delete ui; } +void PreviewWindow::restorePosition() +{ + // only restore position 1 time + if (_positionRestored) return; + + QSettings settings("tikzit", "tikzit"); + QVariant geom = settings.value(QString("geometry-preview-qt") + qVersion()); + + if (geom.isValid()) { + restoreGeometry(geom.toByteArray()); + } + _positionRestored = true; +} + void PreviewWindow::setPdf(QString file) { // use loadFromData to avoid holding a lock on the PDF file in windows diff --git a/src/gui/previewwindow.h b/src/gui/previewwindow.h index a14303b..0cb10aa 100644 --- a/src/gui/previewwindow.h +++ b/src/gui/previewwindow.h @@ -46,6 +46,7 @@ public: }; explicit PreviewWindow(QWidget *parent = nullptr); ~PreviewWindow() override; + void restorePosition(); void setPdf(QString file); QString preparePreview(QString tikz); QPlainTextEdit *outputTextEdit(); @@ -67,6 +68,7 @@ private: Ui::PreviewWindow *ui; PdfDocument *_doc; QLabel *_loader; + bool _positionRestored; }; #endif // PREVIEWWINDOW_H -- cgit v1.2.3