initial digital input implementation
This commit is contained in:
parent
2fd37fe66d
commit
1e2eb1b0cf
|
@ -37,6 +37,7 @@ uint16_t AnalogCard::analogRead(uint8_t pin)
|
||||||
{
|
{
|
||||||
return this->analogInputBankB.readADC_SingleEnded(pin - 4);
|
return this->analogInputBankB.readADC_SingleEnded(pin - 4);
|
||||||
}
|
}
|
||||||
|
return 65535;
|
||||||
}
|
}
|
||||||
bool AnalogCard::begin()
|
bool AnalogCard::begin()
|
||||||
{
|
{
|
||||||
|
|
|
@ -0,0 +1,55 @@
|
||||||
|
#include <DigitalInputIoT.hpp>
|
||||||
|
|
||||||
|
|
||||||
|
bool DigitalInputIoT::begin(uint8_t card_id, DigitalInputCard *card, PubSubClient *mqtt, char *base_topic) {
|
||||||
|
this->card = card;
|
||||||
|
this->card_id = card_id;
|
||||||
|
this->mqtt = mqtt;
|
||||||
|
this->base_topic = base_topic;
|
||||||
|
this->card->registerCallback(std::bind(&DigitalInputIoT::handleValueChange, this, std::placeholders::_1, std::placeholders::_2));
|
||||||
|
return true;
|
||||||
|
|
||||||
|
}
|
||||||
|
void DigitalInputIoT::handleMqttMessage(char *topic, char *payload) {
|
||||||
|
// payload is char '0' or '1'
|
||||||
|
if (!strcmp(topic, PUBLISH_ENABLE_TOPIC)) {
|
||||||
|
if (payload[0] == '1') {
|
||||||
|
this->setDigitalInputsPublishEnabled(true);
|
||||||
|
} else {
|
||||||
|
this->setDigitalInputsPublishEnabled(false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void DigitalInputIoT::publishDigitalInputs() {
|
||||||
|
if (!this->digital_inputs_publish_enabled) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
for (int i = 0; i < 16; i++) {
|
||||||
|
this->publishDigitalInput(i);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void DigitalInputIoT::setDigitalInputsPublishEnabled(bool enabled) {
|
||||||
|
this->digital_inputs_publish_enabled = enabled;
|
||||||
|
if (enabled) {
|
||||||
|
this->publishDigitalInputs();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void DigitalInputIoT::handleValueChange(uint8_t pin, uint8_t value) {
|
||||||
|
if (this->digital_inputs_publish_enabled) {
|
||||||
|
this->publishDigitalInput(pin);
|
||||||
|
}
|
||||||
|
if (this->change_callback != NULL) {
|
||||||
|
this->change_callback(pin, value);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
void DigitalInputIoT::registerChangeCallback(std::function<void(uint8_t, uint8_t)> callback) {
|
||||||
|
this->change_callback = callback;
|
||||||
|
|
||||||
|
}
|
||||||
|
void DigitalInputIoT::publishReport() {
|
||||||
|
this->publishDigitalInputs();
|
||||||
|
}
|
||||||
|
uint8_t DigitalInputIoT::getType() {
|
||||||
|
return CARD_TYPE_DIGITAL_INPUT;
|
||||||
|
}
|
|
@ -3,17 +3,24 @@
|
||||||
#include <IoTComponent.hpp>
|
#include <IoTComponent.hpp>
|
||||||
#include <DigitalInputCard.hpp>
|
#include <DigitalInputCard.hpp>
|
||||||
|
|
||||||
|
#define PUBLISH_ENABLE_TOPIC "publish_enable"
|
||||||
|
|
||||||
class DigitalInputIoT : public IoTComponent {
|
class DigitalInputIoT : public IoTComponent {
|
||||||
public:
|
public:
|
||||||
bool begin(uint8_t card_id, DigitalInputCard *card, PubSubClient *mqtt, char *base_topic);
|
bool begin(uint8_t card_id, DigitalInputCard *card, PubSubClient *mqtt, char *base_topic);
|
||||||
void handleMqttMessage(char *topic, char *payload);
|
void handleMqttMessage(char *topic, char *payload);
|
||||||
void publishDigitalInputs();
|
void publishDigitalInputs();
|
||||||
|
void publishDigitalInput(uint8_t pin);
|
||||||
void setDigitalInputsPublishEnabled(bool enabled);
|
void setDigitalInputsPublishEnabled(bool enabled);
|
||||||
void handleValueChange(uint8_t pin, uint8_t value);
|
void handleValueChange(uint8_t pin, uint8_t value);
|
||||||
void registerValueChangeCallback(void (*callback)(uint8_t, uint8_t));
|
void registerChangeCallback(std::function<void(uint8_t, uint8_t)> callback);
|
||||||
void publishReport();
|
void publishReport();
|
||||||
uint8_t getType();
|
uint8_t getType();
|
||||||
private:
|
private:
|
||||||
|
uint8_t card_id;
|
||||||
|
PubSubClient *mqtt;
|
||||||
|
char *base_topic;
|
||||||
|
std::function<void(uint8_t, uint8_t)> change_callback;
|
||||||
bool digital_inputs_publish_enabled = false;
|
bool digital_inputs_publish_enabled = false;
|
||||||
DigitalInputCard *card;
|
DigitalInputCard *card;
|
||||||
};
|
};
|
|
@ -89,10 +89,10 @@ void ESPMegaIoT::registerCard(uint8_t card_id)
|
||||||
// components[card_id] = new AnalogIoT();
|
// components[card_id] = new AnalogIoT();
|
||||||
// components[card_id]->begin(card_id, cards[card_id], &mqtt, base_topic);
|
// components[card_id]->begin(card_id, cards[card_id], &mqtt, base_topic);
|
||||||
// break;
|
// break;
|
||||||
// case CARD_TYPE_DIGITAL_INPUT:
|
case CARD_TYPE_DIGITAL_INPUT:
|
||||||
// components[card_id] = new DigitalInputIoT();
|
components[card_id] = new DigitalInputIoT();
|
||||||
// components[card_id]->begin(card_id, cards[card_id], &mqtt, base_topic);
|
components[card_id]->begin(card_id, cards[card_id], &mqtt, base_topic);
|
||||||
// break;
|
break;
|
||||||
case CARD_TYPE_DIGITAL_OUTPUT:
|
case CARD_TYPE_DIGITAL_OUTPUT:
|
||||||
components[card_id] = new DigitalOutputIoT();
|
components[card_id] = new DigitalOutputIoT();
|
||||||
components[card_id]->begin(card_id, cards[card_id], &mqtt, base_topic);
|
components[card_id]->begin(card_id, cards[card_id], &mqtt, base_topic);
|
||||||
|
|
Loading…
Reference in New Issue