123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172 |
- /*
- Servo controlled mount backend class
- */
- #pragma once
- #include <AP_Math/AP_Math.h>
- #include <AP_Common/AP_Common.h>
- #include <AP_AHRS/AP_AHRS.h>
- #include <GCS_MAVLink/GCS_MAVLink.h>
- #include <SRV_Channel/SRV_Channel.h>
- #include "AP_Mount_Backend.h"
- class AP_Mount_Servo : public AP_Mount_Backend
- {
- public:
- // Constructor
- AP_Mount_Servo(AP_Mount &frontend, AP_Mount::mount_state &state, uint8_t instance):
- AP_Mount_Backend(frontend, state, instance),
- _roll_idx(SRV_Channel::k_none),
- _tilt_idx(SRV_Channel::k_none),
- _pan_idx(SRV_Channel::k_none),
- _open_idx(SRV_Channel::k_none)
- {
- }
- // init - performs any required initialisation for this instance
- void init() override;
- // update mount position - should be called periodically
- void update() override;
- // has_pan_control - returns true if this mount can control it's pan (required for multicopters)
- bool has_pan_control() const override { return _flags.pan_control; }
- // set_mode - sets mount's mode
- void set_mode(enum MAV_MOUNT_MODE mode) override;
- // send_mount_status - called to allow mounts to send their status to GCS using the MOUNT_STATUS message
- void send_mount_status(mavlink_channel_t chan) override;
- private:
- // flags structure
- struct {
- bool roll_control :1; // true if mount has roll control
- bool tilt_control :1; // true if mount has tilt control
- bool pan_control :1; // true if mount has pan control
- } _flags;
- // check_servo_map - detects which axis we control (i.e. _flags) using the functions assigned to the servos in the SRV_Channel
- // should be called periodically (i.e. 1hz or less)
- void check_servo_map();
- // stabilize - stabilizes the mount relative to the Earth's frame
- void stabilize();
- // closest_limit - returns closest angle to 'angle' taking into account limits. all angles are in degrees * 10
- int16_t closest_limit(int16_t angle, int16_t angle_min, int16_t angle_max);
- /// move_servo - moves servo with the given id to the specified angle. all angles are in degrees * 10
- void move_servo(uint8_t rc, int16_t angle, int16_t angle_min, int16_t angle_max);
- // SRV_Channel - different id numbers are used depending upon the instance number
- SRV_Channel::Aux_servo_function_t _roll_idx; // SRV_Channel mount roll function index
- SRV_Channel::Aux_servo_function_t _tilt_idx; // SRV_Channel mount tilt function index
- SRV_Channel::Aux_servo_function_t _pan_idx; // SRV_Channel mount pan function index
- SRV_Channel::Aux_servo_function_t _open_idx; // SRV_Channel mount open function index
- Vector3f _angle_bf_output_deg; // final body frame output angle in degrees
- uint32_t _last_check_servo_map_ms; // system time of latest call to check_servo_map function
- };
|