123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140 |
- /// @file AP_Camera.h
- /// @brief Photo or video camera manager, with EEPROM-backed storage of constants.
- #pragma once
- #include <AP_Param/AP_Param.h>
- #include <GCS_MAVLink/GCS.h>
- #define AP_CAMERA_TRIGGER_TYPE_SERVO 0
- #define AP_CAMERA_TRIGGER_TYPE_RELAY 1
- #define AP_CAMERA_TRIGGER_DEFAULT_TRIGGER_TYPE AP_CAMERA_TRIGGER_TYPE_SERVO // default is to use servo to trigger camera
- #define AP_CAMERA_TRIGGER_DEFAULT_DURATION 10 // default duration servo or relay is held open in 10ths of a second (i.e. 10 = 1 second)
- #define AP_CAMERA_SERVO_ON_PWM 1300 // default PWM value to move servo to when shutter is activated
- #define AP_CAMERA_SERVO_OFF_PWM 1100 // default PWM value to move servo to when shutter is deactivated
- #define AP_CAMERA_FEEDBACK_DEFAULT_FEEDBACK_PIN -1 // default is to not use camera feedback pin
- /// @class Camera
- /// @brief Object managing a Photo or video camera
- class AP_Camera {
- public:
- AP_Camera(uint32_t _log_camera_bit, const struct Location &_loc)
- : log_camera_bit(_log_camera_bit)
- , current_loc(_loc)
- {
- AP_Param::setup_object_defaults(this, var_info);
- _singleton = this;
- }
- /* Do not allow copies */
- AP_Camera(const AP_Camera &other) = delete;
- AP_Camera &operator=(const AP_Camera&) = delete;
- // get singleton instance
- static AP_Camera *get_singleton()
- {
- return _singleton;
- }
- // MAVLink methods
- void control_msg(const mavlink_message_t &msg);
- void send_feedback(mavlink_channel_t chan);
- // Command processing
- void configure(float shooting_mode, float shutter_speed, float aperture, float ISO, float exposure_type, float cmd_id, float engine_cutoff_time);
- // handle camera control
- void control(float session, float zoom_pos, float zoom_step, float focus_lock, float shooting_cmd, float cmd_id);
- // set camera trigger distance in a mission
- void set_trigger_distance(uint32_t distance_m)
- {
- _trigg_dist.set(distance_m);
- }
- void take_picture();
- // Update - to be called periodically @at least 10Hz
- void update();
- // update camera trigger - 50Hz
- void update_trigger();
- static const struct AP_Param::GroupInfo var_info[];
- // set if vehicle is in AUTO mode
- void set_is_auto_mode(bool enable)
- {
- _is_in_auto_mode = enable;
- }
- enum camera_types {
- CAMERA_TYPE_STD,
- CAMERA_TYPE_BMMCC
- };
- private:
- static AP_Camera *_singleton;
- AP_Int8 _trigger_type; // 0:Servo,1:Relay
- AP_Int8 _trigger_duration; // duration in 10ths of a second that the camera shutter is held open
- AP_Int8 _relay_on; // relay value to trigger camera
- AP_Int16 _servo_on_pwm; // PWM value to move servo to when shutter is activated
- AP_Int16 _servo_off_pwm; // PWM value to move servo to when shutter is deactivated
- uint8_t _trigger_counter; // count of number of cycles shutter has been held open
- uint8_t _trigger_counter_cam_function; // count of number of cycles alternative camera function has been held open
- AP_Int8 _auto_mode_only; // if 1: trigger by distance only if in AUTO mode.
- AP_Int8 _type; // Set the type of camera in use, will open additional parameters if set
- bool _is_in_auto_mode; // true if in AUTO mode
- void servo_pic(); // Servo operated camera
- void relay_pic(); // basic relay activation
- void feedback_pin_timer();
- void feedback_pin_isr(uint8_t, bool, uint32_t);
- void setup_feedback_callback(void);
- AP_Float _trigg_dist; // distance between trigger points (meters)
- AP_Int16 _min_interval; // Minimum time between shots required by camera
- AP_Int16 _max_roll; // Maximum acceptable roll angle when trigging camera
- uint32_t _last_photo_time; // last time a photo was taken
- struct Location _last_location;
- uint16_t _image_index; // number of pictures taken since boot
- // pin number for accurate camera feedback messages
- AP_Int8 _feedback_pin;
- AP_Int8 _feedback_polarity;
- uint32_t _camera_trigger_count;
- uint32_t _camera_trigger_logged;
- uint32_t _feedback_timestamp_us;
- bool _timer_installed;
- bool _isr_installed;
- uint8_t _last_pin_state;
- void log_picture();
- uint32_t log_camera_bit;
- const struct Location ¤t_loc;
- // entry point to trip local shutter (e.g. by relay or servo)
- void trigger_pic();
- // de-activate the trigger after some delay, but without using a delay() function
- // should be called at 50hz from main program
- void trigger_pic_cleanup();
- // return true if we are using a feedback pin
- bool using_feedback_pin(void) const
- {
- return _feedback_pin > 0;
- }
- };
- namespace AP {
- AP_Camera *camera();
- };
|