Public Member Functions | |
Erratic (ConfigFile *cf, int section) | |
virtual int | Subscribe (player_devaddr_t id) |
Subscribe to this driver. | |
virtual int | Unsubscribe (player_devaddr_t id) |
Unsubscribe from this driver. | |
virtual void | Main () |
Talking to the Player architecture. | |
virtual int | Setup () |
Initialize the driver. | |
virtual int | Shutdown () |
Finalize the driver. | |
virtual int | ProcessMessage (QueuePointer &resp_queue, player_msghdr *hdr, void *data) |
Message handler. | |
Private Member Functions | |
int | Connect () |
int | Disconnect () |
void | ResetRawPositions () |
void | ToggleMotorPower (unsigned char val) |
void | ToggleAIn (unsigned char val) |
void | ToggleSonar (unsigned char val) |
int | HandleConfig (QueuePointer &resp_queue, player_msghdr *hdr, void *data) |
int | HandleCommand (player_msghdr *hdr, void *data) |
void | HandlePositionCommand (player_position2d_cmd_vel_t position_cmd) |
void | HandleCarCommand (player_position2d_cmd_car_t position_cmd) |
void | HandlePtzCommand (player_ptz_cmd_t ptz_cmd, player_devaddr_t id) |
void | PublishAllData () |
void | PublishPosition2D () |
void | PublishPower () |
void | PublishAIn () |
void | PublishIR () |
void | PublishSonar () |
float | IRRangeFromVoltage (float voltage) |
float | IRFloorRange (float value) |
void | StartThreads () |
void | StopThreads () |
void | Send (ErraticPacket *packet) |
void | SendThread () |
void | ReceiveThread () |
Talking to the robot. | |
Static Private Member Functions | |
static void * | SendThreadDummy (void *driver) |
static void * | ReceiveThreadDummy (void *driver) |
Private Attributes | |
int | mcount |
player_erratic_data_t | erratic_data |
player_devaddr_t | position_id |
player_devaddr_t | power_id |
player_devaddr_t | aio_id |
player_devaddr_t | ir_id |
player_devaddr_t | sonar_id |
player_devaddr_t | ptz_id |
player_devaddr_t | ptz2_id |
int | position_subscriptions |
int | aio_ir_subscriptions |
int | sonar_subscriptions |
int | ptz_subscriptions |
int | ptz2_subscriptions |
ErraticMotorPacket * | motor_packet |
pthread_mutex_t | motor_packet_mutex |
int | read_fd |
int | write_fd |
const char * | psos_serial_port |
player_position2d_cmd_vel_t | last_position_cmd |
player_position2d_cmd_car_t | last_car_cmd |
std::queue< ErraticPacket * > | send_queue |
pthread_mutex_t | send_queue_mutex |
pthread_cond_t | send_queue_cond |
pthread_t | send_thread |
pthread_t | receive_thread |
bool | direct_wheel_vel_control |
bool | print_all_packets |
bool | print_status_summary |
bool | save_settings_in_robot |
int | param_idx |
int | motor_max_speed |
int | motor_max_turnspeed |
int16_t | pid_trans_p |
int16_t | pid_trans_v |
int16_t | pid_trans_i |
int16_t | pid_rot_p |
int16_t | pid_rot_v |
int16_t | pid_rot_i |
uint16_t | motor_pwm_frequency |
uint16_t | motor_pwm_max_on |
bool | use_vel_band |
short | motor_max_trans_accel |
short | motor_max_trans_decel |
short | motor_max_rot_accel |
short | motor_max_rot_decel |
Member Function Documentation
int Erratic::ProcessMessage | ( | QueuePointer & | resp_queue, |
player_msghdr * | hdr, | ||
void * | data | ||
) | [virtual] |
Message handler.
This function is called once for each message in the incoming queue. Reimplement it to provide message handling. Return 0 if you handled the message and -1 otherwise
- Parameters:
-
resp_queue The queue to which any response should go. hdr The message header data The message body
Reimplemented from Driver.
References PLAYER_MSGTYPE_CMD, PLAYER_MSGTYPE_REQ, and player_msghdr::type.
int Erratic::Setup | ( | void | ) | [virtual] |
Initialize the driver.
This function is called with the first client subscribes; it MUST be implemented by the driver.
- Returns:
- Returns 0 on success.
Reimplemented from Driver.
int Erratic::Shutdown | ( | void | ) | [virtual] |
Finalize the driver.
This function is called with the last client unsubscribes.
- Returns:
- Returns 0 on success.
Reimplemented from Driver.
int Erratic::Subscribe | ( | player_devaddr_t | addr | ) | [virtual] |
Subscribe to this driver.
The Subscribe() and Unsubscribe() methods are used to control subscriptions to the driver; a driver MAY override them, but usually won't.
- Parameters:
-
addr Address of the device to subscribe to (the driver may have more than one interface).
- Returns:
- Returns 0 on success.
Reimplemented from Driver.
References Device::MatchDeviceAddress(), and Driver::Subscribe().
int Erratic::Unsubscribe | ( | player_devaddr_t | addr | ) | [virtual] |
Unsubscribe from this driver.
The Subscribe() and Unsubscribe() methods are used to control subscriptions to the driver; a driver MAY override them, but usually won't.
- Parameters:
-
addr Address of the device to unsubscribe from (the driver may have more than one interface).
- Returns:
- Returns 0 on success.
Reimplemented from Driver.
References Device::MatchDeviceAddress(), and Driver::Unsubscribe().
The documentation for this class was generated from the following files:
- erratic.h
- erratic.cc