【ROS 最简单教程 012/300】ROS 话题通信 -- 订阅方实现简单示例

在这里插入图片描述

ROS 通信机制:ROS是进程(也称为 Nodes)的分布式框架。 这些进程甚至还可分布于不同主机协同工作,所以结点之间如何通信非常重要!

⭐ 基本通信机制一:话题通信(发布订阅模式) 【用于不断更新的、少逻辑处理的数据传输场景】 👉话题通信理论图解必懂 指路
  • ROS Master 负责保管 Talker 📢和 Listener 注册的信息,并匹配话题相同的 Talker📢 与 Listener 👂
  • 帮助 Talker 📢与 Listener 👂 建立连接
  • 连接建立后,Talker 📢 可以发布消息,发布的消息会被 Listener 👂订阅

实例化订阅者对象名称 = rospy.Subscriber(参数1,参数2,参数3,参数4)

sub = rospy.Subscriber("chatter",String,doMsg,queue_size=10) 
  • 名称:订阅者对象名称,如 pub
  • 参数1: 要订阅到的话题,如 "chatter"
  • 参数2: 订阅的消息类型,如 String
  • 参数3: 队列中最大保存的消息数,如 10
    • 超出此阀值时,先进的先销毁 (时间早的先销毁)
  • 参数4: 回调函数 (每订阅到消息则调用),如 doMsg
⭐ 完整订阅方代码,包含详细注释,来啦 ~

不清楚如何配置、执行代码的友友建议先看下 👉快速体验 指路

#! /usr/bin/env python
"""
    消息订阅方: 订阅话题并打印接收到的消息
"""
import rospy  # ----------------------------------- step 1: 导包 
from std_msgs.msg import String

def doMsg(msg):   # 回调函数
    rospy.loginfo("I heard:%s",msg.data)

if __name__ == "__main__":

    rospy.init_node("listener_p")  # -------------- step 2: 初始化 ROS 节点
    
	# --------------------------------------------- step 3: 实例化 订阅者 对象
    sub = rospy.Subscriber("chatter",String,doMsg,queue_size=10)  
    
    # --------------------------------------------- step 4: 处理订阅的消息 (回调函数)
    rospy.spin()   # 循环读取接收的数据,并调用回调函数处理
⭐ 验证订阅是否正常
  • 运行订阅方节点后,可以用 rostopic 命令快速验证 or 运行发布方来验证
    1. 在新的终端利用 rostopic pub 话题名称 消息类型 消息值 快速验证

      $ rostopic pub /chatter std_msgs/String "Hello!!!"
      
      # 执行后,可以看到订阅者窗口有以下输出
      
      [ INFO] [1722417775.084749147]: sub: Hello!!!
      
    2. 运行发布方来验证,代码参照 👉发布方实现简单示例 指路

希望对你有帮助呀!!💜💜 如操作遇到任何问题,欢迎大家留言互助 ~ 一起加油叭 💦
欢迎关注、订阅专栏 【ROS 学习笔记】谢谢你的支持!


另外,使用ROS需要 C++ 或者Python的编程经验,我的博客主页也有相关的教程发布,需要的友友自取!
参考资料ROS理论与实践在线文档B站视频教程

  • 9
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值