From 03db86427af8131dd17c280f02d8beb5323e3be5 Mon Sep 17 00:00:00 2001 From: Nick Exton Date: Thu, 16 May 2024 11:25:51 +1000 Subject: [PATCH] Copter: Handle DO_MOUNT_CONTROL yaw angle as body frame And only accept if the mode is MAV_MOUNT_MODE_MAVLINK_TARGETING. This matches the handlers in AP_Mount. --- ArduCopter/GCS_Mavlink.cpp | 16 ++++++++++------ ArduCopter/mode_auto.cpp | 4 +++- 2 files changed, 13 insertions(+), 7 deletions(-) diff --git a/ArduCopter/GCS_Mavlink.cpp b/ArduCopter/GCS_Mavlink.cpp index 4a54063bd9..1e4e6da598 100644 --- a/ArduCopter/GCS_Mavlink.cpp +++ b/ArduCopter/GCS_Mavlink.cpp @@ -860,9 +860,12 @@ MAV_RESULT GCS_MAVLINK_Copter::handle_command_mount(const mavlink_command_int_t switch (packet.command) { case MAV_CMD_DO_MOUNT_CONTROL: // if vehicle has a camera mount but it doesn't do pan control then yaw the entire vehicle instead - if ((copter.camera_mount.get_mount_type() != AP_Mount::Type::None) && + if (((MAV_MOUNT_MODE)packet.z == MAV_MOUNT_MODE_MAVLINK_TARGETING) && + (copter.camera_mount.get_mount_type() != AP_Mount::Type::None) && !copter.camera_mount.has_pan_control()) { - copter.flightmode->auto_yaw.set_yaw_angle_rate((float)packet.param3, 0.0f); + // Per the handler in AP_Mount, DO_MOUNT_CONTROL yaw angle is in body frame, which is + // equivalent to an offset to the current yaw demand. + copter.flightmode->auto_yaw.set_yaw_angle_offset(packet.param3); } break; default: @@ -1131,11 +1134,12 @@ void GCS_MAVLINK_Copter::handle_mount_message(const mavlink_message_t &msg) case MAVLINK_MSG_ID_MOUNT_CONTROL: // if vehicle has a camera mount but it doesn't do pan control then yaw the entire vehicle instead if ((copter.camera_mount.get_mount_type() != AP_Mount::Type::None) && + (copter.camera_mount.get_mode() == MAV_MOUNT_MODE_MAVLINK_TARGETING) && !copter.camera_mount.has_pan_control()) { - copter.flightmode->auto_yaw.set_yaw_angle_rate( - mavlink_msg_mount_control_get_input_c(&msg) * 0.01f, - 0.0f); - + // Per the handler in AP_Mount, MOUNT_CONTROL yaw angle is in body frame, which is + // equivalent to an offset to the current yaw demand. + const float yaw_offset_d = mavlink_msg_mount_control_get_input_c(&msg) * 0.01f; + copter.flightmode->auto_yaw.set_yaw_angle_offset(yaw_offset_d); break; } } diff --git a/ArduCopter/mode_auto.cpp b/ArduCopter/mode_auto.cpp index bc4bb21ac9..821cf9a5a3 100644 --- a/ArduCopter/mode_auto.cpp +++ b/ArduCopter/mode_auto.cpp @@ -1983,7 +1983,9 @@ void ModeAuto::do_mount_control(const AP_Mission::Mission_Command& cmd) // if vehicle has a camera mount but it doesn't do pan control then yaw the entire vehicle instead if ((copter.camera_mount.get_mount_type() != AP_Mount::Type::None) && !copter.camera_mount.has_pan_control()) { - auto_yaw.set_yaw_angle_rate(cmd.content.mount_control.yaw,0.0f); + // Per the handler in AP_Mount, DO_MOUNT_CONTROL yaw angle is in body frame, which is + // equivalent to an offset to the current yaw demand. + auto_yaw.set_yaw_angle_offset(cmd.content.mount_control.yaw); } // pass the target angles to the camera mount copter.camera_mount.set_angle_target(cmd.content.mount_control.roll, cmd.content.mount_control.pitch, cmd.content.mount_control.yaw, false);