mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-28 03:28:30 -04:00
AP_Mission: improved handling of large LOITER_TURNS
instead of wrapping we should use MIN with 255, which is closer to what was requested
This commit is contained in:
parent
5ac3f9aa33
commit
bb1ee4e34c
@ -920,8 +920,8 @@ MAV_MISSION_RESULT AP_Mission::mavlink_int_to_mission_cmd(const mavlink_mission_
|
|||||||
break;
|
break;
|
||||||
|
|
||||||
case MAV_CMD_NAV_LOITER_TURNS: { // MAV ID: 18
|
case MAV_CMD_NAV_LOITER_TURNS: { // MAV ID: 18
|
||||||
uint16_t num_turns = packet.param1; // param 1 is number of times to circle is held in low p1
|
uint16_t num_turns = MIN(255,packet.param1); // param 1 is number of times to circle is held in low p1
|
||||||
uint16_t radius_m = fabsf(packet.param3); // param 3 is radius in meters is held in high p1
|
uint16_t radius_m = MIN(255,fabsf(packet.param3)); // param 3 is radius in meters is held in high p1
|
||||||
cmd.p1 = (radius_m<<8) | (num_turns & 0x00FF); // store radius in high byte of p1, num turns in low byte of p1
|
cmd.p1 = (radius_m<<8) | (num_turns & 0x00FF); // store radius in high byte of p1, num turns in low byte of p1
|
||||||
cmd.content.location.loiter_ccw = (packet.param3 < 0);
|
cmd.content.location.loiter_ccw = (packet.param3 < 0);
|
||||||
cmd.content.location.loiter_xtrack = (packet.param4 > 0); // 0 to xtrack from center of waypoint, 1 to xtrack from tangent exit location
|
cmd.content.location.loiter_xtrack = (packet.param4 > 0); // 0 to xtrack from center of waypoint, 1 to xtrack from tangent exit location
|
||||||
|
Loading…
Reference in New Issue
Block a user