Files
IoTManager/src/modules/sensors/Pzem004t/Pzem004t.cpp

199 lines
4.7 KiB
C++
Raw Normal View History

#include "Global.h"
#include "classes/IoTItem.h"
#include "PZEMSensor.h"
2022-09-27 01:24:22 +02:00
#include "modules/sensors/UART/Uart.h"
2022-09-26 21:56:54 +02:00
class Pzem004v : public IoTItem {
private:
String addr;
PZEMSensor* pzem;
2022-09-26 21:56:54 +02:00
public:
Pzem004v(String parameters) : IoTItem(parameters) {
addr = jsonReadStr(parameters, "addr");
2022-09-27 00:57:28 +02:00
if (myUART) {
pzem = new PZEMSensor(myUART, hexStringToUint8(addr));
}
}
void doByInterval() {
2022-09-27 00:57:28 +02:00
if (pzem) {
bool online = false;
value.valD = pzem->values(online)->voltage;
if (online) {
regEvent(value.valD, "Pzem V");
} else {
regEvent(NAN, "Pzem V");
SerialPrint("E", "Pzem", "V error");
}
2022-09-27 00:57:28 +02:00
}
2022-09-26 21:56:54 +02:00
}
~Pzem004v(){};
};
class Pzem004a : public IoTItem {
private:
String addr;
PZEMSensor* pzem;
public:
Pzem004a(String parameters) : IoTItem(parameters) {
addr = jsonReadStr(parameters, "addr");
if (myUART) {
pzem = new PZEMSensor(myUART, hexStringToUint8(addr));
}
}
void doByInterval() {
if (pzem) {
bool online = false;
value.valD = pzem->values(online)->current;
if (online) {
regEvent(value.valD, "Pzem A");
} else {
regEvent(NAN, "Pzem A");
SerialPrint("E", "Pzem", "A error");
}
}
}
~Pzem004a(){};
};
class Pzem004w : public IoTItem {
private:
String addr;
PZEMSensor* pzem;
public:
Pzem004w(String parameters) : IoTItem(parameters) {
addr = jsonReadStr(parameters, "addr");
if (myUART) {
pzem = new PZEMSensor(myUART, hexStringToUint8(addr));
}
}
void doByInterval() {
if (pzem) {
bool online = false;
value.valD = pzem->values(online)->power;
if (online) {
regEvent(value.valD, "Pzem W");
} else {
regEvent(NAN, "Pzem W");
SerialPrint("E", "Pzem", "W error");
}
}
}
~Pzem004w(){};
};
class Pzem004wh : public IoTItem {
private:
String addr;
PZEMSensor* pzem;
public:
Pzem004wh(String parameters) : IoTItem(parameters) {
addr = jsonReadStr(parameters, "addr");
if (myUART) {
pzem = new PZEMSensor(myUART, hexStringToUint8(addr));
}
}
void doByInterval() {
if (pzem) {
bool online = false;
value.valD = pzem->values(online)->energy;
if (online) {
regEvent(value.valD, "Pzem Wh");
} else {
regEvent(NAN, "Pzem Wh");
SerialPrint("E", "Pzem", "Wh error");
}
}
}
~Pzem004wh(){};
};
class Pzem004hz : public IoTItem {
private:
String addr;
PZEMSensor* pzem;
public:
Pzem004hz(String parameters) : IoTItem(parameters) {
addr = jsonReadStr(parameters, "addr");
if (myUART) {
pzem = new PZEMSensor(myUART, hexStringToUint8(addr));
}
}
void doByInterval() {
if (pzem) {
bool online = false;
value.valD = pzem->values(online)->freq;
if (online) {
regEvent(value.valD, "Pzem Hz");
} else {
regEvent(NAN, "Pzem Hz");
SerialPrint("E", "Pzem", "Hz error");
}
}
}
~Pzem004hz(){};
};
2022-10-07 14:03:05 +03:00
class Pzem004pf : public IoTItem {
private:
String addr;
PZEMSensor* pzem;
public:
Pzem004pf(String parameters) : IoTItem(parameters) {
addr = jsonReadStr(parameters, "addr");
if (myUART) {
pzem = new PZEMSensor(myUART, hexStringToUint8(addr));
}
}
void doByInterval() {
if (pzem) {
bool online = false;
value.valD = pzem->values(online)->pf;
if (online) {
regEvent(value.valD, "Pzem Pf");
} else {
regEvent(NAN, "Pzem Pf");
SerialPrint("E", "Pzem", "Pf error");
}
}
}
~Pzem004pf(){};
};
2022-09-26 21:56:54 +02:00
void* getAPI_Pzem004(String subtype, String param) {
if (subtype == F("Pzem004v")) {
return new Pzem004v(param);
} else if (subtype == F("Pzem004a")) {
return new Pzem004a(param);
} else if (subtype == F("Pzem004w")) {
return new Pzem004w(param);
} else if (subtype == F("Pzem004wh")) {
return new Pzem004wh(param);
} else if (subtype == F("Pzem004hz")) {
return new Pzem004hz(param);
2022-10-07 14:03:05 +03:00
} else if (subtype == F("Pzem004pf")) {
return new Pzem004pf(param);
} else {
return nullptr;
}
2022-09-26 21:56:54 +02:00
}