mirror of
https://github.com/Chatterino/chatterino2.git
synced 2024-11-21 22:24:07 +01:00
Fix window position/size saving
I've only tested this for the main window so far Fixes #149
This commit is contained in:
parent
02e5030475
commit
f7318a26e3
3 changed files with 52 additions and 106 deletions
|
@ -6,23 +6,22 @@
|
||||||
#include "widgets/settingsdialog.hpp"
|
#include "widgets/settingsdialog.hpp"
|
||||||
#include "widgets/split.hpp"
|
#include "widgets/split.hpp"
|
||||||
|
|
||||||
#include <QDebug>
|
|
||||||
#include <QLibrary>
|
|
||||||
#include <QPalette>
|
#include <QPalette>
|
||||||
#include <QShortcut>
|
#include <QShortcut>
|
||||||
#include <QVBoxLayout>
|
#include <QVBoxLayout>
|
||||||
#include <boost/foreach.hpp>
|
|
||||||
|
|
||||||
namespace chatterino {
|
namespace chatterino {
|
||||||
namespace widgets {
|
namespace widgets {
|
||||||
|
|
||||||
Window::Window(ChannelManager &_channelManager, ColorScheme &_colorScheme, bool _isMainWindow)
|
Window::Window(const QString &_windowName, ChannelManager &_channelManager,
|
||||||
|
ColorScheme &_colorScheme, bool _isMainWindow)
|
||||||
: BaseWidget(_colorScheme, nullptr)
|
: BaseWidget(_colorScheme, nullptr)
|
||||||
|
, windowName(_windowName)
|
||||||
|
, windowGeometry(this->windowName.toStdString())
|
||||||
, channelManager(_channelManager)
|
, channelManager(_channelManager)
|
||||||
, colorScheme(_colorScheme)
|
, colorScheme(_colorScheme)
|
||||||
, notebook(this->channelManager, this, _isMainWindow)
|
, notebook(this->channelManager, this, _isMainWindow)
|
||||||
, dpi(this->getDpiMultiplier())
|
, dpi(this->getDpiMultiplier())
|
||||||
// , windowGeometry("/windows/0/geometry")
|
|
||||||
{
|
{
|
||||||
this->initAsWindow();
|
this->initAsWindow();
|
||||||
|
|
||||||
|
@ -45,14 +44,7 @@ Window::Window(ChannelManager &_channelManager, ColorScheme &_colorScheme, bool
|
||||||
|
|
||||||
this->refreshTheme();
|
this->refreshTheme();
|
||||||
|
|
||||||
if (/*this->windowGeometry->isFilled()*/ false) {
|
this->loadGeometry();
|
||||||
// Load geometry from settings file
|
|
||||||
// this->setGeometry(this->windowGeometry.getValueRef());
|
|
||||||
} else {
|
|
||||||
// Set default geometry
|
|
||||||
// Default position is in the middle of the current monitor or the primary monitor
|
|
||||||
this->resize(1280, 800);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Initialize program-wide hotkeys
|
// Initialize program-wide hotkeys
|
||||||
{
|
{
|
||||||
|
@ -120,8 +112,12 @@ Notebook &Window::getNotebook()
|
||||||
|
|
||||||
void Window::closeEvent(QCloseEvent *)
|
void Window::closeEvent(QCloseEvent *)
|
||||||
{
|
{
|
||||||
// Save closing window position
|
const QRect &geom = this->geometry();
|
||||||
// this->windowGeometry = this->geometry();
|
|
||||||
|
this->windowGeometry.x = geom.x();
|
||||||
|
this->windowGeometry.y = geom.y();
|
||||||
|
this->windowGeometry.width = geom.width();
|
||||||
|
this->windowGeometry.height = geom.height();
|
||||||
|
|
||||||
this->closed();
|
this->closed();
|
||||||
}
|
}
|
||||||
|
@ -133,5 +129,19 @@ void Window::refreshTheme()
|
||||||
this->setPalette(palette);
|
this->setPalette(palette);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Window::loadGeometry()
|
||||||
|
{
|
||||||
|
if (!this->windowGeometry.x.isDefaultValue() && !this->windowGeometry.y.isDefaultValue()) {
|
||||||
|
this->move(this->windowGeometry.x, this->windowGeometry.y);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!this->windowGeometry.width.isDefaultValue() &&
|
||||||
|
!this->windowGeometry.height.isDefaultValue()) {
|
||||||
|
this->resize(this->windowGeometry.width, this->windowGeometry.height);
|
||||||
|
} else {
|
||||||
|
this->resize(1280, 800);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace widgets
|
} // namespace widgets
|
||||||
} // namespace chatterino
|
} // namespace chatterino
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#include "util/helpers.hpp"
|
||||||
#include "widgets/basewidget.hpp"
|
#include "widgets/basewidget.hpp"
|
||||||
#include "widgets/notebook.hpp"
|
#include "widgets/notebook.hpp"
|
||||||
#include "widgets/titlebar.hpp"
|
#include "widgets/titlebar.hpp"
|
||||||
|
@ -10,8 +11,7 @@
|
||||||
|
|
||||||
#include <boost/property_tree/ptree.hpp>
|
#include <boost/property_tree/ptree.hpp>
|
||||||
#include <boost/signals2.hpp>
|
#include <boost/signals2.hpp>
|
||||||
#include <pajlada/settings/serialize.hpp>
|
#include <pajlada/settings/setting.hpp>
|
||||||
#include <pajlada/settings/settingdata.hpp>
|
|
||||||
|
|
||||||
namespace chatterino {
|
namespace chatterino {
|
||||||
|
|
||||||
|
@ -21,12 +21,32 @@ class CompletionManager;
|
||||||
|
|
||||||
namespace widgets {
|
namespace widgets {
|
||||||
|
|
||||||
|
struct WindowGeometry {
|
||||||
|
WindowGeometry(const std::string &key)
|
||||||
|
: x(fS("/windows/{}/geometry/x", key))
|
||||||
|
, y(fS("/windows/{}/geometry/y", key))
|
||||||
|
, width(fS("/windows/{}/geometry/width", key))
|
||||||
|
, height(fS("/windows/{}/geometry/height", key))
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
pajlada::Settings::Setting<int> x;
|
||||||
|
pajlada::Settings::Setting<int> y;
|
||||||
|
pajlada::Settings::Setting<int> width;
|
||||||
|
pajlada::Settings::Setting<int> height;
|
||||||
|
};
|
||||||
|
|
||||||
class Window : public BaseWidget
|
class Window : public BaseWidget
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
|
|
||||||
|
QString windowName;
|
||||||
|
|
||||||
|
WindowGeometry windowGeometry;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
explicit Window(ChannelManager &_channelManager, ColorScheme &_colorScheme, bool isMainWindow);
|
explicit Window(const QString &_windowName, ChannelManager &_channelManager,
|
||||||
|
ColorScheme &_colorScheme, bool isMainWindow);
|
||||||
|
|
||||||
void repaintVisibleChatWidgets(Channel *channel = nullptr);
|
void repaintVisibleChatWidgets(Channel *channel = nullptr);
|
||||||
|
|
||||||
|
@ -48,6 +68,8 @@ private:
|
||||||
|
|
||||||
virtual void refreshTheme() override;
|
virtual void refreshTheme() override;
|
||||||
|
|
||||||
|
void loadGeometry();
|
||||||
|
|
||||||
ChannelManager &channelManager;
|
ChannelManager &channelManager;
|
||||||
ColorScheme &colorScheme;
|
ColorScheme &colorScheme;
|
||||||
|
|
||||||
|
@ -55,92 +77,6 @@ private:
|
||||||
bool loaded = false;
|
bool loaded = false;
|
||||||
TitleBar titleBar;
|
TitleBar titleBar;
|
||||||
|
|
||||||
/*
|
|
||||||
class QRectWrapper : public pajlada::Settings::ISettingData, public QRect
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
QRectWrapper()
|
|
||||||
: QRect(-1, -1, -1, -1)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
pajlada::Signals::Signal<const QRectWrapper &> valueChanged;
|
|
||||||
|
|
||||||
const QRectWrapper &getValueRef() const
|
|
||||||
{
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual rapidjson::Value marshalInto(rapidjson::Document &d) override
|
|
||||||
{
|
|
||||||
using namespace pajlada::Settings;
|
|
||||||
|
|
||||||
rapidjson::Value obj(rapidjson::kObjectType);
|
|
||||||
|
|
||||||
auto _x = serializeToJSON<int>::serialize(this->x(), d.GetAllocator());
|
|
||||||
auto _y = serializeToJSON<int>::serialize(this->y(), d.GetAllocator());
|
|
||||||
auto _width = serializeToJSON<int>::serialize(this->width(), d.GetAllocator());
|
|
||||||
auto _height = serializeToJSON<int>::serialize(this->height(), d.GetAllocator());
|
|
||||||
|
|
||||||
obj.AddMember("x", _x, d.GetAllocator());
|
|
||||||
obj.AddMember("y", _y, d.GetAllocator());
|
|
||||||
obj.AddMember("width", _width, d.GetAllocator());
|
|
||||||
obj.AddMember("height", _height, d.GetAllocator());
|
|
||||||
|
|
||||||
return obj;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual bool unmarshalFrom(rapidjson::Document &document) override
|
|
||||||
{
|
|
||||||
using namespace pajlada::Settings;
|
|
||||||
|
|
||||||
auto vXp = this->getValueWithSuffix("/x", document);
|
|
||||||
auto vYp = this->getValueWithSuffix("/y", document);
|
|
||||||
auto vWidthp = this->getValueWithSuffix("/width", document);
|
|
||||||
auto vHeightp = this->getValueWithSuffix("/height", document);
|
|
||||||
if (vXp != nullptr) {
|
|
||||||
this->setX(deserializeJSON<int>::deserialize(*vXp));
|
|
||||||
this->filled = true;
|
|
||||||
}
|
|
||||||
if (vYp != nullptr) {
|
|
||||||
this->setY(deserializeJSON<int>::deserialize(*vYp));
|
|
||||||
this->filled = true;
|
|
||||||
}
|
|
||||||
if (vWidthp != nullptr) {
|
|
||||||
this->setWidth(deserializeJSON<int>::deserialize(*vWidthp));
|
|
||||||
this->filled = true;
|
|
||||||
}
|
|
||||||
if (vHeightp != nullptr) {
|
|
||||||
this->setHeight(deserializeJSON<int>::deserialize(*vHeightp));
|
|
||||||
this->filled = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual void registerDocument(rapidjson::Document &d) override
|
|
||||||
{
|
|
||||||
this->valueChanged.connect([this, &d](const auto &) {
|
|
||||||
this->marshalInto(d); //
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
QRectWrapper &operator=(const QRect &rhs)
|
|
||||||
{
|
|
||||||
static_cast<QRect &>(*this) = rhs;
|
|
||||||
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
void setValue(const QRect &rhs)
|
|
||||||
{
|
|
||||||
static_cast<QRect &>(*this) = rhs;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
*/
|
|
||||||
|
|
||||||
// pajlada::Settings::Setting<QRectWrapper> windowGeometry;
|
|
||||||
|
|
||||||
friend class Notebook;
|
friend class Notebook;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -22,7 +22,7 @@ WindowManager::WindowManager(ChannelManager &_channelManager, ColorScheme &_colo
|
||||||
void WindowManager::initMainWindow()
|
void WindowManager::initMainWindow()
|
||||||
{
|
{
|
||||||
this->selectedWindow = this->mainWindow =
|
this->selectedWindow = this->mainWindow =
|
||||||
new widgets::Window(this->channelManager, this->colorScheme, true);
|
new widgets::Window("main", this->channelManager, this->colorScheme, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
static const std::string &getSettingsPath()
|
static const std::string &getSettingsPath()
|
||||||
|
@ -68,7 +68,7 @@ widgets::Window &WindowManager::getSelectedWindow()
|
||||||
|
|
||||||
widgets::Window &WindowManager::createWindow()
|
widgets::Window &WindowManager::createWindow()
|
||||||
{
|
{
|
||||||
auto *window = new widgets::Window(this->channelManager, this->colorScheme, false);
|
auto *window = new widgets::Window("external", this->channelManager, this->colorScheme, false);
|
||||||
|
|
||||||
window->loadDefaults();
|
window->loadDefaults();
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue