mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-05 07:28:29 -04:00
Copter: consolidate set_home functions
added lock argument instead of having twice as many functions no functional change
This commit is contained in:
parent
d02013c91b
commit
814cadac68
@ -762,10 +762,8 @@ private:
|
|||||||
void userhook_SuperSlowLoop();
|
void userhook_SuperSlowLoop();
|
||||||
void update_home_from_EKF();
|
void update_home_from_EKF();
|
||||||
void set_home_to_current_location_inflight();
|
void set_home_to_current_location_inflight();
|
||||||
bool set_home_to_current_location();
|
bool set_home_to_current_location(bool lock);
|
||||||
bool set_home_to_current_location_and_lock();
|
bool set_home(const Location& loc, bool lock);
|
||||||
bool set_home_and_lock(const Location& loc);
|
|
||||||
bool set_home(const Location& loc);
|
|
||||||
bool far_from_EKF_origin(const Location& loc);
|
bool far_from_EKF_origin(const Location& loc);
|
||||||
void set_system_time_from_GPS();
|
void set_system_time_from_GPS();
|
||||||
void exit_mission();
|
void exit_mission();
|
||||||
|
@ -1156,7 +1156,7 @@ void GCS_MAVLINK_Copter::handleMessage(mavlink_message_t* msg)
|
|||||||
// param7 : altitude (absolute)
|
// param7 : altitude (absolute)
|
||||||
result = MAV_RESULT_FAILED; // assume failure
|
result = MAV_RESULT_FAILED; // assume failure
|
||||||
if(is_equal(packet.param1,1.0f) || (is_zero(packet.param5) && is_zero(packet.param6) && is_zero(packet.param7))) {
|
if(is_equal(packet.param1,1.0f) || (is_zero(packet.param5) && is_zero(packet.param6) && is_zero(packet.param7))) {
|
||||||
if (copter.set_home_to_current_location_and_lock()) {
|
if (copter.set_home_to_current_location(true)) {
|
||||||
result = MAV_RESULT_ACCEPTED;
|
result = MAV_RESULT_ACCEPTED;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
@ -1168,7 +1168,7 @@ void GCS_MAVLINK_Copter::handleMessage(mavlink_message_t* msg)
|
|||||||
new_home_loc.lat = (int32_t)(packet.param5 * 1.0e7f);
|
new_home_loc.lat = (int32_t)(packet.param5 * 1.0e7f);
|
||||||
new_home_loc.lng = (int32_t)(packet.param6 * 1.0e7f);
|
new_home_loc.lng = (int32_t)(packet.param6 * 1.0e7f);
|
||||||
new_home_loc.alt = (int32_t)(packet.param7 * 100.0f);
|
new_home_loc.alt = (int32_t)(packet.param7 * 100.0f);
|
||||||
if (copter.set_home_and_lock(new_home_loc)) {
|
if (copter.set_home(new_home_loc, true)) {
|
||||||
result = MAV_RESULT_ACCEPTED;
|
result = MAV_RESULT_ACCEPTED;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2005,7 +2005,7 @@ void GCS_MAVLINK_Copter::handleMessage(mavlink_message_t* msg)
|
|||||||
mavlink_set_home_position_t packet;
|
mavlink_set_home_position_t packet;
|
||||||
mavlink_msg_set_home_position_decode(msg, &packet);
|
mavlink_msg_set_home_position_decode(msg, &packet);
|
||||||
if((packet.latitude == 0) && (packet.longitude == 0) && (packet.altitude == 0)) {
|
if((packet.latitude == 0) && (packet.longitude == 0) && (packet.altitude == 0)) {
|
||||||
copter.set_home_to_current_location_and_lock();
|
copter.set_home_to_current_location(true);
|
||||||
} else {
|
} else {
|
||||||
// sanity check location
|
// sanity check location
|
||||||
if (!check_latlng(packet.latitude, packet.longitude)) {
|
if (!check_latlng(packet.latitude, packet.longitude)) {
|
||||||
@ -2015,7 +2015,7 @@ void GCS_MAVLINK_Copter::handleMessage(mavlink_message_t* msg)
|
|||||||
new_home_loc.lat = packet.latitude;
|
new_home_loc.lat = packet.latitude;
|
||||||
new_home_loc.lng = packet.longitude;
|
new_home_loc.lng = packet.longitude;
|
||||||
new_home_loc.alt = packet.altitude / 10;
|
new_home_loc.alt = packet.altitude / 10;
|
||||||
copter.set_home_and_lock(new_home_loc);
|
copter.set_home(new_home_loc, true);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -20,7 +20,7 @@ void Copter::update_home_from_EKF()
|
|||||||
set_home_to_current_location_inflight();
|
set_home_to_current_location_inflight();
|
||||||
} else {
|
} else {
|
||||||
// move home to current ekf location (this will set home_state to HOME_SET)
|
// move home to current ekf location (this will set home_state to HOME_SET)
|
||||||
set_home_to_current_location();
|
set_home_to_current_location(false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -31,37 +31,16 @@ void Copter::set_home_to_current_location_inflight() {
|
|||||||
if (inertial_nav.get_location(temp_loc)) {
|
if (inertial_nav.get_location(temp_loc)) {
|
||||||
const struct Location &ekf_origin = inertial_nav.get_origin();
|
const struct Location &ekf_origin = inertial_nav.get_origin();
|
||||||
temp_loc.alt = ekf_origin.alt;
|
temp_loc.alt = ekf_origin.alt;
|
||||||
set_home(temp_loc);
|
set_home(temp_loc, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// set_home_to_current_location - set home to current GPS location
|
// set_home_to_current_location - set home to current GPS location
|
||||||
bool Copter::set_home_to_current_location() {
|
bool Copter::set_home_to_current_location(bool lock) {
|
||||||
// get current location from EKF
|
// get current location from EKF
|
||||||
Location temp_loc;
|
Location temp_loc;
|
||||||
if (inertial_nav.get_location(temp_loc)) {
|
if (inertial_nav.get_location(temp_loc)) {
|
||||||
return set_home(temp_loc);
|
return set_home(temp_loc, lock);
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// set_home_to_current_location_and_lock - set home to current location and lock so it cannot be moved
|
|
||||||
bool Copter::set_home_to_current_location_and_lock()
|
|
||||||
{
|
|
||||||
if (set_home_to_current_location()) {
|
|
||||||
set_home_state(HOME_SET_AND_LOCKED);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
// set_home_and_lock - sets ahrs home (used for RTL) to specified location and locks so it cannot be moved
|
|
||||||
// unless this function is called again
|
|
||||||
bool Copter::set_home_and_lock(const Location& loc)
|
|
||||||
{
|
|
||||||
if (set_home(loc)) {
|
|
||||||
set_home_state(HOME_SET_AND_LOCKED);
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -69,7 +48,7 @@ bool Copter::set_home_and_lock(const Location& loc)
|
|||||||
// set_home - sets ahrs home (used for RTL) to specified location
|
// set_home - sets ahrs home (used for RTL) to specified location
|
||||||
// initialises inertial nav and compass on first call
|
// initialises inertial nav and compass on first call
|
||||||
// returns true if home location set successfully
|
// returns true if home location set successfully
|
||||||
bool Copter::set_home(const Location& loc)
|
bool Copter::set_home(const Location& loc, bool lock)
|
||||||
{
|
{
|
||||||
// check location is valid
|
// check location is valid
|
||||||
if (loc.lat == 0 && loc.lng == 0) {
|
if (loc.lat == 0 && loc.lng == 0) {
|
||||||
@ -111,6 +90,11 @@ bool Copter::set_home(const Location& loc)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// lock home position
|
||||||
|
if (lock) {
|
||||||
|
set_home_state(HOME_SET_AND_LOCKED);
|
||||||
|
}
|
||||||
|
|
||||||
// log ahrs home and ekf origin dataflash
|
// log ahrs home and ekf origin dataflash
|
||||||
Log_Write_Home_And_Origin();
|
Log_Write_Home_And_Origin();
|
||||||
|
|
||||||
|
@ -1102,9 +1102,9 @@ void Copter::do_change_speed(const AP_Mission::Mission_Command& cmd)
|
|||||||
void Copter::do_set_home(const AP_Mission::Mission_Command& cmd)
|
void Copter::do_set_home(const AP_Mission::Mission_Command& cmd)
|
||||||
{
|
{
|
||||||
if(cmd.p1 == 1 || (cmd.content.location.lat == 0 && cmd.content.location.lng == 0 && cmd.content.location.alt == 0)) {
|
if(cmd.p1 == 1 || (cmd.content.location.lat == 0 && cmd.content.location.lng == 0 && cmd.content.location.alt == 0)) {
|
||||||
set_home_to_current_location();
|
set_home_to_current_location(false);
|
||||||
} else {
|
} else {
|
||||||
set_home(cmd.content.location);
|
set_home(cmd.content.location, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -175,7 +175,7 @@ bool Copter::init_arm_motors(bool arming_from_gcs)
|
|||||||
Log_Write_Event(DATA_EKF_ALT_RESET);
|
Log_Write_Event(DATA_EKF_ALT_RESET);
|
||||||
} else if (ap.home_state == HOME_SET_NOT_LOCKED) {
|
} else if (ap.home_state == HOME_SET_NOT_LOCKED) {
|
||||||
// Reset home position if it has already been set before (but not locked)
|
// Reset home position if it has already been set before (but not locked)
|
||||||
set_home_to_current_location();
|
set_home_to_current_location(false);
|
||||||
}
|
}
|
||||||
calc_distance_and_bearing();
|
calc_distance_and_bearing();
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user