2018-04-13 23:22:14 -03:00
# pragma once
2020-07-06 10:36:58 -03:00
# include "RC_Channel.h"
2018-04-13 23:22:14 -03:00
/*
this header file is expected to be # included by Vehicle subclasses
of RC_Channels after defining RC_CHANNELS_SUBCLASS and
RC_CHANNEL_SUBCLASS - for example , Rover defines
2020-03-26 21:51:16 -03:00
RC_CHANNELS_SUBCLASS to be RC_Channels_Rover in Rover / RC_Channels . cpp , and then includes this header .
2018-04-13 23:22:14 -03:00
This scheme reduces code duplicate between the Vehicles , and avoids the chance of things getting out of sync .
*/
const AP_Param : : GroupInfo RC_Channels : : var_info [ ] = {
// @Group: 1_
// @Path: RC_Channel.cpp
AP_SUBGROUPINFO ( obj_channels [ 0 ] , " 1_ " , 1 , RC_CHANNELS_SUBCLASS , RC_CHANNEL_SUBCLASS ) ,
// @Group: 2_
// @Path: RC_Channel.cpp
AP_SUBGROUPINFO ( obj_channels [ 1 ] , " 2_ " , 2 , RC_CHANNELS_SUBCLASS , RC_CHANNEL_SUBCLASS ) ,
// @Group: 3_
// @Path: RC_Channel.cpp
AP_SUBGROUPINFO ( obj_channels [ 2 ] , " 3_ " , 3 , RC_CHANNELS_SUBCLASS , RC_CHANNEL_SUBCLASS ) ,
// @Group: 4_
// @Path: RC_Channel.cpp
AP_SUBGROUPINFO ( obj_channels [ 3 ] , " 4_ " , 4 , RC_CHANNELS_SUBCLASS , RC_CHANNEL_SUBCLASS ) ,
// @Group: 5_
// @Path: RC_Channel.cpp
AP_SUBGROUPINFO ( obj_channels [ 4 ] , " 5_ " , 5 , RC_CHANNELS_SUBCLASS , RC_CHANNEL_SUBCLASS ) ,
// @Group: 6_
// @Path: RC_Channel.cpp
AP_SUBGROUPINFO ( obj_channels [ 5 ] , " 6_ " , 6 , RC_CHANNELS_SUBCLASS , RC_CHANNEL_SUBCLASS ) ,
// @Group: 7_
// @Path: RC_Channel.cpp
AP_SUBGROUPINFO ( obj_channels [ 6 ] , " 7_ " , 7 , RC_CHANNELS_SUBCLASS , RC_CHANNEL_SUBCLASS ) ,
// @Group: 8_
// @Path: RC_Channel.cpp
AP_SUBGROUPINFO ( obj_channels [ 7 ] , " 8_ " , 8 , RC_CHANNELS_SUBCLASS , RC_CHANNEL_SUBCLASS ) ,
// @Group: 9_
// @Path: RC_Channel.cpp
AP_SUBGROUPINFO ( obj_channels [ 8 ] , " 9_ " , 9 , RC_CHANNELS_SUBCLASS , RC_CHANNEL_SUBCLASS ) ,
// @Group: 10_
// @Path: RC_Channel.cpp
AP_SUBGROUPINFO ( obj_channels [ 9 ] , " 10_ " , 10 , RC_CHANNELS_SUBCLASS , RC_CHANNEL_SUBCLASS ) ,
// @Group: 11_
// @Path: RC_Channel.cpp
AP_SUBGROUPINFO ( obj_channels [ 10 ] , " 11_ " , 11 , RC_CHANNELS_SUBCLASS , RC_CHANNEL_SUBCLASS ) ,
// @Group: 12_
// @Path: RC_Channel.cpp
AP_SUBGROUPINFO ( obj_channels [ 11 ] , " 12_ " , 12 , RC_CHANNELS_SUBCLASS , RC_CHANNEL_SUBCLASS ) ,
// @Group: 13_
// @Path: RC_Channel.cpp
AP_SUBGROUPINFO ( obj_channels [ 12 ] , " 13_ " , 13 , RC_CHANNELS_SUBCLASS , RC_CHANNEL_SUBCLASS ) ,
// @Group: 14_
// @Path: RC_Channel.cpp
AP_SUBGROUPINFO ( obj_channels [ 13 ] , " 14_ " , 14 , RC_CHANNELS_SUBCLASS , RC_CHANNEL_SUBCLASS ) ,
// @Group: 15_
// @Path: RC_Channel.cpp
AP_SUBGROUPINFO ( obj_channels [ 14 ] , " 15_ " , 15 , RC_CHANNELS_SUBCLASS , RC_CHANNEL_SUBCLASS ) ,
// @Group: 16_
// @Path: RC_Channel.cpp
AP_SUBGROUPINFO ( obj_channels [ 15 ] , " 16_ " , 16 , RC_CHANNELS_SUBCLASS , RC_CHANNEL_SUBCLASS ) ,
// @Param: _OVERRIDE_TIME
// @DisplayName: RC override timeout
// @Description: Timeout after which RC overrides will no longer be used, and RC input will resume, 0 will disable RC overrides, -1 will never timeout, and continue using overrides until they are disabled
// @User: Advanced
// @Range: 0.0 120.0
// @Units: s
AP_GROUPINFO ( " _OVERRIDE_TIME " , 32 , RC_CHANNELS_SUBCLASS , _override_timeout , 3.0 ) ,
// @Param: _OPTIONS
// @DisplayName: RC options
// @Description: RC input options
// @User: Advanced
2021-12-19 10:35:22 -04:00
// @Bitmask: 0:Ignore RC Receiver, 1:Ignore MAVLink Overrides, 2:Ignore Receiver Failsafe bit but allow other RC failsafes if setup, 3:FPort Pad, 4:Log RC input bytes, 5:Arming check throttle for 0 input, 6:Skip the arming check for neutral Roll/Pitch/Yaw sticks, 7:Allow Switch reverse, 8:Use passthrough for CRSF telemetry, 9:Suppress CRSF mode/rate message for ELRS systems,10:Enable multiple receiver support, 11:CRSF RSSI shows Link Quality
2020-07-06 10:36:58 -03:00
AP_GROUPINFO ( " _OPTIONS " , 33 , RC_CHANNELS_SUBCLASS , _options , ( uint32_t ) RC_Channels : : Option : : ARMING_CHECK_THROTTLE ) ,
2018-04-13 23:22:14 -03:00
2020-08-12 23:28:28 -03:00
// @Param: _PROTOCOLS
// @DisplayName: RC protocols enabled
// @Description: Bitmask of enabled RC protocols. Allows narrowing the protocol detection to only specific types of RC receivers which can avoid issues with incorrect detection. Set to 1 to enable all protocols.
// @User: Advanced
2021-11-05 02:39:56 -03:00
// @Bitmask: 0:All,1:PPM,2:IBUS,3:SBUS,4:SBUS_NI,5:DSM,6:SUMD,7:SRXL,8:SRXL2,9:CRSF,10:ST24,11:FPORT,12:FPORT2,13:FastSBUS
2020-08-12 23:28:28 -03:00
AP_GROUPINFO ( " _PROTOCOLS " , 34 , RC_CHANNELS_SUBCLASS , _protocols , 1 ) ,
2022-11-14 22:25:34 -04:00
// @Param: _FS_TIMEOUT
// @DisplayName: RC Failsafe timeout
// @Description: RC failsafe will trigger this many seconds after loss of RC
// @User: Standard
// @Range: 0.5 10.0
// @Units: s
AP_GROUPINFO_FRAME ( " _FS_TIMEOUT " , 35 , RC_CHANNELS_SUBCLASS , _fs_timeout , 1.0 , AP_PARAM_FRAME_COPTER ) ,
2018-04-13 23:22:14 -03:00
AP_GROUPEND
} ;