mirror of https://github.com/ArduPilot/ardupilot
Rover: boats always navigate when outside waypoint radius
This commit is contained in:
parent
e6d4b2a087
commit
0da8ff6b2e
|
@ -46,14 +46,14 @@ void ModeAuto::update()
|
|||
case Auto_WP:
|
||||
{
|
||||
_distance_to_destination = get_distance(rover.current_loc, _destination);
|
||||
const bool near_wp = _distance_to_destination <= rover.g.waypoint_radius;
|
||||
// check if we've reached the destination
|
||||
if (!_reached_destination) {
|
||||
if (_distance_to_destination <= rover.g.waypoint_radius || location_passed_point(rover.current_loc, _origin, _destination)) {
|
||||
// trigger reached
|
||||
_reached_destination = true;
|
||||
}
|
||||
if (!_reached_destination && (near_wp || location_passed_point(rover.current_loc, _origin, _destination))) {
|
||||
// trigger reached
|
||||
_reached_destination = true;
|
||||
}
|
||||
if (!_reached_destination || rover.is_boat()) {
|
||||
// determine if we should keep navigating
|
||||
if (!_reached_destination || (rover.is_boat() && !near_wp)) {
|
||||
// continue driving towards destination
|
||||
calc_steering_to_waypoint(_reached_destination ? rover.current_loc : _origin, _destination, _reversed);
|
||||
calc_throttle(calc_reduced_speed_for_turn_or_distance(_reversed ? -_desired_speed : _desired_speed), true);
|
||||
|
|
|
@ -20,13 +20,15 @@ void ModeGuided::update()
|
|||
switch (_guided_mode) {
|
||||
case Guided_WP:
|
||||
{
|
||||
if (!_reached_destination || rover.is_boat()) {
|
||||
// check if we've reached the destination
|
||||
_distance_to_destination = get_distance(rover.current_loc, _destination);
|
||||
if (!_reached_destination && (_distance_to_destination <= rover.g.waypoint_radius || location_passed_point(rover.current_loc, _origin, _destination))) {
|
||||
_reached_destination = true;
|
||||
rover.gcs().send_mission_item_reached_message(0);
|
||||
}
|
||||
_distance_to_destination = get_distance(rover.current_loc, _destination);
|
||||
const bool near_wp = _distance_to_destination <= rover.g.waypoint_radius;
|
||||
// check if we've reached the destination
|
||||
if (!_reached_destination && (near_wp || location_passed_point(rover.current_loc, _origin, _destination))) {
|
||||
_reached_destination = true;
|
||||
rover.gcs().send_mission_item_reached_message(0);
|
||||
}
|
||||
// determine if we should keep navigating
|
||||
if (!_reached_destination || (rover.is_boat() && !near_wp)) {
|
||||
// drive towards destination
|
||||
calc_steering_to_waypoint(_reached_destination ? rover.current_loc : _origin, _destination);
|
||||
calc_throttle(calc_reduced_speed_for_turn_or_distance(_desired_speed), true);
|
||||
|
|
|
@ -22,15 +22,17 @@ bool ModeRTL::_enter()
|
|||
|
||||
void ModeRTL::update()
|
||||
{
|
||||
if (!_reached_destination || rover.is_boat()) {
|
||||
// calculate distance to home
|
||||
_distance_to_destination = get_distance(rover.current_loc, _destination);
|
||||
// check if we've reached the destination
|
||||
if (!_reached_destination && (_distance_to_destination <= rover.g.waypoint_radius || location_passed_point(rover.current_loc, _origin, _destination))) {
|
||||
// trigger reached
|
||||
_reached_destination = true;
|
||||
gcs().send_text(MAV_SEVERITY_INFO, "Reached destination");
|
||||
}
|
||||
// calculate distance to home
|
||||
_distance_to_destination = get_distance(rover.current_loc, _destination);
|
||||
const bool near_wp = _distance_to_destination <= rover.g.waypoint_radius;
|
||||
// check if we've reached the destination
|
||||
if (!_reached_destination && (near_wp || location_passed_point(rover.current_loc, _origin, _destination))) {
|
||||
// trigger reached
|
||||
_reached_destination = true;
|
||||
gcs().send_text(MAV_SEVERITY_INFO, "Reached destination");
|
||||
}
|
||||
// determine if we should keep navigating
|
||||
if (!_reached_destination || (rover.is_boat() && !near_wp)) {
|
||||
// continue driving towards destination
|
||||
calc_steering_to_waypoint(_reached_destination ? rover.current_loc :_origin, _destination);
|
||||
calc_throttle(calc_reduced_speed_for_turn_or_distance(_desired_speed), true);
|
||||
|
|
Loading…
Reference in New Issue