1
0
mirror of https://github.com/qTox/qTox.git synced 2024-03-22 14:00:36 +08:00

Window geometry saved when window is resized Splitter position saved when splitter is moved

Fixed restoring of window geometry when "Start in tray" is unchecked
This commit is contained in:
novist 2014-11-28 11:16:37 +02:00 committed by Dubslow
parent 90e8afa24d
commit 0810559bcb
2 changed files with 37 additions and 10 deletions

View File

@ -73,7 +73,12 @@ Widget::Widget(QWidget *parent)
void Widget::init()
{
ui->setupUi(this);
//restore window state
restoreGeometry(Settings::getInstance().getWindowGeometry());
restoreState(Settings::getInstance().getWindowState());
ui->mainSplitter->restoreState(Settings::getInstance().getSplitterState());
if (QSystemTrayIcon::isSystemTrayAvailable())
{
icon = new QSystemTrayIcon(this);
@ -127,11 +132,6 @@ void Widget::init()
idleTimer->setSingleShot(true);
setIdleTimer(Settings::getInstance().getAutoAwayTime());
//restore window state
restoreGeometry(Settings::getInstance().getWindowGeometry());
restoreState(Settings::getInstance().getWindowState());
ui->mainSplitter->restoreState(Settings::getInstance().getSplitterState());
layout()->setContentsMargins(0, 0, 0, 0);
ui->friendList->setStyleSheet(Style::resolve(Style::getStylesheet(":ui/friendList/friendList.css")));
@ -257,6 +257,7 @@ void Widget::init()
connect(ui->settingsButton, SIGNAL(clicked()), this, SLOT(onSettingsClicked()));
connect(ui->nameLabel, SIGNAL(textChanged(QString, QString)), this, SLOT(onUsernameChanged(QString, QString)));
connect(ui->statusLabel, SIGNAL(textChanged(QString, QString)), this, SLOT(onStatusMessageChanged(QString, QString)));
connect(ui->mainSplitter, &QSplitter::splitterMoved, this, &Widget::onSplitterMoved);
connect(profilePicture, SIGNAL(clicked()), this, SLOT(onAvatarClicked()));
connect(setStatusOnline, SIGNAL(triggered()), this, SLOT(setStatusOnline()));
connect(setStatusAway, SIGNAL(triggered()), this, SLOT(setStatusAway()));
@ -336,9 +337,8 @@ void Widget::closeEvent(QCloseEvent *event)
}
else
{
Settings::getInstance().setWindowGeometry(saveGeometry());
Settings::getInstance().setWindowState(saveState());
Settings::getInstance().setSplitterState(ui->mainSplitter->saveState());
saveWindowGeometry();
saveSplitterGeometry();
QWidget::closeEvent(event);
}
}
@ -354,6 +354,12 @@ void Widget::changeEvent(QEvent *event)
}
}
void Widget::resizeEvent(QResizeEvent *event)
{
Q_UNUSED(event);
saveWindowGeometry();
}
QString Widget::detectProfile()
{
QDir dir(Settings::getSettingsDirPath());
@ -1008,6 +1014,17 @@ void Widget::removeGroup(Group* g, bool fake)
contactListWidget->show();
}
void Widget::saveWindowGeometry()
{
Settings::getInstance().setWindowGeometry(saveGeometry());
Settings::getInstance().setWindowState(saveState());
}
void Widget::saveSplitterGeometry()
{
Settings::getInstance().setSplitterState(ui->mainSplitter->saveState());
}
void Widget::removeGroup(int groupId)
{
removeGroup(GroupList::findGroup(groupId));
@ -1157,6 +1174,12 @@ void Widget::onSetShowSystemTray(bool newValue){
icon->setVisible(newValue);
}
void Widget::onSplitterMoved(int pos, int index)
{
Q_UNUSED(pos);
Q_UNUSED(index);
saveSplitterGeometry();
}
QMessageBox::StandardButton Widget::showWarningMsgBox(const QString& title, const QString& msg, QMessageBox::StandardButtons buttons)
{

View File

@ -72,7 +72,8 @@ public:
virtual void closeEvent(QCloseEvent *event);
virtual void changeEvent(QEvent *event);
virtual void resizeEvent(QResizeEvent *event);
void clearAllReceipts();
void reloadTheme();
@ -132,6 +133,7 @@ private slots:
void onUserAway();
void getPassword(QString info, int passtype, uint8_t* salt);
void onSetShowSystemTray(bool newValue);
void onSplitterMoved(int pos, int index);
private:
void init();
@ -140,6 +142,8 @@ private:
Group* createGroup(int groupId);
void removeFriend(Friend* f, bool fake = false);
void removeGroup(Group* g, bool fake = false);
void saveWindowGeometry();
void saveSplitterGeometry();
QString askProfiles();
QString detectProfile();
QSystemTrayIcon *icon;