Public Types | Public Member Functions | Public Attributes | Protected Member Functions | Private Attributes
Ladybug2Driver Class Reference

IRI ROS Specific Driver Class. More...

#include <ladybug2_driver.h>

Inheritance diagram for Ladybug2Driver:
Inheritance graph
[legend]

List of all members.

Public Types

typedef
iri_ladybug2::Ladybug2Config 
Config
 define config type

Public Member Functions

bool closeDriver (void)
 close driver
void config_update (Config &new_cfg, uint32_t level=0)
 config update
void get_calibration_files (std::vector< std::string > &calibration_files)
void get_current_config (TCameraConfig *current_conf)
void get_frame_ids (std::vector< std::string > &frame_ids)
void get_images (char **front, char **front_right, char **rear_right, char **rear_left, char **front_left, char **top)
std::string get_new_frame_event (void)
 Ladybug2Driver (void)
 constructor
bool openDriver (void)
 open driver
bool startDriver (void)
 start driver
bool stopDriver (void)
 stop driver
 ~Ladybug2Driver (void)
 Destructor.

Public Attributes

Config config_
 config variable

Protected Member Functions

void change_config (TCameraConfig *new_conf)

Private Attributes

std::vector< std::string > calibration_files
CLadyBug * camera
uint64_t camera_id
TCameraConfig current_conf
TCameraConfig default_conf
TCameraConfig desired_conf
std::vector< std::string > frame_ids
CFirewireServer * server

Detailed Description

IRI ROS Specific Driver Class.

This class inherits from the IRI Base class IriBaseDriver, which provides the guidelines to implement any specific driver. The IriBaseDriver class offers an easy framework to integrate functional drivers implemented in C++ with the ROS driver structure. ROS driver_base state transitions are already managed by IriBaseDriver.

The Ladybug2Driver class must implement all specific driver requirements to safetely open, close, run and stop the driver at any time. It also must guarantee an accessible interface for all driver's parameters.

The Ladybug2Config.cfg needs to be filled up with those parameters suitable to be changed dynamically by the ROS dyanmic reconfigure application. The implementation of the CIriNode class will manage those parameters through methods like postNodeOpenHook() and reconfigureNodeHook().

Definition at line 68 of file ladybug2_driver.h.


Member Typedef Documentation

typedef iri_ladybug2::Ladybug2Config Ladybug2Driver::Config

define config type

Define a Config type with the Ladybug2Config. All driver implementations will then use the same variable type Config.

Definition at line 99 of file ladybug2_driver.h.


Constructor & Destructor Documentation

constructor

In this constructor parameters related to the specific driver can be initalized. Those parameters can be also set in the openDriver() function. Attributes from the main node driver class IriBaseDriver such as loop_rate, may be also overload here.

Definition at line 3 of file ladybug2_driver.cpp.

Destructor.

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

Definition at line 292 of file ladybug2_driver.cpp.


Member Function Documentation

void Ladybug2Driver::change_config ( TCameraConfig new_conf) [protected]

Definition at line 196 of file ladybug2_driver.cpp.

bool Ladybug2Driver::closeDriver ( void  ) [virtual]

close driver

In this function, the driver must be closed. Variables related to the driver state must also be taken into account. This function is automatically called by IriBaseDriver::doClose(), an state transition is performed if return value equals true.

Returns:
bool successful

Implements iri_base_driver::IriBaseDriver.

Definition at line 69 of file ladybug2_driver.cpp.

void Ladybug2Driver::config_update ( Config new_cfg,
uint32_t  level = 0 
)

config update

In this function the driver parameters must be updated with the input config variable. Then the new configuration state will be stored in the Config attribute.

Parameters:
new_cfgthe new driver configuration state
levellevel in which the update is taken place

Definition at line 120 of file ladybug2_driver.cpp.

void Ladybug2Driver::get_calibration_files ( std::vector< std::string > &  calibration_files)

Definition at line 274 of file ladybug2_driver.cpp.

Definition at line 241 of file ladybug2_driver.cpp.

void Ladybug2Driver::get_frame_ids ( std::vector< std::string > &  frame_ids)

Definition at line 283 of file ladybug2_driver.cpp.

void Ladybug2Driver::get_images ( char **  front,
char **  front_right,
char **  rear_right,
char **  rear_left,
char **  front_left,
char **  top 
)

Definition at line 249 of file ladybug2_driver.cpp.

std::string Ladybug2Driver::get_new_frame_event ( void  )

Definition at line 264 of file ladybug2_driver.cpp.

bool Ladybug2Driver::openDriver ( void  ) [virtual]

open driver

In this function, the driver must be openned. Openning errors must be taken into account. This function is automatically called by IriBaseDriver::doOpen(), an state transition is performed if return value equals true.

Returns:
bool successful

Implements iri_base_driver::IriBaseDriver.

Definition at line 40 of file ladybug2_driver.cpp.

bool Ladybug2Driver::startDriver ( void  ) [virtual]

start driver

After this function, the driver and its thread will be started. The driver and related variables should be properly setup. This function is automatically called by IriBaseDriver::doStart(), an state transition is performed if return value equals true.

Returns:
bool successful

Implements iri_base_driver::IriBaseDriver.

Definition at line 80 of file ladybug2_driver.cpp.

bool Ladybug2Driver::stopDriver ( void  ) [virtual]

stop driver

After this function, the driver's thread will stop its execution. The driver and related variables should be properly setup. This function is automatically called by IriBaseDriver::doStop(), an state transition is performed if return value equals true.

Returns:
bool successful

Implements iri_base_driver::IriBaseDriver.

Definition at line 100 of file ladybug2_driver.cpp.


Member Data Documentation

Definition at line 83 of file ladybug2_driver.h.

CLadyBug* Ladybug2Driver::camera [private]

Definition at line 72 of file ladybug2_driver.h.

uint64_t Ladybug2Driver::camera_id [private]

Definition at line 75 of file ladybug2_driver.h.

config variable

This variable has all the driver parameters defined in the cfg config file. Is updated everytime function config_update() is called.

Definition at line 107 of file ladybug2_driver.h.

Definition at line 79 of file ladybug2_driver.h.

Definition at line 77 of file ladybug2_driver.h.

Definition at line 81 of file ladybug2_driver.h.

std::vector<std::string> Ladybug2Driver::frame_ids [private]

Definition at line 85 of file ladybug2_driver.h.

CFirewireServer* Ladybug2Driver::server [private]

Definition at line 73 of file ladybug2_driver.h.


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


iri_ladybug2
Author(s): Sergi Hernandez Juan
autogenerated on Fri Dec 6 2013 22:35:11