AP_WindVane_Home.cpp 1.2 KB

123456789101112131415161718192021222324252627282930313233343536
  1. /*
  2. This program is free software: you can redistribute it and/or modify
  3. it under the terms of the GNU General Public License as published by
  4. the Free Software Foundation, either version 3 of the License, or
  5. (at your option) any later version.
  6. This program is distributed in the hope that it will be useful,
  7. but WITHOUT ANY WARRANTY; without even the implied warranty of
  8. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  9. GNU General Public License for more details.
  10. You should have received a copy of the GNU General Public License
  11. along with this program. If not, see <http://www.gnu.org/licenses/>.
  12. */
  13. #include "AP_WindVane_Home.h"
  14. // constructor
  15. AP_WindVane_Home::AP_WindVane_Home(AP_WindVane &frontend) :
  16. AP_WindVane_Backend(frontend)
  17. {
  18. }
  19. void AP_WindVane_Home::update_direction()
  20. {
  21. float direction_apparent_ef = _frontend._home_heading;
  22. if (_frontend._direction_type == _frontend.WINDVANE_PWM_PIN && _frontend._rc_in_no != 0) {
  23. RC_Channel *chan = rc().channel(_frontend._rc_in_no-1);
  24. if (chan != nullptr) {
  25. direction_apparent_ef = wrap_PI(direction_apparent_ef + chan->norm_input() * radians(45));
  26. }
  27. }
  28. direction_update_frontend(direction_apparent_ef);
  29. }