ROS学习总结一:talker and listener

本教程详细介绍了如何在ROS环境中设置工作空间,创建功能包,并实现简单的talker与listener节点通信。从建立工作空间到编译功能包,再到具体代码实现与测试,适合ROS初学者快速上手。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、建立一个工作空间:

$ mkdir -p ~/catkin_ws/src  
$ cd ~/catkin_ws/src  
$ catkin_init_workspace  

编译:

$ cd ~/catkin_ws/  
$ catkin_make
$ source devel/setup.bash

这里可以通过以下命令:

 $ echo $ROS_PACKAGE_PATH  

验证source是否成功,如果成功应该有新建的文件路径。
2、创建一个功能包:

 $ cd ~/catkin_ws/src 
 $ catkin_create_pkg beginner_tutorials std_msgs rospy roscpp  
 #beginner_tutorials为功能包名,std_msgs rospy roscpp 为三个依赖,std_msgs为ROS自定义的一些基本数据格式,rospy为依赖于python,roscpp为依赖于C++.
 $ cd ~/catkin_ws  
 $ catkin_make 

3、建立一个talker以及listener:

$ cd ~/catkin_ws/src/beginner_tutorials/src

在catkin_ws/src/beginner_tutorials/src目录下建立两个cpp文件,复制下列代码:
talker:

#include "ros/ros.h"  
#include "std_msgs/String.h"  

#include <sstream>  
int main(int argc, char **argv)  
{  
 
  ros::init(argc, argv, "talker");  
  
  ros::NodeHandle n;  

  ros::Publisher chatter_pub = n.advertise<std_msgs::String>("chatter", 1000);  

  ros::Rate loop_rate(10);  

  /** 
   * A count of how many messages we have sent. This is used to create 
   * a unique string for each message. 
   */  
  int count = 0;  
  while (ros::ok())  
  {   
    std_msgs::String msg;  
    std::stringstream ss;  
    ss << "hello world " << count;  
    msg.data = ss.str();  
    ROS_INFO("%s", msg.data.c_str());  
    chatter_pub.publish(msg); 
    ros::spinOnce();  
    loop_rate.sleep();  
    ++count;  
   }  
    return 0;  
} 

listener:

#include "ros/ros.h"  
#include "std_msgs/String.h"  

/** 
 * This tutorial demonstrates simple receipt of messages over the ROS system. 
 */  
void chatterCallback(const std_msgs::String::ConstPtr& msg)  
{  
  ROS_INFO("I heard: [%s]", msg->data.c_str());  
}  

int main(int argc, char **argv)  
{  
ros::init(argc, argv, "listener");  
 ros::NodeHandle n;  
 ros::Subscriber sub = n.subscribe("chatter", 1000, chatterCallback);  
 ros::spin();  
 return 0;  
}  

编辑cmakelist文件:

cd ~/catkin_ws/src/beginner_tutorials/src
gedit CMakeLists.txt 

在文件中加入:

include_directories(include ${catkin_INCLUDE_DIRS})  

add_executable(talker src/talker.cpp)  
target_link_libraries(talker ${catkin_LIBRARIES})  
add_dependencies(talker beginner_tutorials_generate_messages_cpp)  

add_executable(listener src/listener.cpp)  
target_link_libraries(listener ${catkin_LIBRARIES})  
add_dependencies(listener beginner_tutorials_generate_messages_cpp) 

注:这里的add_dependencies加入可能会报错,这是因为这里添加的依赖项并没有用到同时也不存在,所以cmake时会出现警告,可以忽略或者直接将add_dependencies这两行先注释掉。

$ cd ~/catkin_ws  
$ catkin_make  

4、测试

$ roscore

新开一个终端:

$ cd ~/catkin_ws  
$ source ./devel/setup.bash
#这里是使路径生效,如果不执行ros将找不到该路径下的文件
$ rosrun beginner_tutorials talker

再新开一个终端:

$ cd ~/catkin_ws  
$ source ./devel/setup.bash
$ rosrun beginner_tutorials listener

如果不想每次开启时都source的话,可以:

$ gedit ~/.bashrc

在bashrc文件最下面加入:

source /home/computer_name/catkin_ws/devel/setup.bash
#这里computer_name为自己的电脑名称。

保存退出后再执行:

source ~/.bashrc

之后再执行上述talker或者listener就不用执行前两行命令了。

参考:https://www.cnblogs.com/flyingjun/p/8796459.html

ROS 2 (Robot Operating System) 中创建个Python包并实现TalkerListener功能通常涉及以下几个步骤: 1. **初始化工作空间**: 首先,你需要在个新的目录下初始化个新的ROS 2工作空间 (`ros2 init <your_package_name>`),这将创建个包含所有依赖和源文件结构的标准结构。 2. **创建包**: 创建个名为`<your_package_name>/src`的目录,并在此处创建两个文件夹,分别用于TalkerListener:`msg`(存放消息定义)和`python`(存放Python代码)。 - `msg` 文件夹:如果你的消息类型还没有定义,需要编写`.msg`文件(如`std_msgs/msg/String`),描述你要交换的信息。如果没有自定义消息,可以保留默认的。 - `python` 文件夹:在这里,你可以创建`talker.py` 和 `listener.py` 文件。 3. **编写Talker**: - 在`talker.py` 中,导入需要的消息类型,创建`Node`实例,然后监听个话题并发送消息。使用`rclpy`库的`Publisher`类来发布消息,如: ```python from rclpy.node import Node from your_package_name.msg import YourMessageType import rclpy class Talker(Node): def __init__(self): super().__init__('talker') self.publisher_ = self.create_publisher(YourMessageType, 'your_topic', 10) timer_period = 0.5 # 发送消息频率 self.timer = self.create_timer(timer_period, self.send_message) def send_message(self): msg = YourMessageType(data='Hello from Talker!') self.publisher_.publish(msg) ``` 4. **编写Listener**: - 在`listener.py`中,做类似的事情,但是创建个`Subscriber`来接收消息。例子如下: ```python from rclpy.node import Node from your_package_name.msg import YourMessageType import rclpy class Listener(Node): def __init__(self): super().__init__('listener') self.subscription = self.create_subscription( YourMessageType, 'your_topic', self.listener_callback, 10) self.subscription # 确保回调函数被注册 def listener_callback(self, msg): self.get_logger().info('Received message: %s' % msg.data) ``` 5. **构建和运行**: - 通过命令行进入工作空间目录,然后执行`colcon build`来构建包,生成二进制文件。 - 接下来,运行TalkerListener,例如: ``` ros2 run your_package_name talker ros2 run your_package_name listener ``` 6. **调试和测试**: 使用`ros2 topic echo` 来确认消息是否正常传递。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一叶执念

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值