1
0
mirror of https://github.com/vcmi/vcmi.git synced 2025-01-04 00:15:53 +02:00
vcmi/launcher/mainwindow_moc.cpp

239 lines
6.1 KiB
C++
Raw Normal View History

/*
* mainwindow_moc.cpp, part of VCMI engine
*
* Authors: listed in file AUTHORS in main folder
*
* License: GNU General Public License v2.0 or later
* Full text of license available in license.txt file, in main folder
*
*/
#include "StdInc.h"
#include "mainwindow_moc.h"
#include "ui_mainwindow_moc.h"
#include <QDir>
#include "../lib/CConfigHandler.h"
#include "../lib/VCMIDirs.h"
#include "../lib/filesystem/Filesystem.h"
#include "../lib/logging/CBasicLogConfigurator.h"
#include "updatedialog_moc.h"
#include "main.h"
void MainWindow::load()
{
// Set current working dir to executable folder.
// This is important on Mac for relative paths to work inside DMG.
QDir::setCurrent(QApplication::applicationDirPath());
#ifndef VCMI_IOS
console = new CConsoleHandler();
#endif
2022-09-17 15:56:01 +02:00
CBasicLogConfigurator logConfig(VCMIDirs::get().userLogsPath() / "VCMI_Launcher_log.txt", console);
logConfig.configureDefault();
CResourceHandler::initialize();
CResourceHandler::load("config/filesystem.json");
#ifdef Q_OS_IOS
QDir::addSearchPath("icons", pathToQString(VCMIDirs::get().binaryPath() / "icons"));
#else
for(auto & string : VCMIDirs::get().dataPaths())
QDir::addSearchPath("icons", pathToQString(string / "launcher" / "icons"));
QDir::addSearchPath("icons", pathToQString(VCMIDirs::get().userDataPath() / "launcher" / "icons"));
#endif
settings.init();
}
void MainWindow::computeSidePanelSizes()
{
QVector<QToolButton*> widgets = {
ui->modslistButton,
ui->settingsButton,
ui->lobbyButton,
ui->startEditorButton,
ui->startGameButton
};
for(auto & widget : widgets)
{
QFontMetrics metrics(widget->font());
QSize iconSize = widget->iconSize();
// this is minimal space that is needed for our button to avoid text clipping
int buttonHeight = iconSize.height() + metrics.height() + 4;
widget->setMinimumHeight(buttonHeight);
widget->setMaximumHeight(buttonHeight * 1.2);
}
}
MainWindow::MainWindow(QWidget * parent)
: QMainWindow(parent), ui(new Ui::MainWindow)
{
load(); // load FS before UI
2022-12-25 23:06:22 +02:00
updateTranslation(); // load translation
ui->setupUi(this);
2022-12-26 02:34:10 +02:00
connect(ui->lobbyView, &Lobby::enableMod, ui->modlistView, &CModListView::enableModByName);
connect(ui->lobbyView, &Lobby::disableMod, ui->modlistView, &CModListView::disableModByName);
connect(ui->modlistView, &CModListView::modsChanged, ui->lobbyView, &Lobby::updateMods);
2019-07-30 08:32:35 +02:00
//load window settings
QSettings s(Ui::teamName, Ui::appName);
auto size = s.value("MainWindow/Size").toSize();
2019-07-30 11:00:44 +02:00
if(size.isValid())
2019-07-30 08:32:35 +02:00
{
resize(size);
}
auto position = s.value("MainWindow/Position").toPoint();
2019-07-30 11:00:44 +02:00
if(!position.isNull())
2019-07-30 08:32:35 +02:00
{
move(position);
}
#ifndef ENABLE_EDITOR
ui->startEditorButton->hide();
#endif
computeSidePanelSizes();
2019-07-30 08:32:35 +02:00
2023-03-11 00:57:55 +02:00
bool h3DataFound = CResourceHandler::get()->existsResource(ResourceID("DATA/GENRLTXT.TXT"));
bool setupCompleted = settings["launcher"]["setupCompleted"].Bool();
if (h3DataFound && setupCompleted)
ui->tabListWidget->setCurrentIndex(TabRows::MODS);
else
2023-03-12 18:33:29 +02:00
enterSetup();
2022-11-16 21:53:54 +02:00
ui->settingsView->isExtraResolutionsModEnabled = ui->modlistView->isExtraResolutionsModEnabled();
ui->settingsView->setDisplayList();
2022-11-16 21:53:54 +02:00
connect(ui->modlistView, &CModListView::extraResolutionsEnabledChanged,
ui->settingsView, &CSettingsView::fillValidResolutions);
2022-11-22 01:36:27 +02:00
if(settings["launcher"]["updateOnStartup"].Bool())
UpdateDialog::showUpdateDialog(false);
}
2023-03-12 18:33:29 +02:00
void MainWindow::enterSetup()
{
ui->startGameButton->setEnabled(false);
ui->startEditorButton->setEnabled(false);
ui->lobbyButton->setEnabled(false);
ui->settingsButton->setEnabled(false);
ui->modslistButton->setEnabled(false);
ui->tabListWidget->setCurrentIndex(TabRows::SETUP);
}
void MainWindow::exitSetup()
{
Settings writer = settings.write["launcher"]["setupCompleted"];
writer->Bool() = true;
ui->startGameButton->setEnabled(true);
ui->startEditorButton->setEnabled(true);
ui->lobbyButton->setEnabled(true);
ui->settingsButton->setEnabled(true);
ui->modslistButton->setEnabled(true);
ui->tabListWidget->setCurrentIndex(TabRows::MODS);
}
void MainWindow::switchToModsTab()
{
ui->startGameButton->setEnabled(true);
ui->tabListWidget->setCurrentIndex(TabRows::MODS);
}
void MainWindow::changeEvent(QEvent *event)
{
2022-12-29 16:37:38 +02:00
if(event->type() == QEvent::LanguageChange)
{
ui->retranslateUi(this);
}
QMainWindow::changeEvent(event);
}
MainWindow::~MainWindow()
{
2019-07-30 08:32:35 +02:00
//save window settings
QSettings s(Ui::teamName, Ui::appName);
s.setValue("MainWindow/Size", size());
s.setValue("MainWindow/Position", pos());
delete ui;
}
void MainWindow::on_startGameButton_clicked()
{
startGame({});
}
2022-11-17 01:15:26 +02:00
void MainWindow::on_startEditorButton_clicked()
2022-11-27 03:35:05 +02:00
{
startEditor({});
2022-11-27 03:35:05 +02:00
}
2022-11-17 01:15:26 +02:00
const CModList & MainWindow::getModList() const
{
return ui->modlistView->getModList();
}
2022-11-27 03:35:05 +02:00
2023-03-11 00:57:55 +02:00
CModListView * MainWindow::getModView()
{
return ui->modlistView;
}
void MainWindow::on_modslistButton_clicked()
2022-11-17 01:15:26 +02:00
{
switchToModsTab();
}
void MainWindow::on_settingsButton_clicked()
{
ui->startGameButton->setEnabled(true);
ui->tabListWidget->setCurrentIndex(TabRows::SETTINGS);
}
void MainWindow::on_lobbyButton_clicked()
{
ui->startGameButton->setEnabled(false);
ui->tabListWidget->setCurrentIndex(TabRows::LOBBY);
2022-11-17 01:15:26 +02:00
}
void MainWindow::updateTranslation()
{
#ifdef ENABLE_QT_TRANSLATIONS
2023-01-07 18:01:39 +02:00
std::string translationFile = settings["general"]["language"].String() + ".qm";
2023-01-15 23:54:27 +02:00
logGlobal->info("Loading translation '%s'", translationFile);
2022-12-29 16:37:03 +02:00
QVector<QString> searchPaths;
2023-01-16 22:37:19 +02:00
#ifdef Q_OS_IOS
searchPaths.push_back(pathToQString(VCMIDirs::get().binaryPath() / "translation" / translationFile));
#else
2022-12-29 16:37:03 +02:00
for(auto const & string : VCMIDirs::get().dataPaths())
searchPaths.push_back(pathToQString(string / "launcher" / "translation" / translationFile));
searchPaths.push_back(pathToQString(VCMIDirs::get().userDataPath() / "launcher" / "translation" / translationFile));
2023-01-16 22:37:19 +02:00
#endif
2022-12-29 16:37:03 +02:00
for(auto const & string : boost::adaptors::reverse(searchPaths))
{
2023-01-15 23:54:27 +02:00
logGlobal->info("Searching for translation at '%s'", string.toStdString());
2022-12-29 16:37:03 +02:00
if (translator.load(string))
{
2023-01-15 23:54:27 +02:00
logGlobal->info("Translation found");
2022-12-29 16:37:03 +02:00
if (!qApp->installTranslator(&translator))
logGlobal->error("Failed to install translator");
return;
}
}
logGlobal->error("Failed to find translation");
#endif
}