Ardupilot2/libraries/AP_Camera/AP_Camera_Scripting.cpp
2023-07-05 16:28:42 +10:00

60 lines
1.8 KiB
C++

#include "AP_Camera_Scripting.h"
#if AP_CAMERA_SCRIPTING_ENABLED
extern const AP_HAL::HAL& hal;
// entry point to actually take a picture
bool AP_Camera_Scripting::trigger_pic()
{
// increment counter to allow backend to notice request
_cam_state.take_pic_incr++;
return true;
}
// start or stop video recording. returns true on success
// set start_recording = true to start record, false to stop recording
bool AP_Camera_Scripting::record_video(bool start_recording)
{
_cam_state.recording_video = start_recording;
return true;
}
// set zoom specified as a rate or percentage
bool AP_Camera_Scripting::set_zoom(ZoomType zoom_type, float zoom_value)
{
_cam_state.zoom_type = (uint8_t)zoom_type;
_cam_state.zoom_value = zoom_value;
return true;
}
// set focus specified as rate, percentage or auto
// focus in = -1, focus hold = 0, focus out = 1
SetFocusResult AP_Camera_Scripting::set_focus(FocusType focus_type, float focus_value)
{
_cam_state.focus_type = (uint8_t)focus_type;
_cam_state.focus_value = focus_value;
return SetFocusResult::ACCEPTED;
}
// set tracking to none, point or rectangle (see TrackingType enum)
// if POINT only p1 is used, if RECTANGLE then p1 is top-left, p2 is bottom-right
// p1,p2 are in range 0 to 1. 0 is left or top, 1 is right or bottom
bool AP_Camera_Scripting::set_tracking(TrackingType tracking_type, const Vector2f& p1, const Vector2f& p2)
{
_cam_state.tracking_type = (uint8_t)tracking_type;
_cam_state.tracking_p1 = p1;
_cam_state.tracking_p2 = p2;
return true;
}
// access for scripting backend to retrieve state
// returns true on success and cam_state is filled in
bool AP_Camera_Scripting::get_state(AP_Camera::camera_state_t& cam_state)
{
cam_state = _cam_state;
return true;
}
#endif // AP_CAMERA_SCRIPTING_ENABLED