依照<ROS-3 : Catkin工作空间和ROS功能包>,创建catkin工作空间,并在起src下创建功能包ros_demo_pkg,依赖项为roscpp、std_msgs、actionlib、actionlib_msgs,并构建该空功能包。ROS中节点间的基本通讯方式是topic,即publish/subscribe模式。以下介绍如何创建两个两个节点分别发布和订阅一个主题。

一、创建节点

1、创建发布者节点topic_publisher

  首先在功能包ros_demo_pkg下的src下创建第一个节点文件topic_publisher.cpp。该节点在主题/numbers上发布一个整数,其代码和详解如下:

 //roscpp client APIs的核心头文件
#include "ros/ros.h"
//标准消息类型Int32的头文件
#include "std_msgs/Int32.h"
#include <iostream> int main(int argc, char **argv) { //初始化ROS node--topic_publisher
ros::init(argc, argv,"topic_publisher"); //创建一个节点句柄对象,用于和ROS系统通讯
ros::NodeHandle node_obj; //创建一个主题发布者对象,设定主题名、消息类型和缓冲区大小
ros::Publisher number_publisher = node_obj.advertise<std_msgs::Int32>("/numbers",); //设定发送数据的频率
ros::Rate loop_rate(); int number_count = ; //开启while循环,递增一个数值,并发布到topic /numbers
while (ros::ok())
{ //创建 Int32型消息对象
std_msgs::Int32 msg; //设置消息值
msg.data = number_count; //打印消息数据
ROS_INFO("%d",msg.data); //将消息发布到主题
number_publisher.publish(msg); //读取并更新所有的topics
ros::spinOnce(); //实现数据发布频率
loop_rate.sleep(); ++number_count;
} return ;
}

2、创建订阅者节点topic_subscriber

  接下来在功能包ros_demo_pkg下的src下创建第二个节点文件topic_subscriber.cpp。该节点订阅主题/numbers,接收该主题的消息,其代码和详解如下: 

 #include "ros/ros.h"
#include "std_msgs/Int32.h"
#include <iostream> //Callback 函数,当有数据被发布到主题/numbers时会调用该函数
void number_callback(const std_msgs::Int32::ConstPtr& msg)
{
ROS_INFO("Recieved [%d]",msg->data);
} int main(int argc, char **argv)
{ //初始化ROS node --topic_subscriber
ros::init(argc, argv,"topic_subscriber");
ros::NodeHandle node_obj;
//创建一个订阅者对象,设定主题名、缓冲区大小和callback函数
ros::Subscriber number_subscriber = node_obj.subscribe("/numbers",,number_callback);
//Spinning the node
ros::spin();
return ;
}

3、构建节点

  为编译并构建上述节点的源代码,必须编辑功能包中的CMakeLists.txt文件。

$ cd ~/catkin_ws/src/ros_demo_pkg
$ gedit CMakeList.txt

  在已有的CMakeLists.txt文件中加入以下代码:

## 指定头文件的位置
include_directories(
include
${catkin_INCLUDE_DIRS}
) ## 声明一个C++可执行文件
## add_executable(node_name src/node_source_file.cpp)
add_executable(topic_publisher src/topic_publisher.cpp)
add_executable(topic_subscriber src/topic_subscriber.cpp) ## 添加可执行文件所需的cmake target dependencies
## add_dependencies(node_name {package_name}_generate_messages_cpp)
add_dependencies(topic_publisher ros_demo_pkg_generate_messages_cpp)
add_dependencies(topic_subscriber ros_demo_pkg_generate_messages_cpp) ## 指定链接 a library 或 executable target所需的libraries
# target_link_libraries(node_name ${catkin_LIBRARIES} )
target_link_libraries(demo_topic_publisher ${catkin_LIBRARIES})
target_link_libraries(demo_topic_subscriber ${catkin_LIBRARIES})

  然后就可以编译上述节点并构建该功能包:切换到catkin工作空间再进行构建。

$ cd ~/catkin_ws
$ catkin_make

  以上即为构建成功。

  综上,创建ROS节点包括以下几个步骤:

  1. 在功能包的src下编写节点的源文件,即.cpp文件
  2. 编辑功能包的CMakeLists.txt文件,添加编译和构建节点所需的内容;
  3. 构建功能包。

二、执行节点

  ROS系统中运行任何节点前都必须先运行roscore。roscore将启动ROS Master、ROS paramter和rosout logging nodes。

$ roscore

  再在另两个终端中分别运行上述两个节点。先运行发布者节点topic_publisher:

$ rosrun ros_demo_pkg topic_publisher

  再运行订阅者节点topic_subscriber:

$ rosrun ros_demo_pkg topic_subscriber

  可看到两个节点的运行结果如下图:

  综上,运行以topic模式通讯的节点的过程如下:

  1. 在一个终端上运行roscore;
  2. 在另一个终端上运行主题发布者节点;
  3. 在另一个终端上运行主题订阅者节点。

  在终端中输入rqt_graph,可看到上述两个节点间的通讯关系:

$ rqt_graph

ROS-4 : ROS节点和主题的更多相关文章

  1. ROS笔记——创建简单的主题发布节点和主题订阅节点

    在安装好ROS后,接着学习如何创建节点和节点之间的通信方式,以一个简单的主题发布节点和主题订阅节点说明. 节点是连接ROS网络等可执行文件,是实现某些功能的软件包,也是一个主要计算执行的进程. 一.创 ...

  2. ROS学习笔记6-理解主题

    本文来源于:http://wiki.ros.org/ROS/Tutorials/UnderstandingTopics ROS主题假设turtlesim节点已经运行,打开一个新终端,使用如下命令运行键 ...

  3. ROS 订阅图像节点(1)

    博客 http://blog.csdn.net/github_30605157/article/details/50990493 参考ROS原网站 http://wiki.ros.org/image_ ...

  4. ROS 订阅图像节点

    博客 http://blog.csdn.net/github_30605157/article/details/50990493 参考ROS原网站 http://wiki.ros.org/image_ ...

  5. ROS分布式控制的节点配置

    首先在终端中输入下面的指令查看ROS主节点主机的IP和远程控制端的IP: ifconfig 比如机器人控制器中运行着ROS主节点,其IP地址为192.168.1.111,hostname为xubunt ...

  6. ros中关于节点、话题、服务以及自定义消息等在终端中的常用命令

    以下面的计算力图说明 节点相关常用命令 在终端中查看项目中有哪些节点命令:rosnode list 有了节点信息想要查看节点中到底发布订阅了哪些话题,作为服务端服务类型或者作为客户端需要的服务类型以上 ...

  7. ros 杀掉所有节点

    rosnode kill -a 或者 rosnode kill --all

  8. Learning ROS: Running ROS across multiple machines

    Start the master ssh hal roscore Start the listener ssh hal export ROS_MASTER_URI=http://hal:11311 r ...

  9. ROS学习笔记5-理解节点(Node)

    本文内容来源于:http://wiki.ros.org/ROS/Tutorials/UnderstandingNodes 图(Graph)概念概览 节点(Nodes):一个节点是ROS下面一个可执行程 ...

随机推荐

  1. win10上的程序兼容win7、xp等

  2. Codeforces Round #593 (Div. 2)D(螺旋形模拟)

    #define HAVE_STRUCT_TIMESPEC#include<bits/stdc++.h>using namespace std;vector<int>po[100 ...

  3. 21. Regular Expressions--from Apache

    转自: http://jmeter.apache.org/usermanual/regular_expressions.html 21.1 Overview¶ JMeter includes the ...

  4. JAVA GUI窗体及控件

    Swing基本操作: JAVA显示一个带按钮的窗口: import java.awt.*; import javax.swing.*; import javax.swing.border.EmptyB ...

  5. 自定义 directive pagination

    学习angular过程中,对directive 不是很了解,很有必要自己写一个,以便知道它的各方面的处理方式. directive 中 scope 与 controller 交互,有三种定义策略 &q ...

  6. springBoot+MybatisPlus数据库字段使用驼峰命名法时报错

    假如有个实体类: package com.jeff.entity; public class User { /** * 主键id */ private Integer id; /** * 登陆名 */ ...

  7. WEB - JSONP

    JSON with Padding参考 https://zh.wikipedia.org/wiki/JSONP http://www.runoob.com/json/json-jsonp.html 使 ...

  8. C++的const成员函数

    我们知道,在C++中,若一个变量声明为const类型,则试图修改该变量的值的操作都被视编译错误.例如, const char blank = ‘’; blank = ‘\n’;  // 错误 面向对象 ...

  9. Python压缩文件/文件夹

    [Python压缩文件夹]导入“zipfile”模块 def zip_ya(startdir,file_news): startdir = ".\\123" #要压缩的文件夹路径 ...

  10. jupyter配置 nbextension

    jupyter contrib nbextension install --user --skip-running-check No module named 'pysqlite2' 解决方法:打开此 ...