mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-11 10:28:29 -04:00
AP_RangeFinder: fixed failover between rangefinders
this fixes the case where we have one rangefinder that can handle short range and another that is good for long range but no good for short range (quite common, eg radar and lidar) If possible we want to use the first rangefinder that is in range for the right orientation. If none are in range then use the first for the orientation
This commit is contained in:
parent
b19ad689a6
commit
df5e154144
@ -570,16 +570,23 @@ bool RangeFinder::has_orientation(enum Rotation orientation) const
|
|||||||
// find first range finder instance with the specified orientation
|
// find first range finder instance with the specified orientation
|
||||||
AP_RangeFinder_Backend *RangeFinder::find_instance(enum Rotation orientation) const
|
AP_RangeFinder_Backend *RangeFinder::find_instance(enum Rotation orientation) const
|
||||||
{
|
{
|
||||||
|
// first try for a rangefinder that is in range
|
||||||
for (uint8_t i=0; i<num_instances; i++) {
|
for (uint8_t i=0; i<num_instances; i++) {
|
||||||
AP_RangeFinder_Backend *backend = get_backend(i);
|
AP_RangeFinder_Backend *backend = get_backend(i);
|
||||||
if (backend == nullptr) {
|
if (backend != nullptr &&
|
||||||
continue;
|
backend->orientation() == orientation &&
|
||||||
}
|
backend->status() == RangeFinder_Good) {
|
||||||
if (backend->orientation() != orientation) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
return backend;
|
return backend;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
// if none in range then return first with correct orientation
|
||||||
|
for (uint8_t i=0; i<num_instances; i++) {
|
||||||
|
AP_RangeFinder_Backend *backend = get_backend(i);
|
||||||
|
if (backend != nullptr &&
|
||||||
|
backend->orientation() == orientation) {
|
||||||
|
return backend;
|
||||||
|
}
|
||||||
|
}
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user