机器人操作系统ROS Indigo 入门学习(11)——创建一个ROS msg和srv

2024-05-25 12:32

本文主要是介绍机器人操作系统ROS Indigo 入门学习(11)——创建一个ROS msg和srv,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 这篇教程将涉及怎样创建和编译msg和srv文件,以及怎样使用命令行工具rosmsg,rossrv 和roscp.

 

1.1介绍msg和srv

msg:msg文件是描叙ROS message字段的简单文本文件.它们用来messsage产生不同程序语言的源代码.

Srv:一个srv文件描叙了一种服务.它由两部分组成:一个请求和一个响应.

msg文件储存在一个packagemsg目录,而srv文件储存在srv目录.

 

msg只是每行有字段类型和字段名字的简单文本文件.可以使用的字段类型有:

int8, int16, int32, int64 (plus uint*) 

float32, float64 

string 

time, duration 

other msg files 

variable-length array[] and fixed-length array[C] 

 

 

ROS一种特殊的类型Header,header包含一个时间戳和一个ROS中运用很普遍的坐标系信息。在一个msg文件中你会经常看到Headerheader:

 

这是一个使用一个Header,一个原始字符和两个其它msgsmsg的例子,

  Header header

  string child_frame_id

  geometry_msgs/PoseWithCovariance pose

  geometry_msgs/TwistWithCovariance twist

srv文件类似于msg文件,不同之处是两个部分:一个请求和一个应答。这两个部分由'—'线分隔.下面是一个例子:

int64 A

int64 B

---

int64 Sum

 

上面的例子中,AB是请求,而Sun是响应.

 

 

2.使用msg

 

2.1创建一个msg

让我们在之前的教程创建的package中创建一个新的msg.

$ cd ~/catkin_ws/src/beginner_tutorials

$ mkdir msg

$ echo "int64 num" > msg/Num.msg

上面例子的.msg文件只一行.当然你也可以通过添加其它元素创建一个更加复杂的文件,每行一个元素,像这样:

string first_name

string last_name

uint8 age

uint32 score

还有一步要做.我们需要确定在msg文件能够转化为C++,Python源代码或者其它语言:

打开package.xml文件,确认有下面两行并且没有被注释掉.

  <build_depend>message_generation</build_depend>

  <run_depend>message_runtime</run_depend>

注意:在编译的时候我们需要”message_generation”,而在运行的时候,我们只需要”message_runtime”

 

在你最喜欢的编辑器中打开CMkeLists.txtrosed是一个不错的选择).

 

增加message_generation依赖到CMakeLists.txt中已经存在的find_package调用中,这样你就可以产生message.你只需要简单的增加message_generationCOMPONENTS的列表中,看起来大概是这个样子:

 

# Do not just add this to your CMakeLists.txt, modify the existing text to add message_generation before the closing parenthesis

find_package(catkin REQUIRED COMPONENTS

   roscpp

   rospy

   std_msgs

   message_generation

)

有时候你会发现即使你没有调用有所有依赖的find_package,工程编译也没错这是因为catkin结合你的所有工程,所以如果你之前的工程调用过find_package,那么你的配置会是一样的.但是忘记调用意味着你的工程在独自编译时会轻易的中断.

 

同样也要确认你输出message运行时的依赖.

catkin_package(

  ...

  CATKIN_DEPENDS message_runtime ...

  ...)

 

找到下面的代码段:

# add_message_files(

#   FILES

#   Message1.msg

#   Message2.msg

# )

通过移除#号解除注释,用你的.msg文件替代Message*.msg文件,大概看起来是这个样子:

add_message_files(

  FILES

  Num.msg

)

通过手动添加.msg文件,我们可以保证CMake在你添加其他.msg文件后知道什么时候去配置你的工程.

 

现在我们必须保证generate_messages()函数能被调用.

 

对于ROS Hydro和之后的版本,需要解除下面三个注释:

# generate_messages(

#   DEPENDENCIES

#   std_msgs

# )

看起来是这样:

generate_messages(

  DEPENDENCIES

  std_msgs

)

现在你已经准备好你的msg定义中产生源代码.如果你现在就想做,跳过下面的部分直接去Common step for msg and srv

 

 

2.2使用rosmsg

这就是你创建一个msg文件需要做的.现在用rosmsg命令确认一下ROS可以看到这些.

用法:

$rosmsg show [message type]

例子:

$rosmsg show beginner_tutorials/Num

你会看到:

int64 num

 

在之前的例子中,message类型由两部分组成:

beginner_tutorials—定义messagepackage

Num—msg Num的名字

如果你不记得msg哪个package里面,你可以列出package的名字:

$rosmsg show Num

你会看到:

[beginner_tutorials/Num]:

Int64 num

 

 

3.使用srv

 

3.1创建一个srv

让我们用刚刚创建的package创建一个srv:

$ roscd beginner_tutorials

$ mkdir srv

 

我们会从其它package中复制已经存在的srv,不而是手动创建一个srv定义.

这样的话,从一个package复制文件到另一个packageroscp一个非常有用的工具.

用法:

$ roscp [package_name] [file_to_copy_path] [copy_path]

 

现在我们可以从rospy_tutorialspackage复制一个服务:

$ roscp rospy_tutorials AddTwoInts.srv srv/AddTwoInts.srv

 

还有一步要做.我们需要保证srv文件转变为了C++,Python和其他语言代码,除非你已经做过了,否则打开package.xml,确认下面这两行语句没有被注释掉.

  <build_depend>message_generation</build_depend>

  <run_depend>message_runtime</run_depend>

正如之前说的一样,编译的时候,我们需要”message_generation”,而在运行的时候,我们需要”message_tuntime”.

 

除非在之前的步骤中已经做过了,否则在CMakeLists.txt中添加messager_

generatoin依赖:

# Do not just add this to your CMakeLists.txt, modify the existing text to add message_generation before the closing parenthesisfind_package(catkin REQUIRED COMPONENTSroscpprospystd_msgsmessage_generation)


(除了名字,message_generation可以供msgsrv使用)

 

正如message中的一样,在services中你同样也需要改变package.xml,所以看看上面添加要求的依赖:

移除#号解除下面的几行的注释:

# add_service_files(

#   FILES

#   Service1.srv

#   Service2.srv

# )

用你的sercvice文件代替service*.srv文件:

add_service_files(FILESAddTwoInts.srv)

现在你已经准备好从你的service定义中产生源文件了.如果你的想现在就做,跳过下面的步骤去Common step for msg and srv

 

 

3.2使用rossrv

这些就是创建一个srv所有需要做的.让我们用rossrv show命令确认ROS可以看见.:

用法:

$ rossrv show <message type>

例子:

$rossrv  show beginner_tutorials/AddTwoInts

你会看到:

int64 a

int64 b

---

int64 sum

rosmsg相似,你会看到service 文件没有指定package的名字:

$ rossrv show AddTwoInts

[beginner_tutorials/AddTwoInts]:

int64 a

int64 b

---

int64 sum

 

[rospy_tutorials/AddTwoInts]:

int64 a

int64 b

---

int64 sum

 

4.msgsrv的一般步骤

除非已经在前面的步骤做过,否则请在CMakeLists.txt中改变:

# generate_messages(

#   DEPENDENCIES

# #  std_msgs  # Or other packages containing msgs

# )

解除它的注释并且添加任何包含你的message(这里是std_msgs)使用的.msg文件的package,这看起来是这个样子:

generate_messages(

  DEPENDENCIES

  std_msgs

)

 

既然你已经生成了一些新的messages我们需要重新生成package

# In your catkin workspace

$ cd ../..

$ catkin_make

$ cd -

任何msg目录中.msg文件会产生所有支持的语言代码.C++message header文件会产生在~/catkin_ws/devel/include/beginner_tutorials/中.Python脚本会创建在~/catkin_ws/devel/lib/python2.7/distpackages

/beginner_tutorials/msg中,lisp文件~/catkin_ws/devel/share/common-lisp/ros/beginner_tutorials/msg/中.

messages形式的完整描叙在Message Description Language中.

 

5.获取帮助

我们已经明白了许多ROS工具.要了解每一个命令要求的参数很困难.幸好,大部分的ROS工具提供了它们的帮助.

试用:

$ rosmsg -h

 

你会看到一列的不同的rosmsg的子命令:

Commands:

  rosmsg show Show message description

  rosmsg users  Find files that use message

  rosmsg md5  Display message md5sum

  rosmsg package  List messages in a package

  rosmsg packages List packages that contain messages

你也可以得到子命令的帮助:

$ rosmsg show -h

 

这里显示了rosmsg命令需要的参数:

Usage: rosmsg show [options] <message type>

 

Options:

  -h, --help  show this help message and exit

  -r, --raw   show raw message text, including comments

 

6.回顾

让我们列举一下至今我们已经使用的命令:

rospack = ros + pack(age):提供ROS packages的信息

roscd = ros +cd :改变目录到ROS packages或者stack.

rosls = ros +ls:列出ROSpackage中的文件.

roscp = ros + cp :从一个package中拷贝文件,或者拷贝到一个 package中.

rosmsg = ros +msg:提供关于ROSmessage定义的信息.

rossrv = ros +srv :提供关于ROS messages定义的信息

catkin_make:编译一个ROS packages

rosmake = ros + make:编译一个ROS package(如果你不是在 catkin工作空间中)

这篇关于机器人操作系统ROS Indigo 入门学习(11)——创建一个ROS msg和srv的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1001509

相关文章

高效管理你的Linux系统: Debian操作系统常用命令指南

《高效管理你的Linux系统:Debian操作系统常用命令指南》在Debian操作系统中,了解和掌握常用命令对于提高工作效率和系统管理至关重要,本文将详细介绍Debian的常用命令,帮助读者更好地使... Debian是一个流行的linux发行版,它以其稳定性、强大的软件包管理和丰富的社区资源而闻名。在使用

龙蜥操作系统Anolis OS-23.x安装配置图解教程(保姆级)

《龙蜥操作系统AnolisOS-23.x安装配置图解教程(保姆级)》:本文主要介绍了安装和配置AnolisOS23.2系统,包括分区、软件选择、设置root密码、网络配置、主机名设置和禁用SELinux的步骤,详细内容请阅读本文,希望能对你有所帮助... ‌AnolisOS‌是由阿里云推出的开源操作系统,旨

五大特性引领创新! 深度操作系统 deepin 25 Preview预览版发布

《五大特性引领创新!深度操作系统deepin25Preview预览版发布》今日,深度操作系统正式推出deepin25Preview版本,该版本集成了五大核心特性:磐石系统、全新DDE、Tr... 深度操作系统今日发布了 deepin 25 Preview,新版本囊括五大特性:磐石系统、全新 DDE、Tree

Python在固定文件夹批量创建固定后缀的文件(方法详解)

《Python在固定文件夹批量创建固定后缀的文件(方法详解)》文章讲述了如何使用Python批量创建后缀为.md的文件夹,生成100个,代码中需要修改的路径、前缀和后缀名,并提供了注意事项和代码示例,... 目录1. python需求的任务2. Python代码的实现3. 代码修改的位置4. 运行结果5.

使用IntelliJ IDEA创建简单的Java Web项目完整步骤

《使用IntelliJIDEA创建简单的JavaWeb项目完整步骤》:本文主要介绍如何使用IntelliJIDEA创建一个简单的JavaWeb项目,实现登录、注册和查看用户列表功能,使用Se... 目录前置准备项目功能实现步骤1. 创建项目2. 配置 Tomcat3. 项目文件结构4. 创建数据库和表5.

使用SpringBoot创建一个RESTful API的详细步骤

《使用SpringBoot创建一个RESTfulAPI的详细步骤》使用Java的SpringBoot创建RESTfulAPI可以满足多种开发场景,它提供了快速开发、易于配置、可扩展、可维护的优点,尤... 目录一、创建 Spring Boot 项目二、创建控制器类(Controller Class)三、运行

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

手把手教你idea中创建一个javaweb(webapp)项目详细图文教程

《手把手教你idea中创建一个javaweb(webapp)项目详细图文教程》:本文主要介绍如何使用IntelliJIDEA创建一个Maven项目,并配置Tomcat服务器进行运行,过程包括创建... 1.启动idea2.创建项目模板点击项目-新建项目-选择maven,显示如下页面输入项目名称,选择

Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)

《Python基于火山引擎豆包大模型搭建QQ机器人详细教程(2024年最新)》:本文主要介绍Python基于火山引擎豆包大模型搭建QQ机器人详细的相关资料,包括开通模型、配置APIKEY鉴权和SD... 目录豆包大模型概述开通模型付费安装 SDK 环境配置 API KEY 鉴权Ark 模型接口Prompt

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert