ROS机器人编程学习(七)——ROS编程基础1

第7章 ROS编程基础
本章主要介绍了ROS的基本编程实现内容,包括编程规则、发布者&订阅者、服务服务器&客户端、动作服务器&客户端。
同样的,由于本章节内容较多,博客学习记录分为三节。
本文主要介绍编程规则、发布者&订阅者两部分内容。


《ROS机器人编程》源代码:
https://github.com/ROBOTIS-GIT/ros_tutorials/tree/master/ros_tutorials_topic

古月居源代码:
https://github.com/huchunxu/ros_21_tutorials/tree/master/learning_topic


7.1 编程基本规则

1、标准单位SI
在这里插入图片描述

2、坐标系

机器人的旋转方向是右手定则,用右手卷住的方向是正(+)方向。
在这里插入图片描述

3、命名规则

在这里插入图片描述

7.2 发布者节点和订阅者节点的创建和运行

《ROS机器人编程》

1. 创建功能包
依赖选项 message_generation、std_msgs、roscpp

$ cd ~/catkin_ws/src
$ catkin_create_pkg ros_tutorials_topic message_generation std_msgs roscpp

2. 修改功能包配置文件
package.xml是一个包含功能包信息的XML文件,包含用于描述功能包名称、作者、许可证和依赖包的信息。

$ gedit package.xml

3. 修改构建配置文件
ROS的构建系统catkin基本上使用CMake,在功能包目录中的CMakeLists.txt文件中描述了构建环境。该文件设置可执行文件的创建、依赖包优先构建、链接创建等。

$ gedit CMakeLists.txt

4. 创建消息文件
在构建时要包含消息MsgTutorial.msg,该消息将在此节点中被使用。

add_message_files(FILES MsgTutorial.msg)

创建MsgTutorial.msg:

$ roscd ros_tutorials_topic		→ 移动到功能包目录
$ mkdir msg						→ 功能包中创建新的msg消息目录
$ cd msg						→ 转到创建的msg目录
$ gedit MsgTutorial.msg			→ 创建新的MsgTutorial.msg文件并修改内容

5. 创建发布者节点和订阅者节点

CMakeLists.txt文件中,给了生成以下可执行文件的选项。
即,通过构建 .cpp 源文件来创建可执行文件。

add_executable(topic_publisher src/topic_publisher.cpp)
add_executable(topic_subscriber src/topic_subscriber.cpp)
$ roscd ros_tutorials_topic/src		→ 移至src目录,该目录是功能包的源代码目录
$ gedit topic_publisher.cpp			→ 新建源文件并修改内容

$ roscd ros_tutorials_topic/src		→ 移动到src目录,该目录是功能包的源代码目录 
$ gedit topic_subscriber.cpp		→ 创建和修改新的源代码文件

7. 构建(build)节点

catkin构建:

$ cd ~/catkin_ws&&catkin_make

功能包的源代码位于 “~/catkin_ws/src/ros_tutorials_topic/src"
消息文件位于 “~/catkin_ws/src/ros_tutorials_topic/msg”

“/build”目录中保存catkin构建用到的配置内容
“/devel/lib/ros_tutorials_topic’”目录中保存可执行文件。

8. 运行发布者和订阅者

运行的发布者节点,通过 rostopic 检查ros_tutorial_msg话题消息内容。

$ roscore
$ rosrun ros_tutorials_topictopic_publisher
$ rostopic echo /ros_tutorial_msg

在这里插入图片描述
运行订阅者节点,接收发布者发布的ros_tutorial_msg话题的消息,并在屏幕上显示该值。

$ rosrun ros_tutorials_topic topic_subscriber

9. 检查运行中的节点的通信状态

使用rqt_graph或rqt,查看运行中的节点的通信状态。

在这里插入图片描述



古月居《ROS入门21讲》

古月居21讲中,对于发布者和订阅者的讲述构建的是小海龟运动实例。

1. 实现发布者节点的基本代码内容
(.cpp or .py,此处以.cpp为例)

在这里插入图片描述

  • 初始化ROS节点
// ROS节点初始化
ros::init(argc, argv, "velocity_publisher");
  • 向ROS Master注册节点信息,包括发布打话题名和话题中的消息类型
// 创建一个Publisher,发布名为/turtle1/cmd_vel的topic,消息类型为geometry_msgs::Twist,队列长度10
ros::Publisher turtle_vel_pub = n.advertise<geometry_msgs::Twist>("/turtle1/cmd_vel", 10);
  • 创建消息数据
// 初始化geometry_msgs::Twist类型的消息
geometry_msgs::Twist vel_msg;
vel_msg.linear.x = 0.5;
vel_msg.angular.z = 0.2;
  • 按照一定频率循环发送消息
// 发布消息
turtle_vel_pub.publish(vel_msg);
ROS_INFO("Publsh turtle velocity command[%0.2f m/s, %0.2f rad/s]", 
vel_msg.linear.x, vel_msg.angular.z);

// 按照循环频率延时
loop_rate.sleep();

在这里插入图片描述


2. 实现订阅者节点的基本代码内容

在这里插入图片描述

  • 初始化ROS节点
// 初始化ROS节点
ros::init(argc, argv, "pose_subscriber");
  • 订阅需要的话题
// 创建一个Subscriber,订阅名为/turtle1/pose的topic,注册回调函数poseCallback
ros::Subscriber pose_sub = n.subscribe("/turtle1/pose", 10, poseCallback);
  • 循环等待话题消息,接收到消息后进入回调函数
    (相当于一个中断,回调函数的处理时间不能太长)
// 循环等待回调函数,在回调函数中完成消息处理
ros::spin();

// 接收到订阅的消息后,会进入消息回调函数
void poseCallback(const turtlesim::Pose::ConstPtr& msg)
{
    // 将接收到的消息打印出来
    ROS_INFO("Turtle pose: x:%0.6f, y:%0.6f", msg->x, msg->y);
}

在这里插入图片描述
此外,运行.py无需进行编译,但需要确认.py文件是可执行文件。

$ rosrun learning_topic pose_subscriber.py

自定义消息类型

在这里插入图片描述

<build_depend> 编译依赖,message_generation动态产生功能包
<exec_depend> 执行依赖,message_runtime运行时的依赖项

find_package项是进行构建所需的组件包,让用户创建依赖包的选项。

add_message_files是添加消息文件的选项。
generate_messages是设置依赖的消息的选项。此示例是将DEPENDENCIES选项设置为使用std_msgs消息包。
catkin_package是catkin 构建选项:

  • INCLUDE_DIRS表示将使用INCLUDE_DIRS后面的内部目录include的头文件。
  • LIBRARIES表示将使用随后而来的功能包的库。
  • CATKIN_DEPENDS后面指定如roscpp或std_msgs等依赖包。
  • DEPENDS是一个描述系统依赖包的设置。
  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值