Browse Source

Thermostat: MQTTClient: switch to a singleton

master
rico rico 5 years ago
parent
commit
23c726f740
4 changed files with 21 additions and 11 deletions
  1. +0
    -2
      soft/thermostat/inc/mainwindow.h
  2. +5
    -3
      soft/thermostat/inc/mqttclient.h
  3. +1
    -5
      soft/thermostat/src/mainwindow.cpp
  4. +15
    -1
      soft/thermostat/src/mqttclient.cpp

+ 0
- 2
soft/thermostat/inc/mainwindow.h View File

@ -34,8 +34,6 @@ public:
explicit MainWindow(QWidget *parent = NULL);
~MainWindow();
MQTTClient *mqttclient;
private:
QPushButton m_state_btn;
BackgroundLoop m_backLoop;


+ 5
- 3
soft/thermostat/inc/mqttclient.h View File

@ -18,13 +18,15 @@ class MQTTClient: public QMQTT::Client
{
Q_OBJECT
public:
void publish_msg(const QString& topic, const QString& payload);
static MQTTClient *getInstance(void);
private:
explicit MQTTClient(const QHostAddress& host = QHostAddress::LocalHost,
const quint16 port = 1883,
QObject* parent = NULL);
virtual ~MQTTClient();
void publish_msg(const QString& topic, const QString& payload);
private:
static MQTTClient *_singleton;
QTimer m_timer;
public slots:


+ 1
- 5
soft/thermostat/src/mainwindow.cpp View File

@ -21,10 +21,8 @@ MainWindow::MainWindow(QWidget *parent) :
QMainWindow(parent)
{
ZoneItem *zone;
Settings *s = Settings::getInstance();
mqttclient = new MQTTClient(QHostAddress(s->m_broker.address), s->m_broker.port);
MQTTClient *mqttclient = MQTTClient::getInstance();
for (int i = 0; i < s->nbZones(); i++) {
zone = new ZoneItem(s->m_rooms.at(i).name, this);
@ -69,8 +67,6 @@ MainWindow::MainWindow(QWidget *parent) :
setWindowTitle(tr("Sorico's thermostat"));
m_backLoop.start();
mqttclient->connectToHost();
connect(&m_state_btn, SIGNAL(clicked()), this, SLOT(change_state()));
}


+ 15
- 1
soft/thermostat/src/mqttclient.cpp View File

@ -16,6 +16,19 @@
#include "settings.h"
#include "qmqtt.h"
MQTTClient *MQTTClient::_singleton = NULL;
MQTTClient *MQTTClient::getInstance(void)
{
if (!_singleton) {
Settings *s = Settings::getInstance();
_singleton = new MQTTClient(QHostAddress(s->m_broker.address), s->m_broker.port);
}
return _singleton;
}
MQTTClient::MQTTClient(const QHostAddress& host, const quint16 port,
QObject* parent) : QMQTT::Client(host, port, parent)
{
@ -24,7 +37,8 @@ MQTTClient::MQTTClient(const QHostAddress& host, const quint16 port,
connect(this, &MQTTClient::received, this, &MQTTClient::onReceived);
connect(this, &MQTTClient::published, this, &MQTTClient::onPublished);
connect(this, &MQTTClient::error, this, &MQTTClient::onError);
qDebug() << "created" << endl;
connectToHost();
}
MQTTClient::~MQTTClient() {


Loading…
Cancel
Save