mirror of
https://github.com/IoTManagerProject/IoTManager.git
synced 2026-03-27 22:52:19 +03:00
Переписываем взаимодействие c драйверами IoTGpio
This commit is contained in:
@@ -3,64 +3,79 @@
|
||||
#include "classes/IoTGpio.h"
|
||||
#include <Adafruit_MCP23X17.h>
|
||||
|
||||
class Mcp23017 : public IoTItem, IoTGpio {
|
||||
void scanI2C();
|
||||
|
||||
class Mcp23017Driver : public IoTGpio {
|
||||
private:
|
||||
Adafruit_MCP23X17 _mcp;
|
||||
|
||||
public:
|
||||
Adafruit_MCP23X17 mcp;
|
||||
|
||||
Mcp23017(String parameters, int index) : IoTItem(parameters), IoTGpio(index) {
|
||||
}
|
||||
|
||||
void doByInterval() {
|
||||
// regEvent(value.valD, "Mcp23017");
|
||||
}
|
||||
|
||||
//возвращает ссылку на экземпляр класса Mcp23017
|
||||
bool isGpioDriver() {
|
||||
return true;
|
||||
Mcp23017Driver(int index, String addr) : IoTGpio(index) {
|
||||
if (!_mcp.begin_I2C(hexStringToUint8(addr))) {
|
||||
Serial.println("MCP23X17 Init Error.");
|
||||
}
|
||||
}
|
||||
|
||||
void pinMode(uint8_t pin, uint8_t mode) {
|
||||
mcp.pinMode(pin, mode);
|
||||
_mcp.pinMode(pin, mode);
|
||||
}
|
||||
|
||||
void digitalWrite(uint8_t pin, uint8_t val) {
|
||||
mcp.digitalWrite(pin, val);
|
||||
_mcp.digitalWrite(pin, val);
|
||||
}
|
||||
|
||||
int digitalRead(uint8_t pin) {
|
||||
return mcp.digitalRead(pin);
|
||||
return _mcp.digitalRead(pin);
|
||||
}
|
||||
|
||||
void digitalInvert(uint8_t pin) {
|
||||
mcp.digitalWrite(pin, 1 - mcp.digitalRead(pin));
|
||||
_mcp.digitalWrite(pin, 1 - _mcp.digitalRead(pin));
|
||||
}
|
||||
|
||||
~Mcp23017(){};
|
||||
~Mcp23017Driver() {};
|
||||
};
|
||||
|
||||
|
||||
class Mcp23017 : public IoTItem {
|
||||
private:
|
||||
Mcp23017Driver* _driver;
|
||||
|
||||
public:
|
||||
Mcp23017(String parameters) : IoTItem(parameters) {
|
||||
_driver = nullptr;
|
||||
|
||||
String addr;
|
||||
jsonRead(parameters, "addr", addr);
|
||||
if (addr == "") {
|
||||
scanI2C();
|
||||
return;
|
||||
}
|
||||
|
||||
int index;
|
||||
jsonRead(parameters, "index", index);
|
||||
if (index > 4) {
|
||||
Serial.println("MCP23X17 wrong index. Must be 0 - 4");
|
||||
return;
|
||||
}
|
||||
|
||||
_driver = new Mcp23017Driver(index, addr);
|
||||
}
|
||||
|
||||
void doByInterval() {}
|
||||
|
||||
//возвращает ссылку на экземпляр класса Mcp23017Driver
|
||||
IoTGpio* getGpioDriver() {
|
||||
return _driver;
|
||||
}
|
||||
|
||||
~Mcp23017() {
|
||||
delete _driver;
|
||||
};
|
||||
};
|
||||
|
||||
void* getAPI_Mcp23017(String subtype, String param) {
|
||||
if (subtype == F("Mcp23017")) {
|
||||
String addr;
|
||||
jsonRead(param, "addr", addr);
|
||||
Serial.printf("deviceAddress %s = %02x \n", addr.c_str(), hexStringToUint8(addr));
|
||||
|
||||
String index_str;
|
||||
jsonRead(param, "index", index_str);
|
||||
int index = index_str.toInt();
|
||||
if (index > 4) {
|
||||
Serial.println("MCP23X17 wrong index. Must be 0 - 4");
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
Mcp23017* newItem = new Mcp23017(param, index);
|
||||
if (!newItem->mcp.begin_I2C(hexStringToUint8(addr))) {
|
||||
Serial.println("MCP23X17 Init Error.");
|
||||
delete newItem;
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
return newItem;
|
||||
return new Mcp23017(param);
|
||||
} else {
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user