diff --git a/src/modules/exec/IoTServo/IoTServo.cpp b/src/modules/exec/IoTServo/IoTServo.cpp index d9e95974..e66bc8df 100644 --- a/src/modules/exec/IoTServo/IoTServo.cpp +++ b/src/modules/exec/IoTServo/IoTServo.cpp @@ -15,12 +15,19 @@ class IoTServo : public IoTItem { public: IoTServo(String parameters): IoTItem(parameters) { - int pin, minPulseWidth, maxPulseWidth, neutralPulseWidth; + int pin, minPulseWidth, maxPulseWidth, minAngle, maxAngle; jsonRead(parameters, "pin", pin); jsonRead(parameters, "minPulseWidth", minPulseWidth); jsonRead(parameters, "maxPulseWidth", maxPulseWidth); - jsonRead(parameters, "neutralPulseWidth", neutralPulseWidth); - servObj.attach(pin, minPulseWidth, maxPulseWidth, neutralPulseWidth); + jsonRead(parameters, "minAngle", minAngle); + jsonRead(parameters, "maxAngle", maxAngle); + +#ifdef ESP32 + servObj.attach(pin, Servo::CHANNEL_NOT_ATTACHED, minAngle, maxAngle, minPulseWidth, maxPulseWidth); +#endif +#ifdef ESP8266 + servObj.attach(pin, minPulseWidth, maxPulseWidth, value.valD); +#endif // jsonRead(parameters, "apin", _apin); // if (_apin >= 0) IoTgpio.pinMode(_apin, INPUT); diff --git a/src/modules/exec/IoTServo/modinfo.json b/src/modules/exec/IoTServo/modinfo.json index 5557aeb4..56ecc51b 100644 --- a/src/modules/exec/IoTServo/modinfo.json +++ b/src/modules/exec/IoTServo/modinfo.json @@ -13,7 +13,8 @@ "pin": 12, "minPulseWidth": 544, "maxPulseWidth": 2400, - "neutralPulseWidth": 1500, + "minAngle": 0, + "maxAngle": 180, "trackingID": "" } ], @@ -34,7 +35,8 @@ "pin": "Пин, к которому подключен сервопривод", "minPulseWidth": "Минимальная длина импульса", "maxPulseWidth": "Максимальная длина импульса", - "neutralPulseWidth": "Нейтральная длина импульса", + "minAngle": "Минимальное значение угла (имеет значение для ESP32)", + "maxAngle": "Максимальное значение угла (имеет значение для ESP32)", "trackingID": "Идентификатор отслеживания значения другого элемента конфигурации, например, чтение аналога" }, "retInfo": "Содержит текущее значение поворота",