mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-05 07:28:29 -04:00
AP_Gripper: add grabbed and released method
This commit is contained in:
parent
289aba4350
commit
4a1439ca0b
@ -111,3 +111,21 @@ PASS_TO_BACKEND(release)
|
|||||||
PASS_TO_BACKEND(update)
|
PASS_TO_BACKEND(update)
|
||||||
|
|
||||||
#undef PASS_TO_BACKEND
|
#undef PASS_TO_BACKEND
|
||||||
|
|
||||||
|
|
||||||
|
#define PASS_TO_BACKEND(function_name) \
|
||||||
|
bool AP_Gripper::function_name() const \
|
||||||
|
{ \
|
||||||
|
if (!enabled()) { \
|
||||||
|
return false; \
|
||||||
|
} \
|
||||||
|
if (backend != nullptr) { \
|
||||||
|
return backend->function_name(); \
|
||||||
|
} \
|
||||||
|
return false; \
|
||||||
|
}
|
||||||
|
|
||||||
|
PASS_TO_BACKEND(released)
|
||||||
|
PASS_TO_BACKEND(grabbed)
|
||||||
|
|
||||||
|
#undef PASS_TO_BACKEND
|
||||||
|
@ -35,6 +35,12 @@ public:
|
|||||||
// release - move the servo output to the release position
|
// release - move the servo output to the release position
|
||||||
void release();
|
void release();
|
||||||
|
|
||||||
|
// released - returns true if currently in released position
|
||||||
|
bool released() const;
|
||||||
|
|
||||||
|
// grabbed - returns true if currently in grabbed position
|
||||||
|
bool grabbed() const;
|
||||||
|
|
||||||
// update - should be called at at least 10hz
|
// update - should be called at at least 10hz
|
||||||
void update();
|
void update();
|
||||||
|
|
||||||
|
@ -34,6 +34,12 @@ public:
|
|||||||
// release - move the servo output to the release position
|
// release - move the servo output to the release position
|
||||||
virtual void release() = 0;
|
virtual void release() = 0;
|
||||||
|
|
||||||
|
// released - returns true if currently in released position
|
||||||
|
virtual bool released() const = 0;
|
||||||
|
|
||||||
|
// grabbed - returns true if currently in grabbed position
|
||||||
|
virtual bool grabbed() const = 0;
|
||||||
|
|
||||||
// type-specific intiailisations:
|
// type-specific intiailisations:
|
||||||
virtual void init_gripper() = 0;
|
virtual void init_gripper() = 0;
|
||||||
|
|
||||||
|
@ -54,7 +54,7 @@ void AP_Gripper_EPM::grab()
|
|||||||
else
|
else
|
||||||
#endif
|
#endif
|
||||||
{
|
{
|
||||||
// move the servo to the release position
|
// move the servo output to the grab position
|
||||||
RC_Channel_aux::set_radio(RC_Channel_aux::k_gripper, config.grab_pwm);
|
RC_Channel_aux::set_radio(RC_Channel_aux::k_gripper, config.grab_pwm);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -121,3 +121,17 @@ UAVCANCommand AP_Gripper_EPM::make_uavcan_command(uint16_t command) const
|
|||||||
return cmd;
|
return cmd;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool AP_Gripper_EPM::released() const
|
||||||
|
{
|
||||||
|
// we assume instanteous releasing ATM:
|
||||||
|
return (config.state == AP_Gripper::STATE_GRABBED ||
|
||||||
|
config.state == AP_Gripper::STATE_GRABBING);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool AP_Gripper_EPM::grabbed() const
|
||||||
|
{
|
||||||
|
// we assume instanteous grabbing ATM:
|
||||||
|
return (config.state == AP_Gripper::STATE_GRABBED ||
|
||||||
|
config.state == AP_Gripper::STATE_GRABBING);
|
||||||
|
}
|
||||||
|
@ -35,6 +35,12 @@ public:
|
|||||||
// release - move the EPM pwm output to the release position
|
// release - move the EPM pwm output to the release position
|
||||||
void release() override;
|
void release() override;
|
||||||
|
|
||||||
|
// grabbed - returns true if gripper in grabbed state
|
||||||
|
bool grabbed() const override;
|
||||||
|
|
||||||
|
// released - returns true if gripper in released state
|
||||||
|
bool released() const override;
|
||||||
|
|
||||||
// update - moves the pwm back to neutral after the timeout has passed
|
// update - moves the pwm back to neutral after the timeout has passed
|
||||||
// should be called at at least 10hz
|
// should be called at at least 10hz
|
||||||
void update_gripper() override;
|
void update_gripper() override;
|
||||||
|
@ -5,20 +5,53 @@ extern const AP_HAL::HAL& hal;
|
|||||||
void AP_Gripper_Servo::init_gripper()
|
void AP_Gripper_Servo::init_gripper()
|
||||||
{
|
{
|
||||||
// move the servo to the release position
|
// move the servo to the release position
|
||||||
RC_Channel_aux::set_radio(RC_Channel_aux::k_gripper, config.release_pwm);
|
release();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AP_Gripper_Servo::grab()
|
void AP_Gripper_Servo::grab()
|
||||||
{
|
{
|
||||||
// move the servo to the release position
|
// move the servo to the grab position
|
||||||
RC_Channel_aux::set_radio(RC_Channel_aux::k_gripper, config.grab_pwm);
|
RC_Channel_aux::set_radio(RC_Channel_aux::k_gripper, config.grab_pwm);
|
||||||
|
action_timestamp = AP_HAL::millis();
|
||||||
}
|
}
|
||||||
|
|
||||||
void AP_Gripper_Servo::release()
|
void AP_Gripper_Servo::release()
|
||||||
{
|
{
|
||||||
// move the servo to the release position
|
// move the servo to the release position
|
||||||
RC_Channel_aux::set_radio(RC_Channel_aux::k_gripper, config.release_pwm);
|
RC_Channel_aux::set_radio(RC_Channel_aux::k_gripper, config.release_pwm);
|
||||||
|
action_timestamp = AP_HAL::millis();
|
||||||
}
|
}
|
||||||
|
|
||||||
// type-specific periodic updates:
|
bool AP_Gripper_Servo::has_state_pwm(const uint16_t pwm) const
|
||||||
|
{
|
||||||
|
// return true if servo is in position represented by pwm
|
||||||
|
int16_t current_pwm;
|
||||||
|
if (!RC_Channel_aux::get_radio(RC_Channel_aux::k_gripper, current_pwm)) {
|
||||||
|
// function not assigned to a channel, perhaps?
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (current_pwm != pwm) {
|
||||||
|
// last action did not set pwm to the current value
|
||||||
|
// (e.g. last action was a grabm not a release)
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (AP_HAL::millis() - action_timestamp < action_time) {
|
||||||
|
// servo still moving....
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
bool AP_Gripper_Servo::released() const
|
||||||
|
{
|
||||||
|
return has_state_pwm(config.release_pwm);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool AP_Gripper_Servo::grabbed() const
|
||||||
|
{
|
||||||
|
return has_state_pwm(config.grab_pwm);
|
||||||
|
}
|
||||||
|
|
||||||
|
// type-specific periodic updates:
|
||||||
void AP_Gripper_Servo::update_gripper() { };
|
void AP_Gripper_Servo::update_gripper() { };
|
||||||
|
@ -30,6 +30,12 @@ public:
|
|||||||
// release - move the servo output to the release position
|
// release - move the servo output to the release position
|
||||||
void release() override;
|
void release() override;
|
||||||
|
|
||||||
|
// grabbed - returns true if gripper in grabbed state
|
||||||
|
bool grabbed() const override;
|
||||||
|
|
||||||
|
// released - returns true if gripper in released state
|
||||||
|
bool released() const override;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
// type-specific intiailisations:
|
// type-specific intiailisations:
|
||||||
@ -37,4 +43,11 @@ protected:
|
|||||||
|
|
||||||
// type-specific periodic updates:
|
// type-specific periodic updates:
|
||||||
void update_gripper() override;
|
void update_gripper() override;
|
||||||
|
|
||||||
|
private:
|
||||||
|
|
||||||
|
uint32_t action_timestamp; // ms; time grab or release happened
|
||||||
|
const uint16_t action_time = 3000; // ms; time to grab or release
|
||||||
|
|
||||||
|
bool has_state_pwm(const uint16_t pwm) const;
|
||||||
};
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user