|
|
|
@ -434,6 +434,22 @@ void GCS_MAVLINK_Tracker::handleMessage(mavlink_message_t* msg)
@@ -434,6 +434,22 @@ void GCS_MAVLINK_Tracker::handleMessage(mavlink_message_t* msg)
|
|
|
|
|
{ |
|
|
|
|
switch (msg->msgid) { |
|
|
|
|
|
|
|
|
|
case MAVLINK_MSG_ID_SET_GPS_GLOBAL_ORIGIN: |
|
|
|
|
{ |
|
|
|
|
mavlink_set_gps_global_origin_t packet; |
|
|
|
|
mavlink_msg_set_gps_global_origin_decode(msg, &packet); |
|
|
|
|
// sanity check location
|
|
|
|
|
if (!check_latlng(packet.latitude, packet.longitude)) { |
|
|
|
|
break; |
|
|
|
|
} |
|
|
|
|
Location ekf_origin {}; |
|
|
|
|
ekf_origin.lat = packet.latitude; |
|
|
|
|
ekf_origin.lng = packet.longitude; |
|
|
|
|
ekf_origin.alt = packet.altitude / 10; |
|
|
|
|
tracker.set_ekf_origin(ekf_origin); |
|
|
|
|
break; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
// If we are currently operating as a proxy for a remote,
|
|
|
|
|
// alas we have to look inside each packet to see if it's for us or for the remote
|
|
|
|
|
case MAVLINK_MSG_ID_REQUEST_DATA_STREAM: |
|
|
|
@ -526,6 +542,10 @@ void GCS_MAVLINK_Tracker::handleMessage(mavlink_message_t* msg)
@@ -526,6 +542,10 @@ void GCS_MAVLINK_Tracker::handleMessage(mavlink_message_t* msg)
|
|
|
|
|
|
|
|
|
|
case MAV_CMD_GET_HOME_POSITION: |
|
|
|
|
send_home(tracker.ahrs.get_home()); |
|
|
|
|
Location ekf_origin; |
|
|
|
|
if (tracker.ahrs.get_origin(ekf_origin)) { |
|
|
|
|
send_ekf_origin(ekf_origin); |
|
|
|
|
} |
|
|
|
|
result = MAV_RESULT_ACCEPTED; |
|
|
|
|
break; |
|
|
|
|
|
|
|
|
|