Added autoreconncet, resized window

This commit is contained in:
CommanderRedYT
2022-02-01 12:40:08 +01:00
parent bfb54c3f8f
commit c1de4d0cc3
3 changed files with 53 additions and 2 deletions

View File

@@ -30,6 +30,8 @@ MainWindow::MainWindow(QWidget *parent) :
connect(m_ui->saveSlot, &QComboBox::currentIndexChanged, this, &MainWindow::loadSelectedUrl);
connect(m_ui->pushButtonSave, &QAbstractButton::clicked, this, &MainWindow::saveSettings);
connect(m_ui->autoReconnectBox, &QCheckBox::toggled, this, &MainWindow::setAutoReconnect);
connect(&m_webSocket, &QWebSocket::connected, this, &MainWindow::connected);
connect(&m_webSocket, &QWebSocket::disconnected, this, &MainWindow::disconnected);
connect(&m_webSocket, &QWebSocket::stateChanged, this, &MainWindow::stateChanged);
@@ -56,7 +58,11 @@ void MainWindow::connectClicked()
connectToWebsocket();
}
else
{
m_ui->autoReconnectBox->setChecked(false);
m_autoReconnect = false;
m_webSocket.close();
}
}
void MainWindow::sendClicked()
@@ -106,6 +112,7 @@ void MainWindow::connected()
m_ui->plainTextEdit->appendHtml(QStringLiteral("<b>%0</b> <i>%1</i><br/>")
.arg(QTime::currentTime().toString())
.arg(tr("Connected")));
m_autoReconnectTries = 0;
}
void MainWindow::disconnected()
@@ -113,11 +120,29 @@ void MainWindow::disconnected()
m_ui->plainTextEdit->appendHtml(QStringLiteral("<b>%0</b> <i>%1</i><br/>")
.arg(QTime::currentTime().toString())
.arg(tr("Disconnected")));
if (m_autoReconnect && m_autoReconnectTries < 5)
{
m_ui->plainTextEdit->appendHtml(QStringLiteral("<b>%0</b> <i>%1</i><br/>")
.arg(QTime::currentTime().toString())
.arg(tr("Auto-Reconnecting...")));
connectToWebsocket();
m_autoReconnectTries++;
}
else if (m_autoReconnectTries >= 5)
{
m_ui->plainTextEdit->appendHtml(QStringLiteral("<b>%0</b> <i>%1</i><br/>")
.arg(QTime::currentTime().toString())
.arg(tr("Maximum attempts reached.")));
m_ui->autoReconnectBox->setChecked(false);
m_autoReconnect = false;
}
}
void MainWindow::stateChanged(QAbstractSocket::SocketState state)
{
m_ui->lineEditUrl->setEnabled(state == QAbstractSocket::UnconnectedState);
m_ui->saveSlot->setEnabled(state == QAbstractSocket::UnconnectedState);
m_ui->pushButtonSave->setEnabled(state == QAbstractSocket::UnconnectedState);
m_ui->pushButtonConnect->setText(state == QAbstractSocket::UnconnectedState ? tr("Connect") : tr("Disconnect"));
m_ui->labelStatus->setText(qtEnumToString(state));
m_ui->lineEditSend->setEnabled(state == QAbstractSocket::ConnectedState);
@@ -181,3 +206,8 @@ void MainWindow::loadSelectedUrl()
if (tmpSocketState == QAbstractSocket::ConnectedState)
connectToWebsocket();
}
void MainWindow::setAutoReconnect(bool state)
{
m_autoReconnect = state;
}

View File

@@ -28,11 +28,16 @@ private slots:
void binaryMessageReceived(const QByteArray &message);
void error(QAbstractSocket::SocketError error);
void pong(quint64 elapsedTime, const QByteArray &payload);
void saveSettings();
void loadSettings();
void loadSelectedUrl();
void setAutoReconnect(bool state);
private:
const std::unique_ptr<Ui::MainWindow> m_ui;
QWebSocket m_webSocket;
std::array<QString, 10> m_url_slots;
bool m_autoReconnect;
uint8_t m_autoReconnectTries{0};
};

View File

@@ -6,8 +6,8 @@
<rect>
<x>0</x>
<y>0</y>
<width>800</width>
<height>600</height>
<width>995</width>
<height>709</height>
</rect>
</property>
<property name="windowTitle">
@@ -61,6 +61,22 @@
</property>
</widget>
</item>
<item>
<widget class="QCheckBox" name="autoReconnectBox">
<property name="enabled">
<bool>true</bool>
</property>
<property name="text">
<string>AutoReconnect</string>
</property>
<property name="checked">
<bool>false</bool>
</property>
<property name="autoRepeat">
<bool>false</bool>
</property>
</widget>
</item>
</layout>
</item>
<item>