naoqidriver
laser.hpp
Go to the documentation of this file.
1 /*
2  * Copyright 2015 Aldebaran
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  *
16 */
17 
18 #ifndef LASER_CONVERTER_HPP
19 #define LASER_CONVERTER_HPP
20 
21 /*
22 * LOCAL includes
23 */
24 #include "converter_base.hpp"
26 
27 /*
28 * ROS includes
29 */
30 #include <sensor_msgs/LaserScan.h>
31 
32 namespace naoqi
33 {
34 namespace converter
35 {
36 
37 class LaserConverter : public BaseConverter<LaserConverter>
38 {
39 
40  typedef boost::function<void(sensor_msgs::LaserScan&)> Callback_t;
41 
42 public:
43  LaserConverter( const std::string& name, const float& frequency, const qi::SessionPtr& session );
44 
45  void registerCallback( message_actions::MessageAction action, Callback_t cb );
46 
47  void callAll( const std::vector<message_actions::MessageAction>& actions );
48 
49  void reset( );
50 
51 private:
52 
53  qi::AnyObject p_memory_;
54 
55  std::map<message_actions::MessageAction, Callback_t> callbacks_;
56  sensor_msgs::LaserScan msg_;
57 }; // class
58 
59 } //publisher
60 } // naoqi
61 
62 #endif
std::string name() const
Definition: converter_base.hpp:54
float frequency() const
Definition: converter_base.hpp:59
Definition: laser.hpp:37
sensor_msgs::LaserScan msg_
Definition: laser.hpp:56
MessageAction
Definition: message_actions.h:9
Definition: audio.cpp:29
qi::AnyObject p_memory_
Definition: laser.hpp:53
void reset()
Definition: laser.cpp:213
LaserConverter(const std::string &name, const float &frequency, const qi::SessionPtr &session)
Definition: laser.cpp:131
boost::function< void(sensor_msgs::LaserScan &)> Callback_t
Definition: laser.hpp:40
Definition: converter_base.hpp:40
std::map< message_actions::MessageAction, Callback_t > callbacks_
Definition: laser.hpp:55
void callAll(const std::vector< message_actions::MessageAction > &actions)
Definition: laser.cpp:142
void registerCallback(message_actions::MessageAction action, Callback_t cb)
Definition: laser.cpp:137