ROS Topic通信

Topic通信

参考链接:https://blog.csdn.net/github_39611196/article/details/82970668

注意:

package.xml修改如下

<build_depend>message_generation</build_depend>

<exec_depend>message_runtime</exec_depend>

#而不是<run_depend>message_runtime</run_depend>

回到工作空间 执行catkin_make 命令

 

通常我们会把消息收发的两端分成两个节点来写,一个节点就是一个完整的C++程序。

消息发送节点 见topic_demo/src/talker.cpp

ros::Publisher pub = nh.advertise<topic_demo::gps>("gps_info", 1); //创建publisher,往"gps_info"话题上发布消息,红色为头文件按照C++的语法规则定义了topic_demo::gps类型的数据。

消息接收节点 见topic_demo/src/listener.cpp

然后在工作空间catkin_make一下

若出现fatal error: ros/ros.h: No such file or directory错误提示

在CMakeList_txt添加include_directories(include ${PCL_INCLUDE_DIRS})

最后应该是

include_directories(include ${catkin_INCLUDE_DIRS} ${PCL_INCLUDE_DIRS})

编译通过后

启动 talker listener 两个节点命令格式rosrun [package_name] [node_name]

在本工作空间中生成的可执行文件在zxw_ws/devel/lib/topic_demo下所以命令应为

$rosrun topic_demo talker

$rosrun topic_demo listener

在启动之前需要在工作空间source devel/setup.bash 作用是让ROS能够找到你想要执行的可执行文件

NodeHandle是Node的句柄,用来对当前节点进行各种操作。在ROS中,NodeHandle是一个定义好的类,通过include<ros/ros.h>,我们可以创建这个类,以及使用它的成员函数。

NodeHandle常用成员函数包括:

//创建话题的publisher

ros::Publisher advertise(const string &topic, uint32_t queue_size, bool latch=false);

//第一个参数为发布话题的名称

//第二个是消息队列的最大长度,如果发布的消息超过这个长度而没有被接收,那么就的消息就会出队。通常设为一个较小的数即可。

//第三个参数是是否锁存。某些话题并不是会以某个频率发布,比如/map这个topic,只有在初次订阅或者地图更新这两种情况下,/map才会发布消息。这里就用到了锁存。

//创建话题的subscriber

ros::Subscriber subscribe(const string &topic, uint32_t queue_size, void(*)(M));

//第一个参数是订阅话题的名称

//第二个参数是订阅队列的长度,如果受到的消息都没来得及处理,那么新消息入队,就消息就会出队

//第三个参数是回调函数指针,指向回调函数来处理接收到的消息

//创建服务的server,提供服务

ros::ServiceServer advertiseService(const string &service, bool(*srv_func)(Mreq &, Mres &));

//第一个参数是service名称

//第二个参数是服务函数的指针,指向服务函数。指向的函数应该有两个参数,分别接受请求和响应。

//创建服务的client-

ros::ServiceClient serviceClient(const string &service_name, bool persistent=false);

//第一个函数式service名称

//第二个参数用于设置服务的连接是否持续,如果为true,client将会保持与远程主机的连接,这样后续的请求会快一些。通常我们设为flase

//查询某个参数的值

bool getParam(const string &key, std::string &s);

bool getParam (const std::string &key, double &d) const;

bool getParam (const std::string &key, int &i) const;

//从参数服务器上获取key对应的值,已重载了多个类型

//给参数赋值

void setParam (const std::string &key, const std::string &s) const;

void setParam (const std::string &key, const char *s) const;

void setParam (const std::string &key, int i) const;

//给key对应的val赋值,重载了多个类型的val

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 你好,以下是一个 ROS 和 MQTT 通信的示例: 首先,需要安装 ROS 和 MQTT 的相关库和依赖。然后,可以使用 ROSroscpp 库和 MQTT 的 Eclipse Paho C++ 客户端库来实现通信。 在 ROS 中,可以使用 roscpp 的 Publisher 和 Subscriber 类来发布和订阅 ROS 消息。在 MQTT 中,可以使用 Eclipse Paho C++ 客户端库的 MQTTClient 类来连接 MQTT 代理服务器,并发布和订阅 MQTT 消息。 下面是一个简单的 ROS 和 MQTT 通信示例: 1. 创建 ROS 节点和 MQTT 客户端 ros::init(argc, argv, "ros_mqtt_node"); ros::NodeHandle nh; MQTTClient client("tcp://localhost:1883", "ros_mqtt_client"); 2. 创建 ROS 发布者和订阅者 ros::Publisher pub = nh.advertise<std_msgs::String>("ros_mqtt_topic", 100); ros::Subscriber sub = nh.subscribe("ros_mqtt_topic", 100, &callback); 3. 创建 MQTT 订阅者和发布者 client.subscribe("mqtt_ros_topic", ); client.publish("mqtt_ros_topic", "Hello, MQTT!"); 4. 实现 ROS 回调函数和 MQTT 回调函数 void callback(const std_msgs::String::ConstPtr& msg) { ROS_INFO("Received ROS message: %s", msg->data.c_str()); client.publish("mqtt_ros_topic", msg->data.c_str()); } void mqtt_callback(void* context, char* topicName, int topicLen, MQTTClient_message* message) { ROS_INFO("Received MQTT message: %s", message->payload); std_msgs::String msg; msg.data = std::string(message->payload); pub.publish(msg); } 5. 运行 ROS 节点和 MQTT 客户端 ros::spin(); MQTTClient_setCallbacks(client, NULL, NULL, mqtt_callback, NULL); MQTTClient_connect(client, &conn_opts); MQTTClient_subscribe(client, "mqtt_ros_topic", ); 注意,这只是一个简单的示例,实际应用中需要根据具体需求进行修改和优化。 ### 回答2: ROS (Robot Operating System) 是一个灵活的开源框架,用于构建机器人软件应用程序。MQTT (Message Queuing Telemetry Transport) 是一个轻量级的通信协议,用于物联网设备之间的通信。在ROS中使用MQTT进行通信可以实现ROS和其他设备的互联互通。 ROS中的mqtt_bridge软件包提供了ROS和MQTT之间的桥接功能。通过安装该软件包并配置相应参数,可以使ROS节点与MQTT代理之间进行通信。下面以订阅和发布两种常见的通信方式为例进行说明。 首先,在ROS中订阅MQTT消息,可以使用rospy.Subscriber来订阅特定话题。例如,可以通过如下方式在ROS中订阅名为“mqtt_topic”的MQTT话题: ``` rospy.Subscriber("mqtt_topic", MsgType, callback) ``` 其中,MsgType表示消息类型,callback是回调函数,用于处理接收到的消息。 接下来,在ROS中发布MQTT消息,可以使用rospy.Publisher来发布特定话题。例如,可以通过如下方式在ROS中发布名为“mqtt_topic”的MQTT话题: ``` rospy.Publisher("mqtt_topic", MsgType).publish(message) ``` 其中,MsgType表示消息类型,message为要发布的消息内容。 通过配置mqtt_bridge的参数,可以将ROS节点与MQTT代理连接起来。在mqtt_bridge的配置文件中,可以设置ROS和MQTT之间的话题映射关系,例如将“ros_topic”映射到“mqtt_topic”。 ``` ros_topic: mqtt_topic ``` 这样,当ROS节点发布“ros_topic”话题时,mqtt_bridge会将该消息转发到MQTT代理,同时,当MQTT代理发布“mqtt_topic”话题时,mqtt_bridge会将该消息转发给ROS节点。 综上所述,通过使用mqtt_bridge软件包,可以实现ROS和MQTT之间的通信。只需订阅和发布相应的话题即可实现消息传递。这样,ROS节点可以与其他设备实现无缝连接,实现更灵活的机器人应用程序开发。 ### 回答3: ROS (Robot Operating System) 是一个用于开发机器人软件的开源框架,MQTT (Message Queuing Telemetry Transport) 是一种轻量级的通信协议。在 ROS 中使用 MQTT 进行通信可以实现机器人与其他设备之间的消息传递和数据交换。 为了在 ROS 中使用 MQTT 进行通信,首先需要安装 ROS MQTT 包。可以使用命令行运行以下命令来安装: ``` $ sudo apt-get install ros-<distro>-mqtt ``` 在 ROS 中使用 MQTT,通常需要创建一个 ROS 节点来订阅和发布 MQTT 消息。下面是一个使用 ROS MQTT 包的示例代码: ```python import rospy from std_msgs.msg import String from mqtt_ros_bridge.msg import MqttMsg def mqtt_callback(msg): # 当从 MQTT 接收到消息时的回调函数 rospy.loginfo("Received MQTT message: %s", msg.payload.data) def ros_callback(msg): # 当从 ROS 主题接收到消息时的回调函数 # 发布 MQTT 消息 mqtt_msg = MqttMsg() mqtt_msg.topic = "mqtt_topic" mqtt_msg.payload = msg.data mqtt_msg.qos = 0 mqtt_pub.publish(mqtt_msg) rospy.init_node('mqtt_example') # 创建 MQTT 订阅节点 mqtt_sub = rospy.Subscriber('mqtt_topic', MqttMsg, mqtt_callback) # 创建 MQTT 发布节点 mqtt_pub = rospy.Publisher('mqtt_topic', MqttMsg, queue_size=10) # 创建 ROS 主题订阅节点 ros_sub = rospy.Subscriber('ros_topic', String, ros_callback) rospy.spin() ``` 在这个示例中,我们创建了一个 ROS 节点,并使用 ROS MQTT 包提供的功能创建了一个 MQTT 订阅节点和一个 MQTT 发布节点。通过在回调函数中实现 MQTT 消息的处理,我们可以在 ROS 和 MQTT 之间进行双向通信。 通过运行这个示例代码,ROS 节点将能够接收来自 MQTT 消息的数据,并将其打印出来。同时,它还可以订阅 ROS 主题,并将接收到的消息发布到 MQTT。 这是一个简单的 ROS MQTT 通信示例,可以根据实际需求进行扩展和定制。通过使用 ROS MQTT 包,可以方便地在 ROS 系统中集成 MQTT,实现机器人与其他设备之间的无缝通信
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值