99e314f49a
our pattern is to include the config file and then use the relevant define, with nothing in between
49 lines
1.4 KiB
C++
49 lines
1.4 KiB
C++
/*
|
|
SToRM32 mount backend class
|
|
*/
|
|
#pragma once
|
|
|
|
#include "AP_Mount_config.h"
|
|
|
|
#if HAL_MOUNT_STORM32MAVLINK_ENABLED
|
|
|
|
#include "AP_Mount_Backend.h"
|
|
|
|
#include <AP_Math/AP_Math.h>
|
|
#include <AP_Common/AP_Common.h>
|
|
|
|
class AP_Mount_SToRM32 : public AP_Mount_Backend
|
|
{
|
|
|
|
public:
|
|
// Constructor
|
|
using AP_Mount_Backend::AP_Mount_Backend;
|
|
|
|
// update mount position - should be called periodically
|
|
void update() override;
|
|
|
|
// has_pan_control - returns true if this mount can control its pan (required for multicopters)
|
|
bool has_pan_control() const override { return yaw_range_valid(); }
|
|
|
|
protected:
|
|
|
|
// get attitude as a quaternion. returns true on success
|
|
bool get_attitude_quaternion(Quaternion& att_quat) override;
|
|
|
|
private:
|
|
|
|
// search for gimbal in GCS_MAVLink routing table
|
|
void find_gimbal();
|
|
|
|
// send_do_mount_control with latest angle targets
|
|
void send_do_mount_control(const MountTarget& angle_target_rad);
|
|
|
|
// internal variables
|
|
bool _initialised; // true once the driver has been initialised
|
|
uint8_t _sysid; // sysid of gimbal
|
|
uint8_t _compid; // component id of gimbal
|
|
mavlink_channel_t _chan = MAVLINK_COMM_0; // mavlink channel used to communicate with gimbal
|
|
uint32_t _last_send; // system time of last do_mount_control sent to gimbal
|
|
};
|
|
#endif // HAL_MOUNT_STORM32MAVLINK_ENABLED
|