Public Member Functions | Protected Member Functions | Private Member Functions | Static Private Member Functions | Private Attributes
IriJoystickDriverNode Class Reference

IRI ROS Specific Driver Class. More...

#include <iri_joystick_driver_node.h>

Inheritance diagram for IriJoystickDriverNode:
Inheritance graph
[legend]

List of all members.

Public Member Functions

 IriJoystickDriverNode (ros::NodeHandle &nh)
 constructor
 ~IriJoystickDriverNode ()
 Destructor.

Protected Member Functions

void addNodeDiagnostics (void)
 node add diagnostics
void addNodeOpenedTests (void)
 open status driver tests
void addNodeRunningTests (void)
 run status driver tests
void addNodeStoppedTests (void)
 stop status driver tests
void joystick_check (diagnostic_updater::DiagnosticStatusWrapper &stat)
void mainNodeThread (void)
 main node thread
void reconfigureNodeHook (int level)
 specific node dynamic reconfigure

Private Member Functions

void button_callback (unsigned int button_id, bool level)
void move_joystick_callback (unsigned int axis_id, float value)
void postNodeOpenHook (void)
 post open hook
void publish_joy_msg (const sensor_msgs::Joy &msg)

Static Private Member Functions

static void wrapper_button_callback (void *param, unsigned int button_id, bool level)
static void wrapper_move_joystick_callback (void *param, unsigned int axis_id, float value)

Private Attributes

ros::Publisher joy_mov_pub_
std::string joy_mov_pub_name_
double total_axes_events_
double total_button_events_
double total_joy_msg_sent_

Detailed Description

IRI ROS Specific Driver Class.

This class inherits from the IRI Core class IriBaseNodeDriver<IriBaseDriver>, to provide an execution thread to the driver object. A complete framework with utilites to test the node functionallity or to add diagnostics to specific situations is also given. The inherit template design form allows complete access to any IriBaseDriver object implementation.

As mentioned, tests in the different driver states can be performed through class methods such as addNodeOpenedTests() or addNodeRunningTests(). Tests common to all nodes may be also executed in the pattern class IriBaseNodeDriver. Similarly to the tests, diagnostics can easyly be added. See ROS Wiki for more details: http://www.ros.org/wiki/diagnostics/ (Tutorials: Creating a Diagnostic Analyzer) http://www.ros.org/wiki/self_test/ (Example: Self Test)

Definition at line 49 of file iri_joystick_driver_node.h.


Constructor & Destructor Documentation

constructor

This constructor mainly creates and initializes the IriJoystickDriverNode topics through the given public_node_handle object. IriBaseNodeDriver attributes may be also modified to suit node specifications.

All kind of ROS topics (publishers, subscribers, servers or clients) can be easyly generated with the scripts in the iri_ros_scripts package. Refer to ROS and IRI Wiki pages for more details:

http://www.ros.org/wiki/ROS/Tutorials/WritingPublisherSubscriber(c++) http://www.ros.org/wiki/ROS/Tutorials/WritingServiceClient(c++) http://wikiri.upc.es/index.php/Robotics_Lab

Parameters:
nha reference to the node handle object to manage all ROS topics.

Definition at line 7 of file iri_joystick_driver_node.cpp.

Destructor.

This destructor is called when the object is about to be destroyed.

Definition at line 164 of file iri_joystick_driver_node.cpp.


Member Function Documentation

void IriJoystickDriverNode::addNodeDiagnostics ( void  ) [protected, virtual]

node add diagnostics

In this function ROS diagnostics applied to this specific node may be added. Common use diagnostics for all nodes are already called from IriBaseNodeDriver::addDiagnostics(), which also calls this function. Information of how ROS diagnostics work can be readen here: http://www.ros.org/wiki/diagnostics/ http://www.ros.org/doc/api/diagnostic_updater/html/example_8cpp-source.html

Implements iri_base_driver::IriBaseNodeDriver< IriJoystickDriver >.

Definition at line 139 of file iri_joystick_driver_node.cpp.

void IriJoystickDriverNode::addNodeOpenedTests ( void  ) [protected, virtual]

open status driver tests

In this function tests checking driver's functionallity when driver_base status=open can be added. Common use tests for all nodes are already called from IriBaseNodeDriver tests methods. For more details on how ROS tests work, please refer to the Self Test example in: http://www.ros.org/wiki/self_test/

Implements iri_base_driver::IriBaseNodeDriver< IriJoystickDriver >.

Definition at line 145 of file iri_joystick_driver_node.cpp.

void IriJoystickDriverNode::addNodeRunningTests ( void  ) [protected, virtual]

run status driver tests

In this function tests checking driver's functionallity when driver_base status=run can be added. Common use tests for all nodes are already called from IriBaseNodeDriver tests methods. For more details on how ROS tests work, please refer to the Self Test example in: http://www.ros.org/wiki/self_test/

Implements iri_base_driver::IriBaseNodeDriver< IriJoystickDriver >.

Definition at line 155 of file iri_joystick_driver_node.cpp.

void IriJoystickDriverNode::addNodeStoppedTests ( void  ) [protected, virtual]

stop status driver tests

In this function tests checking driver's functionallity when driver_base status=stop can be added. Common use tests for all nodes are already called from IriBaseNodeDriver tests methods. For more details on how ROS tests work, please refer to the Self Test example in: http://www.ros.org/wiki/self_test/

Implements iri_base_driver::IriBaseNodeDriver< IriJoystickDriver >.

Definition at line 150 of file iri_joystick_driver_node.cpp.

void IriJoystickDriverNode::button_callback ( unsigned int  button_id,
bool  level 
) [private]

Definition at line 74 of file iri_joystick_driver_node.cpp.

Definition at line 121 of file iri_joystick_driver_node.cpp.

void IriJoystickDriverNode::mainNodeThread ( void  ) [protected, virtual]

main node thread

This is the main thread node function. Code written here will be executed in every node loop while the driver is on running state. Loop frequency can be tuned my modifying loop_rate attribute.

Here data related to the process loop or to ROS topics (mainly data structs related to the MSG and SRV files) must be updated. ROS publisher objects must publish their data in this process. ROS client servers may also request data to the corresponding server topics.

Implements iri_base_driver::IriBaseNodeDriver< IriJoystickDriver >.

Definition at line 98 of file iri_joystick_driver_node.cpp.

void IriJoystickDriverNode::move_joystick_callback ( unsigned int  axis_id,
float  value 
) [private]

Definition at line 43 of file iri_joystick_driver_node.cpp.

void IriJoystickDriverNode::postNodeOpenHook ( void  ) [private, virtual]

post open hook

This function is called by IriBaseNodeDriver::postOpenHook(). In this function specific parameters from the driver must be added so the ROS dynamic reconfigure application can update them.

Implements iri_base_driver::IriBaseNodeDriver< IriJoystickDriver >.

Definition at line 103 of file iri_joystick_driver_node.cpp.

void IriJoystickDriverNode::publish_joy_msg ( const sensor_msgs::Joy &  msg) [private]

Definition at line 59 of file iri_joystick_driver_node.cpp.

void IriJoystickDriverNode::reconfigureNodeHook ( int  level) [protected, virtual]

specific node dynamic reconfigure

This function is called reconfigureHook()

Parameters:
levelinteger

Implements iri_base_driver::IriBaseNodeDriver< IriJoystickDriver >.

Definition at line 160 of file iri_joystick_driver_node.cpp.

void IriJoystickDriverNode::wrapper_button_callback ( void *  param,
unsigned int  button_id,
bool  level 
) [static, private]

Definition at line 66 of file iri_joystick_driver_node.cpp.

void IriJoystickDriverNode::wrapper_move_joystick_callback ( void *  param,
unsigned int  axis_id,
float  value 
) [static, private]

Definition at line 35 of file iri_joystick_driver_node.cpp.


Member Data Documentation

Definition at line 52 of file iri_joystick_driver_node.h.

Definition at line 53 of file iri_joystick_driver_node.h.

Definition at line 56 of file iri_joystick_driver_node.h.

Definition at line 58 of file iri_joystick_driver_node.h.

Definition at line 60 of file iri_joystick_driver_node.h.


The documentation for this class was generated from the following files:


iri_joystick
Author(s): Jose Luis Rivero
autogenerated on Fri Dec 6 2013 23:38:45