odometry_helper_ros.h
Go to the documentation of this file.
1 /*********************************************************************
2  *
3  * Software License Agreement (BSD License)
4  *
5  * Copyright (c) 2008, Willow Garage, Inc.
6  * All rights reserved.
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions
10  * are met:
11  *
12  * * Redistributions of source code must retain the above copyright
13  * notice, this list of conditions and the following disclaimer.
14  * * Redistributions in binary form must reproduce the above
15  * copyright notice, this list of conditions and the following
16  * disclaimer in the documentation and/or other materials provided
17  * with the distribution.
18  * * Neither the name of Willow Garage, Inc. nor the names of its
19  * contributors may be used to endorse or promote products derived
20  * from this software without specific prior written permission.
21  *
22  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
23  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
24  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
25  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
26  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
27  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
28  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
29  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
30  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
32  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
33  * POSSIBILITY OF SUCH DAMAGE.
34  *
35  * Author: TKruse
36  *********************************************************************/
37 
38 #ifndef ODOMETRY_HELPER_ROS2_H_
39 #define ODOMETRY_HELPER_ROS2_H_
40 
41 #include <nav_msgs/Odometry.h>
42 #include <ros/ros.h>
43 #include <boost/thread.hpp>
44 #include <geometry_msgs/PoseStamped.h>
45 
46 namespace base_local_planner {
47 
48 class OdometryHelperRos {
49 public:
50 
55  OdometryHelperRos(std::string odom_topic = "");
57 
62  void odomCallback(const nav_msgs::Odometry::ConstPtr& msg);
63 
64  void getOdom(nav_msgs::Odometry& base_odom);
65 
66  void getRobotVel(geometry_msgs::PoseStamped& robot_vel);
67 
73  void setOdomTopic(std::string odom_topic);
74 
76  std::string getOdomTopic() const { return odom_topic_; }
77 
78 private:
79  //odom topic
80  std::string odom_topic_;
81 
82  // we listen on odometry on the odom topic
84  nav_msgs::Odometry base_odom_;
85  boost::mutex odom_mutex_;
86  // global tf frame id
87  std::string frame_id_;
88 };
89 
90 } /* namespace base_local_planner */
91 #define CHUNKY 1
92 #endif /* ODOMETRY_HELPER_ROS2_H_ */
base_local_planner::OdometryHelperRos::setOdomTopic
void setOdomTopic(std::string odom_topic)
Set the odometry topic. This overrides what was set in the constructor, if anything.
Definition: odometry_helper_ros.cpp:123
base_local_planner::OdometryHelperRos::base_odom_
nav_msgs::Odometry base_odom_
Definition: odometry_helper_ros.h:154
base_local_planner::OdometryHelperRos::OdometryHelperRos
OdometryHelperRos(std::string odom_topic="")
Constructor.
Definition: odometry_helper_ros.cpp:79
base_local_planner::OdometryHelperRos::getOdom
void getOdom(nav_msgs::Odometry &base_odom)
Definition: odometry_helper_ros.cpp:97
ros.h
base_local_planner::OdometryHelperRos::frame_id_
std::string frame_id_
The frame_id associated this data.
Definition: odometry_helper_ros.h:157
base_local_planner::OdometryHelperRos::odomCallback
void odomCallback(const nav_msgs::Odometry::ConstPtr &msg)
Callback for receiving odometry data.
Definition: odometry_helper_ros.cpp:83
base_local_planner::OdometryHelperRos::getOdomTopic
std::string getOdomTopic() const
Return the current odometry topic.
Definition: odometry_helper_ros.h:146
base_local_planner::OdometryHelperRos::getRobotVel
void getRobotVel(geometry_msgs::PoseStamped &robot_vel)
Definition: odometry_helper_ros.cpp:103
base_local_planner::OdometryHelperRos::odom_sub_
ros::Subscriber odom_sub_
Definition: odometry_helper_ros.h:153
base_local_planner::OdometryHelperRos::odom_mutex_
boost::mutex odom_mutex_
Definition: odometry_helper_ros.h:155
base_local_planner::OdometryHelperRos::odom_topic_
std::string odom_topic_
Definition: odometry_helper_ros.h:150
base_local_planner::OdometryHelperRos::~OdometryHelperRos
~OdometryHelperRos()
Definition: odometry_helper_ros.h:126
base_local_planner
Definition: costmap_model.h:44
ros::Subscriber


base_local_planner
Author(s): Eitan Marder-Eppstein, Eric Perko, contradict@gmail.com
autogenerated on Mon Mar 6 2023 03:50:24