diff --git a/libraries/AP_Mount/AP_Mount_Siyi.cpp b/libraries/AP_Mount/AP_Mount_Siyi.cpp index 714a9cadd694e8..c81755100ba5e2 100644 --- a/libraries/AP_Mount/AP_Mount_Siyi.cpp +++ b/libraries/AP_Mount/AP_Mount_Siyi.cpp @@ -82,6 +82,12 @@ void AP_Mount_Siyi::update() _last_rangefinder_req_ms = now_ms; } + // send attitude to gimbal at 10Hz + if (now_ms - _last_attitude_send_ms > 100) { + _last_attitude_send_ms = now_ms; + send_attitude_velocity(); + } + // run zoom control update_zoom_control(); @@ -1086,4 +1092,47 @@ void AP_Mount_Siyi::check_firmware_version() const } } +/* + send ArduPilot attitude and velocity to gimbal +*/ +void AP_Mount_Siyi::send_attitude_velocity(void) +{ + const auto &ahrs = AP::ahrs(); + struct { + uint32_t time_boot_ms; + float roll, pitch, yaw; + float rollspeed, pitchspeed, yawspeed; + } attitude; + + // get attitude as euler 321 + const auto &gyro = ahrs.get_gyro(); + const uint32_t now_ms = AP_HAL::millis(); + + attitude.time_boot_ms = now_ms; + attitude.roll = ahrs.roll; + attitude.pitch = ahrs.pitch; + attitude.yaw = ahrs.yaw; + attitude.rollspeed = gyro.x; + attitude.pitchspeed = gyro.y; + attitude.yawspeed = gyro.z; + + send_packet(SiyiCommandId::EXTERNAL_ATTITUDE, (const uint8_t *)&attitude, sizeof(attitude)); + + // send velocity NED + struct { + uint32_t time_boot_ms; + float vn, ve, vd; + } velocity; + Vector3f vel_ned; + if (!ahrs.get_velocity_NED(vel_ned)) { + return; + } + velocity.time_boot_ms = now_ms; + velocity.vn = vel_ned.x; + velocity.ve = vel_ned.y; + velocity.vd = vel_ned.z; + + send_packet(SiyiCommandId::EXTERNAL_VELOCITY, (const uint8_t *)&velocity, sizeof(velocity)); +} + #endif // HAL_MOUNT_SIYI_ENABLED diff --git a/libraries/AP_Mount/AP_Mount_Siyi.h b/libraries/AP_Mount/AP_Mount_Siyi.h index fd929558a7d3e8..45215cafb4d47d 100644 --- a/libraries/AP_Mount/AP_Mount_Siyi.h +++ b/libraries/AP_Mount/AP_Mount_Siyi.h @@ -111,6 +111,8 @@ class AP_Mount_Siyi : public AP_Mount_Backend ABSOLUTE_ZOOM = 0x0F, SET_CAMERA_IMAGE_TYPE = 0x11, READ_RANGEFINDER = 0x15, + EXTERNAL_ATTITUDE = 0x22, + EXTERNAL_VELOCITY = 0x26, }; // Function Feedback Info packet info_type values @@ -324,6 +326,10 @@ class AP_Mount_Siyi : public AP_Mount_Backend uint32_t _last_rangefinder_dist_ms; // system time of last successful read of rangefinder distance float _rangefinder_dist_m; // distance received from rangefinder + // sending of attitude and velocity to gimbal + uint32_t _last_attitude_send_ms; + void send_attitude_velocity(void); + // hardware lookup table indexed by HardwareModel enum values (see above) struct HWInfo { uint8_t hwid[2];