依照<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. 洛谷P1060开心的金明(滚动数组优化)

    题目描述 金明今天很开心,家里购置的新房就要领钥匙了,新房里有一间他自己专用的很宽敞的房间.更让他高兴的是,妈妈昨天对他说:“你的房间需要购买哪些物品,怎么布置,你说了算,只要不超过NNN元钱就行”. ...

  2. IDEA 查看字节码

    参考:https://www.jianshu.com/p/18953ec8c0b7 打开工具栏 输入参数: 参数: $JDKPath$\bin\javap.exe -c $FileClass$ $Ou ...

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

  4. WPF 体系结构

    转载地址:http://blog.csdn.net/changtianshuiyue/article/details/38963477 本主题提供 Windows Presentation Found ...

  5. 代理模式之静态代理,JDK动态代理和cglib动态代理

    代理模式,顾名思义,就是通过代理去完成某些功能.比如,你需要购买火车票,不想跑那么远到火车站售票窗口买,可以去附近的火车票代售点买,或者到携程等第三方网站买.这个时候,我们就把火车站叫做目标对象或者委 ...

  6. 学习 Python,怎能不懂点PEP 呢?

    或许你是一个初入门 Python 的小白,完全不知道 PEP 是什么.又或许你是个学会了 Python 的熟手,见过几个 PEP,却不知道这玩意背后是什么.那正好,本文将系统性地介绍一下 PEP,与大 ...

  7. 端口打开和关闭do while

    ;Author : Bing Song ;// ;Usage: modify “logfile" according to actual drictory getdir logdir #获取 ...

  8. Struts2.0笔记二

    Mvc与servlet 1.1   Servlet的优点 1.  是mvc的基础,其他的框架比如struts1,struts2,webwork都是从servlet基础上发展过来的.所以掌握servle ...

  9. Struts笔记二:栈值的内存区域及标签和拦截器

    值栈和ognl表达式 1.只要是一个MVC框架,必须解决数据的存和取的问题 2.struts2利用值栈来存数据,所以值栈是一个存储数据的内存结构 1.  ValueStack是一个接口,在struts ...

  10. JS闭包(1)

    1.首先看一段代码: var a = 1; function fn1(){ var b = 2; function fn2(){ console.log(a); console.log(b); } } ...