#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