Skip to content

Update ServoSmooth.cpp#3

Open
DoomsdayGS wants to merge 1 commit into
AlexGyver:masterfrom
DoomsdayGS:fix-smoothservo
Open

Update ServoSmooth.cpp#3
DoomsdayGS wants to merge 1 commit into
AlexGyver:masterfrom
DoomsdayGS:fix-smoothservo

Conversation

@DoomsdayGS

Copy link
Copy Markdown
  1. Если вызывается поворот на угол или длительностью равным текущей позиции сервы, то ServoSmooth::tick() не когда не вернет true потому как его не вернет ServoSmooth::tickManual(). Что бы вернулось true (или "серва приехала") нужно _servoState иметь true, а оно выставляется только в случае если не выполняется условие abs(_servoTargetPos - (int)_newPos) < SS_DEADZONE, а если _servoTargetPos = _newPos, то условие выполняется, и значение true не когда не будет достигнуто.
  2. boolean должен возвращать true или false. Если не выполняется millis() - _prevServoTime >= SS_SERVO_PERIOD, то функция ничего не возвращает (вернее ахинею возвращает). И ServoSmooth::tickManual() тоже boolean, потому её не обязательно проверять.

1. Если вызывается поворот на угол или длительностью равным текущей позиции сервы, то ServoSmooth::tick() не когда не вернет true потому как его не вернет ServoSmooth::tickManual(). Что бы вернулось true (или "серва приехала") нужно _servoState иметь true, а оно выставляется только в случае если не выполняется условие abs(_servoTargetPos - (int)_newPos) < SS_DEADZONE, а если _servoTargetPos = _newPos, то условие выполняется, и значение true не когда не будет достигнуто.
2. boolean должен возвращать true или false. Если не выполняется millis() - _prevServoTime >= SS_SERVO_PERIOD, то функция ничего не возвращает (вернее ахинею возвращает). И ServoSmooth::tickManual() тоже boolean, потому её не обязательно проверять.
@AlexGyver

Copy link
Copy Markdown
Owner

Спасибо! Решил задачу более красиво, работает корректно

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants