Ardupilot2/libraries/RC_Channel/SRV_Channel.h
Andrew Tridgell 992bf2368e RC_Channel: cope with SERVO_RNG_ENABLE changing while booted
this prevents a one second throttle up on scaled ESCs when
enabling/disabling the servo output mapping
2016-10-15 16:59:37 +11:00

60 lines
1.6 KiB
C++

// -*- tab-width: 4; Mode: C++; c-basic-offset: 4; indent-tabs-mode: nil -*-
/*
control of servo output ranges, trim and servo reversal. This can
optionally be used to provide separation of input and output channel
ranges so that RCn_MIN, RCn_MAX, RCn_TRIM and RCn_REV only apply to
the input side of RC_Channel
It works by running servo output calculations as normal, then
re-mapping the output according to the servo MIN/MAX/TRIM/REV from
this object
Only 4 channels of ranges are defined as those match the input
channels for R/C sticks
*/
#pragma once
#include <AP_Common/AP_Common.h>
#include <AP_Param/AP_Param.h>
#include "RC_Channel.h"
#define NUM_SERVO_RANGE_CHANNELS 4
/*
class SRV_Channel
*/
class SRV_Channels {
public:
// constructor
SRV_Channels(void);
static const struct AP_Param::GroupInfo var_info[];
// take current radio_out for first 4 channels and remap using
// servo ranges if enabled
void remap_servo_output(void);
// set and save trim values from current RC input trim
void set_trim(void);
// setup output ESC scaling for a channel
void set_esc_scaling(uint8_t chnum);
private:
AP_Int8 enable;
int8_t esc_cal_chan;
bool last_enable;
// PWM values for min/max and trim
AP_Int16 servo_min[NUM_SERVO_RANGE_CHANNELS];
AP_Int16 servo_max[NUM_SERVO_RANGE_CHANNELS];
AP_Int16 servo_trim[NUM_SERVO_RANGE_CHANNELS];
// reversal, following convention that < 0 means reversed, >= 0 means normal
AP_Int8 reverse[NUM_SERVO_RANGE_CHANNELS];
// remap a PWM value from a channel in value
uint16_t remap_pwm(uint8_t ch, uint16_t pwm) const;
};