mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-22 16:48:29 -04:00
AP_Scripting: Lua applet starts/stops video recording on arm/disarm
This commit is contained in:
parent
0bef5a9dab
commit
205329575a
68
libraries/AP_Scripting/applets/runcam_on_arm.lua
Normal file
68
libraries/AP_Scripting/applets/runcam_on_arm.lua
Normal file
@ -0,0 +1,68 @@
|
||||
-- runcam_on_arm.lua: start and stop video recording on arm/disarm
|
||||
--
|
||||
-- ArduPilot can turn a RUNCAM on and off with a TX switch if you set
|
||||
-- its function to 78:RunCamControl. This script uses
|
||||
-- `rc:run_aux_function()' to start and stop the camera without human
|
||||
-- intervention or a separate RC channel.
|
||||
--
|
||||
-- An interesting aspect of this script is variable rescheduling
|
||||
-- time. RUNCAM serial protocol controls the camera by simulating a
|
||||
-- button press both to start and stop recording--it's the same
|
||||
-- button. If you send commands faster than the camera can process
|
||||
-- them, it can ignore a command and interpret the next one as the
|
||||
-- opposite of what you intend, e.g., you may lose a button press to
|
||||
-- stop recording, and the camera keeps rolling; when you're ready to
|
||||
-- start recording again, the camera interprets your button press as a
|
||||
-- command to stop recording. To address this, AP has a special
|
||||
-- parameter, `CAM_RC_BTN_DELAY'. I use this parameter as the
|
||||
-- rescheduling delay after a button press. But between button
|
||||
-- presses, I want the script to be responsive and start recording as
|
||||
-- soon as the vehicle arms, so there I use a shorter delay.
|
||||
|
||||
|
||||
-- constants
|
||||
local RC_OPTION = {RunCamControl=78}
|
||||
local AuxSwitchPos = {LOW=0, MIDDLE=1, HIGH=2}
|
||||
local MAV_SEVERITY = {EMERGENCY=0, ALERT=1, CRITICAL=2, ERROR=3, WARNING=4, NOTICE=5, INFO=6, DEBUG=7}
|
||||
|
||||
-- configuration
|
||||
local DELAY_LONG = param:get("CAM_RC_BTN_DELAY")
|
||||
if not DELAY_LONG then
|
||||
gcs:send_text(MAV_SEVERITY.ERROR, "CAM_RC_* parameters missing; camera autoarming unavailable")
|
||||
return
|
||||
end
|
||||
local DELAY_SHORT = DELAY_LONG / 3
|
||||
|
||||
|
||||
gcs:send_text(MAV_SEVERITY.NOTICE, "Arming controls RUNCAM recording")
|
||||
|
||||
|
||||
-- state
|
||||
local prev_armed = false
|
||||
|
||||
function update()
|
||||
local is_armed = arming:is_armed()
|
||||
|
||||
local delay = DELAY_SHORT
|
||||
|
||||
if is_armed ~= prev_armed then
|
||||
-- a state transition has occurred
|
||||
if is_armed then
|
||||
gcs:send_text(MAV_SEVERITY.INFO, "RUNCAM on")
|
||||
rc:run_aux_function(RC_OPTION.RunCamControl, AuxSwitchPos.HIGH)
|
||||
else
|
||||
gcs:send_text(MAV_SEVERITY.INFO, "RUNCAM off")
|
||||
rc:run_aux_function(RC_OPTION.RunCamControl, AuxSwitchPos.LOW)
|
||||
end
|
||||
delay = DELAY_LONG
|
||||
else
|
||||
delay = DELAY_SHORT
|
||||
end
|
||||
|
||||
prev_armed = is_armed
|
||||
|
||||
return update, delay
|
||||
end
|
||||
|
||||
return update()
|
||||
|
19
libraries/AP_Scripting/applets/runcam_on_arm.md
Normal file
19
libraries/AP_Scripting/applets/runcam_on_arm.md
Normal file
@ -0,0 +1,19 @@
|
||||
# `runcam_on_arm.lua`: start and stop video recording on arm/disarm
|
||||
|
||||
ArduPilot can control RunCam devices out of the box.
|
||||
Normally, you use a 2-position switch with `RCx_OPTION=78:RunCamControl` to start and stop video recording.
|
||||
This applet starts recording automatically when your vehicle arms and stops on disarm.
|
||||
|
||||
Information on setting up RunCam devices with ArduPilot is on this page: https://ardupilot.org/plane/docs/common-camera-runcam.html
|
||||
You need a free serial port.
|
||||
You need to set these three parameters: `SERIALx_PROTOCOL=26`, `SERIALx_BAUD=115` (where `x` is your serial port) and `CAM_RC_TYPE=y` where `y` depends on the RunCam model you are using.
|
||||
You do not need to configure any `RCx_OPTION`s.
|
||||
|
||||
## If camera commands get out of sync
|
||||
|
||||
RUNCAM serial protocol controls the camera by simulating a button press both to start and stop recording--it's the same button.
|
||||
If you send commands faster than the camera can process them, it can ignore a command and interpret the next one as the opposite of what you intend, e.g., you may lose a button press to stop recording, and the camera keeps rolling; when you're ready to start recording again, the camera interprets your button press as a
|
||||
command to stop recording.
|
||||
To address this, AP has a special parameter, `CAM_RC_BTN_DELAY`, that controls minimum time between simulated button presses.
|
||||
If you find your commands getting out of sync--camera starting when you want it to stop--try increasing this value.
|
||||
I find that with my RunCam Split HD, the default 300ms is inadequate, and 1500ms gives reliable performance.
|
Loading…
Reference in New Issue
Block a user