|
@ -28,25 +28,30 @@ |
|
|
|
|
|
|
|
|
#include "Servo.h" |
|
|
#include "Servo.h" |
|
|
|
|
|
|
|
|
uint8_t servoPin[MAX_SERVOS] = { 0 }; |
|
|
static uint_fast8_t servoCount = 0; |
|
|
|
|
|
constexpr millis_t servoDelay[] = SERVO_DELAY; |
|
|
|
|
|
static_assert(COUNT(servoDelay) == NUM_SERVOS, "SERVO_DELAY must be an array NUM_SERVOS long."); |
|
|
|
|
|
|
|
|
|
|
|
libServo::libServo() |
|
|
|
|
|
: delay(servoDelay[servoCount++]) |
|
|
|
|
|
{} |
|
|
|
|
|
|
|
|
int8_t libServo::attach(const int pin) { |
|
|
int8_t libServo::attach(const int pin) { |
|
|
if (servoIndex >= MAX_SERVOS) return -1; |
|
|
if (servoCount >= MAX_SERVOS) return -1; |
|
|
if (pin > 0) servoPin[servoIndex] = pin; |
|
|
if (pin > 0) servo_pin = pin; |
|
|
return super::attach(servoPin[servoIndex]); |
|
|
return super::attach(servo_pin); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
int8_t libServo::attach(const int pin, const int min, const int max) { |
|
|
int8_t libServo::attach(const int pin, const int min, const int max) { |
|
|
if (pin > 0) servoPin[servoIndex] = pin; |
|
|
if (servoCount >= MAX_SERVOS) return -1; |
|
|
return super::attach(servoPin[servoIndex], min, max); |
|
|
if (pin > 0) servo_pin = pin; |
|
|
|
|
|
return super::attach(servo_pin, min, max); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
void libServo::move(const int value) { |
|
|
void libServo::move(const int value) { |
|
|
constexpr uint16_t servo_delay[] = SERVO_DELAY; |
|
|
|
|
|
static_assert(COUNT(servo_delay) == NUM_SERVOS, "SERVO_DELAY must be an array NUM_SERVOS long."); |
|
|
|
|
|
if (attach(0) >= 0) { |
|
|
if (attach(0) >= 0) { |
|
|
write(value); |
|
|
write(value); |
|
|
safe_delay(servo_delay[servoIndex]); |
|
|
safe_delay(delay); |
|
|
#if ENABLED(DEACTIVATE_SERVOS_AFTER_MOVE) |
|
|
#if ENABLED(DEACTIVATE_SERVOS_AFTER_MOVE) |
|
|
detach(); |
|
|
detach(); |
|
|
#endif |
|
|
#endif |
|
|