mirror of
https://gitea.msk.dinamika-avia.ru/Constanta-Design/RRJClient.git
synced 2026-03-28 05:25:39 +03:00
560 lines
15 KiB
C++
560 lines
15 KiB
C++
#include "mainwindow.h"
|
|
#include "ui_mainwindow.h"
|
|
#include "updatenotifywidget.h"
|
|
|
|
#include <QFontDatabase>
|
|
#include <QMessageBox>
|
|
#include <QMovie>
|
|
#include <QPaintEvent>
|
|
#include <QPainter>
|
|
#include <QTimer>
|
|
|
|
MainWindow::MainWindow(QWidget *parent)
|
|
: QMainWindow(parent)
|
|
, ui(new Ui::MainWindow)
|
|
{
|
|
ui->setupUi(this);
|
|
isRecovery = false;
|
|
setWindowFlag(Qt::FramelessWindowHint);
|
|
painting();
|
|
}
|
|
|
|
void MainWindow::initialize()
|
|
{
|
|
createObjects();
|
|
|
|
updateTextWidget->initialize();
|
|
entryWidget->initialize(this);
|
|
versionSelectWidget->initialize();
|
|
hashComparer->initialize(this);
|
|
updateController->initialize(this);
|
|
|
|
commonButtonGroupWidget->initialize(externalExecuter,sendSystem,client);
|
|
commonButtonGroupWidget->show();
|
|
|
|
instructorButtonGroupWidget->initialize(this);
|
|
|
|
ui->notificationLabel->hide();
|
|
|
|
ui->offlineStartButton->show();
|
|
ui->offlineStartButton->setEnabled(false);
|
|
ui->offlineStartButton->setGeometry(540,549,250,40);
|
|
|
|
ui->displayGroupWidget->show();
|
|
ui->autostartCheckBox->hide();
|
|
bindConnection();
|
|
|
|
sendSystem->initialize(this,dataParser);
|
|
dataParser->initialize(recognizeSystem);
|
|
emit sigCalculateHash();
|
|
emit sigInitializeClient(this,recognizeSystem,externalExecuter,sendSystem,workerThread);
|
|
emit sigRecognize(updateController,dataParser,this,hashComparer,client);
|
|
|
|
screenChecker->check();
|
|
|
|
loadStaticData();
|
|
emit sigSetConnect(dataParser->getServerSettings(),workerThread);
|
|
|
|
checkAppAvailable();
|
|
|
|
//test
|
|
|
|
}
|
|
|
|
void MainWindow::createObjects()
|
|
{
|
|
updateWidget = new UpdateNotifyWidget;
|
|
commonButtonGroupWidget = new CommonButtonGroupWidget;
|
|
instructorButtonGroupWidget = new InstructorButtonGroupWidget;
|
|
updateTextWidget = new UpdateWidget;
|
|
entryWidget = new EntryWidget;
|
|
versionSelectWidget = new VersionSelectWidget;
|
|
|
|
ui->changButtonGroup->addWidget(commonButtonGroupWidget);
|
|
ui->changButtonGroup->addWidget(instructorButtonGroupWidget);
|
|
|
|
ui->interactiveGroup->addWidget(entryWidget);
|
|
ui->interactiveGroup->addWidget(updateTextWidget);
|
|
ui->interactiveGroup->addWidget(versionSelectWidget);
|
|
|
|
workerThread = new QThread;
|
|
animationThread = new QThread;
|
|
|
|
client = new TCPClient;
|
|
client->moveToThread(workerThread);
|
|
|
|
dataParser = new DataParser;
|
|
dataParser->moveToThread(workerThread);
|
|
|
|
sendSystem = new SendSystem;
|
|
sendSystem->moveToThread(workerThread);
|
|
|
|
updateController = new UpdateController(dataParser,sendSystem);
|
|
updateController->moveToThread(workerThread);
|
|
|
|
recognizeSystem = new RecognizeSystem;
|
|
recognizeSystem->moveToThread(workerThread);
|
|
|
|
screenChecker = new ScreenChecker(this,dataParser,ui->displayLayout);
|
|
externalExecuter = new ExternalExecuter;
|
|
|
|
hashComparer = new HashComparer(dataParser);
|
|
hashComparer->moveToThread(workerThread);
|
|
|
|
workerThread->start();
|
|
workerThread->setPriority(QThread::HighestPriority);
|
|
|
|
timer = new QTimer;
|
|
}
|
|
|
|
void MainWindow::bindConnection()
|
|
{
|
|
connect(timer,&QTimer::timeout,this,&MainWindow::slotDisableNotify);
|
|
|
|
connect(this,&MainWindow::sigUpdateFilesOnServer,updateController,&UpdateController::updateFilesOnServer);
|
|
connect(this,&MainWindow::sigInitializeClient,client,&TCPClient::initialize,Qt::AutoConnection);
|
|
connect(this,&MainWindow::sigSetConnect,client,&TCPClient::setConnect,Qt::AutoConnection);
|
|
connect(this,&MainWindow::sigSendCommand,client,&TCPClient::slotSendCommand,Qt::AutoConnection);
|
|
connect(this,&MainWindow::sigSendXMLAnswer,sendSystem,&SendSystem::xmlAnswer,Qt::AutoConnection);
|
|
connect(this,&MainWindow::sigRecognize,recognizeSystem,&RecognizeSystem::initialize,Qt::AutoConnection);
|
|
|
|
connect(this,&MainWindow::sigGetConnected,client,&TCPClient::getIsConnected);
|
|
connect(this,&MainWindow::sigCalculateHash,updateController,&UpdateController::calculateCommonHash);
|
|
connect(this,&MainWindow::sigSendAutorization,sendSystem,&SendSystem::sendClientAutorization);
|
|
}
|
|
|
|
void MainWindow::updateProgress()
|
|
{
|
|
filesLoaded++;
|
|
float value = 100 / ((float)fileCountForUpdate / filesLoaded);
|
|
commonButtonGroupWidget->updateProgressBar(value);
|
|
}
|
|
|
|
void MainWindow::loadComplete()
|
|
{
|
|
externalExecuter->findApp();
|
|
commonButtonGroupWidget->loadCompleteState();
|
|
autoStart();
|
|
ui->inlineTextDebug->setText(tr("Обновление завершено"));
|
|
ui->offlineStartButton->setEnabled(true);
|
|
ui->autostartCheckBox->hide();
|
|
ui->offlineStartButton->show();
|
|
}
|
|
|
|
void MainWindow::setNeedUpdate(bool flag,quint64 size, quint64 fileCount)
|
|
{
|
|
fileCountForUpdate = 0;
|
|
filesLoaded = 0;
|
|
fileCountForUpdate = fileCount;
|
|
QString availableSizeText;
|
|
|
|
if (flag && isRecovery)
|
|
{
|
|
ui->inlineTextDebug->setText(tr("Восстановление версии..."));
|
|
|
|
}
|
|
else if(flag)
|
|
{
|
|
QString result = tr("Доступно обновление: ") + Tools::convertFileSize(size);
|
|
result += tr("Количество файлов: ") + QString::number(fileCount);
|
|
ui->inlineTextDebug->setText(result);
|
|
commonButtonGroupWidget->needUpdateState(flag);
|
|
ui->autostartCheckBox->show();
|
|
stopLoadingMovie();
|
|
}
|
|
else
|
|
{
|
|
ui->inlineTextDebug->setText(tr("Установлена последняя версия"));
|
|
autoStart();
|
|
commonButtonGroupWidget->lastVerInstalledState();
|
|
ui->offlineStartButton->setEnabled(true);
|
|
stopLoadingMovie();
|
|
}
|
|
}
|
|
|
|
void MainWindow::lostConnection()
|
|
{
|
|
commonButtonGroupWidget->updateProgressBar(0);
|
|
slotConnectionState(false);
|
|
}
|
|
|
|
void MainWindow::serverBlocked()
|
|
{
|
|
ui->notificationLabel->show();
|
|
QPalette palette = ui->notificationLabel->palette();
|
|
QColor orangeColor(255,165,0);
|
|
palette.setColor(ui->notificationLabel->foregroundRole(),orangeColor);
|
|
ui->notificationLabel->setText(tr("Сервер заблокирован"));
|
|
|
|
ui->notificationLabel->setPalette(palette);
|
|
timer->start(3000);
|
|
}
|
|
|
|
void MainWindow::checkLoginResult(ServerAuthorization *serverAuth)
|
|
{
|
|
if (serverAuth->Result)
|
|
{
|
|
|
|
if (serverAuth->AccessType != "instructor") //временно для отладки загрузки на сервер
|
|
{
|
|
checkUpdate();
|
|
}
|
|
else
|
|
{
|
|
emit sigSendXMLAnswer("CHECKVERSIONLIST");
|
|
}
|
|
|
|
dataParser->createAuthData(serverAuth);
|
|
entryWidget->loginIsActive(false);
|
|
ui->LanguageWidget->hide();
|
|
ui->settingsButton->hide();
|
|
ui->offlineStartButton->show();
|
|
startLoadingAnim();
|
|
}
|
|
else
|
|
{
|
|
ui->notificationLabel->setText(tr("Неверный логин/пароль"));
|
|
timer->setInterval(3000);
|
|
timer->start();
|
|
|
|
QPalette palette = ui->notificationLabel->palette();
|
|
palette.setColor(ui->notificationLabel->foregroundRole(), Qt::red);
|
|
|
|
ui->notificationLabel->setPalette(palette);
|
|
ui->notificationLabel->show();
|
|
}
|
|
|
|
}
|
|
|
|
void MainWindow::checkAppAvailable()
|
|
{
|
|
bool isAvailable = externalExecuter->findApp();
|
|
commonButtonGroupWidget->startButtonActive(isAvailable);
|
|
ui->offlineStartButton->setEnabled(isAvailable);
|
|
}
|
|
|
|
void MainWindow::checkLanguage(QString language)
|
|
{
|
|
if (language == "RUS")
|
|
{
|
|
translator.load("QtLanguage_ru_RU",".");
|
|
}
|
|
else if(language == "ENG")
|
|
{
|
|
translator.load("QtLanguage_eng_EN",".");
|
|
}
|
|
|
|
qApp->installTranslator(&translator);
|
|
ui->retranslateUi(this);
|
|
}
|
|
|
|
void MainWindow::autoStart()
|
|
{
|
|
if(ui->autostartCheckBox->isChecked()){
|
|
startUnityClient();
|
|
}
|
|
}
|
|
|
|
void MainWindow::loadStaticData()
|
|
{
|
|
ServerSettings *currentSettings = dataParser->getServerSettings();
|
|
|
|
entryWidget->fillSettings(currentSettings);
|
|
ui->languageComboBox->setCurrentText(currentSettings->Language);
|
|
ui->autostartCheckBox->setChecked(currentSettings->isAutoStart);
|
|
|
|
checkLanguage(currentSettings->Language);
|
|
}
|
|
|
|
void MainWindow::showConnectionEmpty()
|
|
{
|
|
QPalette palette = ui->notificationLabel->palette();
|
|
palette.setColor(ui->notificationLabel->foregroundRole(),Qt::red);
|
|
ui->notificationLabel->setText(tr("Соединение отсутсвует"));
|
|
entryWidget->connectionEmptyState();
|
|
updateTextWidget->hide();
|
|
ui->offlineStartButton->show();
|
|
ui->offlineStartButton->setGeometry(280,340,250,40);
|
|
ui->settingsButton->show();
|
|
instructorButtonGroupWidget->hide();
|
|
}
|
|
|
|
void MainWindow::slotConnectionState(bool flag)
|
|
{
|
|
ui->notificationLabel->show();
|
|
QPalette palette = ui->notificationLabel->palette();
|
|
|
|
stopLoadingMovie();
|
|
|
|
if(flag)
|
|
{
|
|
palette.setColor(ui->notificationLabel->foregroundRole(),Qt::green);
|
|
ui->notificationLabel->setText(tr("Соединение установлено"));
|
|
entryWidget->loginIsActive(true);
|
|
|
|
ui->offlineStartButton->show();
|
|
ui->offlineStartButton->setGeometry(540,549,250,40);
|
|
}
|
|
else
|
|
{
|
|
showConnectionEmpty();
|
|
}
|
|
|
|
ui->notificationLabel->setPalette(palette);
|
|
timer->start(3000);
|
|
}
|
|
|
|
void MainWindow::slotServerDisconnect()
|
|
{
|
|
commonButtonGroupWidget->disconnectState();
|
|
ui->autostartCheckBox->hide();
|
|
ui->inlineTextDebug->setText("");
|
|
slotConnectionState(false);
|
|
}
|
|
|
|
void MainWindow::slotDisableNotify()
|
|
{
|
|
ui->notificationLabel->hide();
|
|
|
|
QPalette palette = ui->notificationLabel->palette();
|
|
palette.setColor(ui->notificationLabel->foregroundRole(), Qt::black);
|
|
|
|
ui->notificationLabel->setPalette(palette);
|
|
timer->stop();
|
|
}
|
|
|
|
void MainWindow::callUpdateList()
|
|
{
|
|
hashComparer->setWidget(updateWidget);
|
|
//QByteArray answer = dataParser->xmlAnswer_notify("GETSERVERDATALIST");
|
|
emit sigSendXMLAnswer("GETSERVERDATALIST");
|
|
updateWidget->initialize(this);
|
|
}
|
|
|
|
|
|
void MainWindow::login()
|
|
{
|
|
if (!client->getIsConnected())
|
|
{
|
|
showConnectionEmpty();
|
|
return;
|
|
}
|
|
|
|
entryWidget->loginIsActive(false);
|
|
ClientAutorization *autorization = entryWidget->getAuthData();
|
|
dataParser->createAuthMessage(autorization);
|
|
emit sigSendAutorization();
|
|
|
|
}
|
|
|
|
void MainWindow::saveServerSettingsWithConnect()
|
|
{
|
|
startLoadingAnim();
|
|
entryWidget->settingsWidgetIsActive(false);
|
|
|
|
if(client->getIsConnected())
|
|
{
|
|
entryWidget->loginIsActive(true);
|
|
ui->offlineStartButton->show();
|
|
stopLoadingMovie();
|
|
return;
|
|
}
|
|
//TODO: не заполняется 2 поля (автостарт и язык)
|
|
ServerSettings *settings = entryWidget->getServerSettings();
|
|
dataParser->createServerSettings(settings);
|
|
|
|
emit sigSetConnect(settings,workerThread);
|
|
}
|
|
|
|
void MainWindow::on_settingsButton_clicked()
|
|
{
|
|
entryWidget->settingsState();
|
|
ui->offlineStartButton->hide();
|
|
}
|
|
|
|
void MainWindow::on_languageComboBox_activated(const QString &arg1)
|
|
{
|
|
qDebug() << arg1;
|
|
dataParser->saveClientSettrings(arg1,ui->autostartCheckBox->isChecked());
|
|
checkLanguage(arg1);
|
|
ui->retranslateUi(this);
|
|
}
|
|
|
|
void MainWindow::loadToServer()
|
|
{
|
|
ui->inlineTextDebug->setText(tr("Отправка файлов..."));
|
|
commonButtonGroupWidget->showProgressBar(true);
|
|
instructorButtonGroupWidget->hide();
|
|
ui->offlineStartButton->setEnabled(false);
|
|
updateTextWidget->hide();
|
|
emit sigUpdateFilesOnServer(hashComparer->getFilesForUpdate());
|
|
}
|
|
|
|
void MainWindow::undoCurrentChanges()
|
|
{
|
|
isRecovery = true;
|
|
emit sigSendCommand("check");
|
|
|
|
commonButtonGroupWidget->showProgressBar(true);
|
|
ui->offlineStartButton->setEnabled(false);
|
|
instructorButtonGroupWidget->hide();
|
|
updateTextWidget->hide();
|
|
|
|
startLoadingAnim();
|
|
|
|
//delay
|
|
|
|
QTime dieTime= QTime::currentTime().addSecs(10);
|
|
while (QTime::currentTime() < dieTime)
|
|
QCoreApplication::processEvents(QEventLoop::AllEvents, 100);
|
|
|
|
startLoadingAnim();
|
|
|
|
emit sigSendCommand("update");
|
|
commonButtonGroupWidget->startUpdateState();
|
|
|
|
isRecovery = false;
|
|
stopLoadingMovie();
|
|
}
|
|
|
|
void MainWindow::on_updateListGuideLabel_linkActivated(const QString &)
|
|
{
|
|
updateWidget->show();
|
|
}
|
|
|
|
void MainWindow::on_offlineStartButton_clicked()
|
|
{
|
|
QString username = "offlineUser";
|
|
QString password = "000000";
|
|
|
|
dataParser->createAuthDataOffline(username,password);
|
|
startUnityClient();
|
|
}
|
|
|
|
void MainWindow::on_exitButton_clicked()
|
|
{
|
|
exit(0);
|
|
}
|
|
|
|
void MainWindow::checkUpdate()
|
|
{
|
|
emit sigSendCommand("check");
|
|
ui->inlineTextDebug->setText(tr("Проверка обновлений..."));
|
|
}
|
|
|
|
void MainWindow::showUpdateInfo()
|
|
{
|
|
stopLoadingMovie();
|
|
updateTextWidget->showWithFill();
|
|
entryWidget->hide();
|
|
commonButtonGroupWidget->hide();
|
|
instructorButtonGroupWidget->show();
|
|
ui->offlineStartButton->setGeometry(540,549,250,40);
|
|
fileCountForUpdate = hashComparer->getFilesForUpdate()->length();
|
|
|
|
filesLoaded = 0;
|
|
}
|
|
|
|
void MainWindow::showCompleteDialogBox()
|
|
{
|
|
ui->inlineTextDebug->setText(tr("Загрузка завершена"));
|
|
startLoadingAnim();
|
|
|
|
QTime dieTime= QTime::currentTime().addSecs(10);
|
|
while (QTime::currentTime() < dieTime)
|
|
QCoreApplication::processEvents(QEventLoop::AllEvents, 100);
|
|
|
|
stopLoadingMovie();
|
|
checkUpdate();
|
|
}
|
|
|
|
void MainWindow::startUnityClient()
|
|
{
|
|
externalExecuter->callApp();
|
|
emit sigSendXMLAnswer("DISABLE");
|
|
}
|
|
|
|
void MainWindow::keyPressEvent(QKeyEvent *event)
|
|
{
|
|
if (event->key() == Qt::Key_Enter || event->key() == Qt::Key_Return)
|
|
{
|
|
if (entryWidget->isLoginFieldsFill()) return;
|
|
login();
|
|
}
|
|
}
|
|
|
|
void MainWindow::painting()
|
|
{
|
|
QFontDatabase::addApplicationFont(":/resource/Fonts/Kanit Cyrillic.ttf");
|
|
QFontDatabase::addApplicationFont(":/resource/Fonts/HelveticaNeue-Medium.ttf");
|
|
|
|
//settings
|
|
QPixmap settingIcon(":resource/Icons/settingWhite.png");
|
|
QPainter painter;
|
|
QColor color(45,84,130);
|
|
|
|
painter.begin(&settingIcon);
|
|
painter.setCompositionMode(QPainter::CompositionMode_SourceIn);
|
|
painter.fillRect(settingIcon.rect(),color);
|
|
painter.end();
|
|
|
|
QIcon icon;
|
|
icon.addPixmap(settingIcon,QIcon::Normal,QIcon::Off);
|
|
|
|
ui->settingsButton->setIcon(icon);
|
|
|
|
//exit
|
|
QPixmap crossPixmap(":resource/Icons/crossInCircle.png");
|
|
QPainter painterCross;
|
|
QSize iconSize(30,30);
|
|
|
|
painter.begin(&crossPixmap);
|
|
painter.setCompositionMode(QPainter::CompositionMode_SourceIn);
|
|
painter.fillRect(crossPixmap.rect(),color);
|
|
painter.end();
|
|
|
|
QIcon crossIcon;
|
|
crossIcon.addPixmap(crossPixmap,QIcon::Normal,QIcon::Off);
|
|
|
|
ui->exitButton->setIcon(crossIcon);
|
|
ui->exitButton->setIconSize(iconSize);
|
|
|
|
//loading
|
|
|
|
movie = new QMovie(":/resource/Icons/762.gif");
|
|
movieLabel = new QLabel("No movie");
|
|
movieLabel->setParent(this);
|
|
movieLabel->setGeometry(367,300,70,70);
|
|
movieLabel->setSizePolicy(QSizePolicy::Minimum,QSizePolicy::Minimum);
|
|
movieLabel->setMovie(movie);
|
|
startLoadingAnim();
|
|
}
|
|
|
|
void MainWindow::startLoadingAnim()
|
|
{
|
|
movie->start();
|
|
movieLabel->show();
|
|
}
|
|
|
|
void MainWindow::stopLoadingMovie()
|
|
{
|
|
movie->stop();
|
|
movieLabel->hide();
|
|
}
|
|
|
|
MainWindow::~MainWindow()
|
|
{
|
|
workerThread->quit();
|
|
workerThread->wait();
|
|
|
|
emit sigSendXMLAnswer("DISABLE");
|
|
|
|
delete workerThread;
|
|
delete ui;
|
|
}
|
|
|
|
|
|
|
|
|
|
|