mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-11 10:28:29 -04:00
Some cleanup.
This commit is contained in:
parent
1aa8586558
commit
d20d53ee81
@ -14,42 +14,44 @@ namespace apo {
|
|||||||
|
|
||||||
void AP_ArmingMechanism::update(const float dt) {
|
void AP_ArmingMechanism::update(const float dt) {
|
||||||
|
|
||||||
// arming
|
// arming
|
||||||
if ( (_hal->getState() != MAV_STATE_ACTIVE) &
|
if ( (_hal->getState() != MAV_STATE_ACTIVE) &
|
||||||
(_hal->rc[_ch1]->getRadioPosition() < _ch1Min) &&
|
(_hal->rc[_ch1]->getRadioPosition() < _ch1Min) &&
|
||||||
(_hal->rc[_ch2]->getRadioPosition() < _ch2Min) ) {
|
(_hal->rc[_ch2]->getRadioPosition() < _ch2Min) ) {
|
||||||
|
|
||||||
// always start clock at 0
|
// always start clock at 0
|
||||||
if (_armingClock<0) _armingClock = 0;
|
if (_armingClock<0) _armingClock = 0;
|
||||||
|
|
||||||
if (_armingClock++ >= 100) {
|
if (_armingClock++ >= 100) {
|
||||||
_hal->gcs->sendText(SEVERITY_HIGH, PSTR("armed"));
|
_hal->gcs->sendText(SEVERITY_HIGH, PSTR("armed"));
|
||||||
_hal->setState(MAV_STATE_ACTIVE);
|
_hal->setState(MAV_STATE_ACTIVE);
|
||||||
} else {
|
} else {
|
||||||
_hal->gcs->sendText(SEVERITY_HIGH, PSTR("arming"));
|
_hal->gcs->sendText(SEVERITY_HIGH, PSTR("arming"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// disarming
|
// disarming
|
||||||
else if ( (_hal->getState() == MAV_STATE_ACTIVE) &
|
else if ( (_hal->getState() == MAV_STATE_ACTIVE) &
|
||||||
(_hal->rc[_ch1]->getRadioPosition() < _ch1Min) &&
|
(_hal->rc[_ch1]->getRadioPosition() < _ch1Min) &&
|
||||||
(_hal->rc[_ch2]->getRadioPosition() > _ch2Max) ) {
|
(_hal->rc[_ch2]->getRadioPosition() > _ch2Max) ) {
|
||||||
|
|
||||||
// always start clock at 0
|
// always start clock at 0
|
||||||
if (_armingClock>0) _armingClock = 0;
|
if (_armingClock>0) _armingClock = 0;
|
||||||
|
|
||||||
if (_armingClock-- <= -100) {
|
if (_armingClock-- <= -100) {
|
||||||
_hal->gcs->sendText(SEVERITY_HIGH, PSTR("disarmed"));
|
_hal->gcs->sendText(SEVERITY_HIGH, PSTR("disarmed"));
|
||||||
_hal->setState(MAV_STATE_STANDBY);
|
_hal->setState(MAV_STATE_STANDBY);
|
||||||
} else {
|
} else {
|
||||||
_hal->gcs->sendText(SEVERITY_HIGH, PSTR("disarming"));
|
_hal->gcs->sendText(SEVERITY_HIGH, PSTR("disarming"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
// reset arming clock and report status
|
// reset arming clock and report status
|
||||||
else if (_armingClock != 0) {
|
else if (_armingClock != 0) {
|
||||||
_armingClock = 0;
|
_armingClock = 0;
|
||||||
if (_hal->getState()==MAV_STATE_ACTIVE) _hal->gcs->sendText(SEVERITY_HIGH, PSTR("armed"));
|
if (_hal->getState()==MAV_STATE_ACTIVE) _hal->gcs->sendText(SEVERITY_HIGH, PSTR("armed"));
|
||||||
else if (_hal->getState()!=MAV_STATE_ACTIVE) _hal->gcs->sendText(SEVERITY_HIGH, PSTR("disarmed"));
|
else if (_hal->getState()!=MAV_STATE_ACTIVE) _hal->gcs->sendText(SEVERITY_HIGH, PSTR("disarmed"));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
} // apo
|
} // apo
|
||||||
|
|
||||||
|
// vim:ts=4:sw=4:expandtab
|
||||||
|
@ -16,50 +16,52 @@ class AP_HardwareAbstractionLayer;
|
|||||||
class AP_ArmingMechanism {
|
class AP_ArmingMechanism {
|
||||||
|
|
||||||
public:
|
public:
|
||||||
/**
|
/**
|
||||||
* Constructor
|
* Constructor
|
||||||
*
|
*
|
||||||
* @param ch1: typically throttle channel
|
* @param ch1: typically throttle channel
|
||||||
* @param ch2: typically yaw channel
|
* @param ch2: typically yaw channel
|
||||||
* @param ch1Min: disarms/arms belows this
|
* @param ch1Min: disarms/arms belows this
|
||||||
* @param ch2Min: disarms below this
|
* @param ch2Min: disarms below this
|
||||||
* @param ch2Max: arms above this
|
* @param ch2Max: arms above this
|
||||||
*/
|
*/
|
||||||
AP_ArmingMechanism(AP_HardwareAbstractionLayer * hal,
|
AP_ArmingMechanism(AP_HardwareAbstractionLayer * hal,
|
||||||
uint8_t ch1, uint8_t ch2, float ch1Min, float ch2Min,
|
uint8_t ch1, uint8_t ch2, float ch1Min, float ch2Min,
|
||||||
float ch2Max) : _armingClock(0), _hal(hal), _ch1(ch1), _ch2(ch2),
|
float ch2Max) : _armingClock(0), _hal(hal), _ch1(ch1), _ch2(ch2),
|
||||||
_ch1Min(ch1Min), _ch2Min(ch2Min) {
|
_ch1Min(ch1Min), _ch2Min(ch2Min) {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* update
|
* update
|
||||||
*
|
*
|
||||||
* arming:
|
* arming:
|
||||||
*
|
*
|
||||||
* to arm: put stick to bottom right for 100 controller cycles
|
* to arm: put stick to bottom right for 100 controller cycles
|
||||||
* (max yaw, min throttle)
|
* (max yaw, min throttle)
|
||||||
*
|
*
|
||||||
* didn't use clock here in case of millis() roll over
|
* didn't use clock here in case of millis() roll over
|
||||||
* for long runs
|
* for long runs
|
||||||
*
|
*
|
||||||
* disarming:
|
* disarming:
|
||||||
*
|
*
|
||||||
* to disarm: put stick to bottom left for 100 controller cycles
|
* to disarm: put stick to bottom left for 100 controller cycles
|
||||||
* (min yaw, min throttle)
|
* (min yaw, min throttle)
|
||||||
*/
|
*/
|
||||||
void update(const float dt);
|
void update(const float dt);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
AP_HardwareAbstractionLayer * _hal;
|
AP_HardwareAbstractionLayer * _hal;
|
||||||
uint8_t _armingClock;
|
uint8_t _armingClock;
|
||||||
uint8_t _ch1; /// typically throttle channel
|
uint8_t _ch1; /// typically throttle channel
|
||||||
uint8_t _ch2; /// typically yaw channel
|
uint8_t _ch2; /// typically yaw channel
|
||||||
float _ch1Min; /// arms/disarms below this on ch1
|
float _ch1Min; /// arms/disarms below this on ch1
|
||||||
float _ch2Min; /// disarms below this on ch2
|
float _ch2Min; /// disarms below this on ch2
|
||||||
float _ch2Max; /// arms above this on ch2
|
float _ch2Max; /// arms above this on ch2
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace apo
|
} // namespace apo
|
||||||
|
|
||||||
#endif /* AP_ARMINGMECHANISM */
|
#endif /* AP_ARMINGMECHANISM */
|
||||||
|
|
||||||
|
// vim:ts=4:sw=4:expandtab
|
||||||
|
@ -146,3 +146,4 @@ private:
|
|||||||
#endif // AP_Guide_H
|
#endif // AP_Guide_H
|
||||||
|
|
||||||
// vim:ts=4:sw=4:expandtab
|
// vim:ts=4:sw=4:expandtab
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user