12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- #include <AP_HAL/AP_HAL.h>
- #include "AC_PrecLand_SITL_Gazebo.h"
- extern const AP_HAL::HAL& hal;
- #if CONFIG_HAL_BOARD == HAL_BOARD_SITL
- // Constructor
- AC_PrecLand_SITL_Gazebo::AC_PrecLand_SITL_Gazebo(const AC_PrecLand& frontend, AC_PrecLand::precland_state& state)
- : AC_PrecLand_Backend(frontend, state),
- irlock()
- {
- }
- // init - perform initialisation of this backend
- void AC_PrecLand_SITL_Gazebo::init()
- {
- irlock.init(get_bus());
- }
- // update - give chance to driver to get updates from sensor
- void AC_PrecLand_SITL_Gazebo::update()
- {
- // update health
- _state.healthy = irlock.healthy();
- // get new sensor data
- irlock.update();
- if (irlock.num_targets() > 0 && irlock.last_update_ms() != _los_meas_time_ms) {
- irlock.get_unit_vector_body(_los_meas_body);
- _have_los_meas = true;
- _los_meas_time_ms = irlock.last_update_ms();
- }
- _have_los_meas = _have_los_meas && AP_HAL::millis()-_los_meas_time_ms <= 1000;
- }
- // provides a unit vector towards the target in body frame
- // returns same as have_los_meas()
- bool AC_PrecLand_SITL_Gazebo::get_los_body(Vector3f& ret) {
- if (have_los_meas()) {
- ret = _los_meas_body;
- return true;
- }
- return false;
- }
- // returns system time in milliseconds of last los measurement
- uint32_t AC_PrecLand_SITL_Gazebo::los_meas_time_ms() {
- return _los_meas_time_ms;
- }
- // return true if there is a valid los measurement available
- bool AC_PrecLand_SITL_Gazebo::have_los_meas() {
- return _have_los_meas;
- }
- #endif
|