ROS的学习(四)创建一个ROS包

前端之家收集整理的这篇文章主要介绍了ROS的学习(四)创建一个ROS包前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

ROS学习(三)中,笔者不知道catkin到底是个什么东东,后来终于在官方网站上找到了答案,原来catkin是ROS的一个官方的编译构建系统,是原本的ROS的编译构建系统rosbuild的后继者。catkin的来源有点复杂,我们可以慢慢的讲一下其中的渊源。ROS来源于Willow Garage这个公司,他们希望借助开源的力量,使ROS发扬光大。而在英语中,willow的意思是柳树,catkin是柳絮的意思,为了纪念的作用吧,因而为这个软件命名为catkin。

这篇博客的主要内容是介绍如何使用catkin创建一个ROS包。一个catkin的包主要有以下几部分组成:(1)必须包括一个package.xml文件,(2)必须包括一个CMakeLists.txt文件,(3)在每一个文件夹下只能有一个包,且包不允许嵌套。一个最简单的包类似于如下的形式:

  1. my_package/
  2. CMakeLists.txt
  3. package.xml

官网上推荐在catkin工作空间中使用catkin包,当然也可以独立使用catkin包,一个典型的工作空间结构如下:
  1. workspace_folder/ -- WORKSPACE
  2. src/ -- SOURCE SPACE
  3. CMakeLists.txt -- 'Toplevel' CMake file,provided by catkin
  4. package_1/
  5. CMakeLists.txt -- CMakeLists.txt file for package_1
  6. package.xml -- Package manifest for package_1
  7. ...
  8. package_n/
  9. CMakeLists.txt -- CMakeLists.txt file for package_n
  10. package.xml -- Package manifest for package_n

我们之前已经创建过一个空的工作空间:catkin_ws,下面我们来看一下如何在一个工作空间中创建一个包。在创建一个catkin包时需要使用catkin_create_pkg脚本。

首先进入到目录~/catkin_ws/src下,使用如下命令:

  1. cd ~/catkin_ws/src

接着创建一个名字为beginner_tutorials的包,它直接以来与一下三个包:std_msgs,rospy以及roscpp,使用如下命令:
  1. catkin_create_pkg beginner_tutorials std_msgs rospy roscpp

在创建的 beginner_tutorials文件夹下可以看到package.xml和CMakeLists.txt。catkin_create_pkg要求您给出包的名字,及选择性的给出所创建的包依赖于哪一个包。他的使用方法如下:
  1. catkin_create_pkg <package_name> [depend1] [depend2] [depend3]

这样,我们的一个包就创建好了,我们可能会需要对包之间的依赖性做一下解释。我们可以使用rospack命令来查看包之间的依赖关系。查看直接依赖关系:
  1. rospack depends1 beginner_tutorials

可以看到,返回的结果正是我们使用catkin_create_pkg时,所使用的参数。我们还可以直接在beginner_tutorials包下的package.xml中查看包的依赖关系。使用命令:
  1. roscd beginner_tutorials
  2. cat package.xml

结果如下:
  1. <package>
  2. ...
  3. <buildtool_depend>catkin</buildtool_depend>
  4. <build_depend>roscpp</build_depend>
  5. <build_depend>rospy</build_depend>
  6. <build_depend>std_msgs</build_depend>
  7. ...
  8. </package>

在通常情况下,一个包所依赖的包又会依赖许多其它的包,这称为间接依赖。我们使用如下命令来查看rospy依赖的包:
  1. rospack depends1 rospy

返回结果如下:
  1. genpy
  2. rosgraph
  3. rosgraph_msgs
  4. roslib
  5. std_msgs

一个包可以有很多的间接依赖关系,我们可以使用命令:
  1. rospack depends beginner_tutorials

来进行查看。返回结果如下:
  1. cpp_common
  2. rostime
  3. roscpp_traits
  4. roscpp_serialization
  5. genmsg
  6. genpy
  7. message_runtime
  8. rosconsole
  9. std_msgs
  10. rosgraph_msgs
  11. xmlrpcpp
  12. roscpp
  13. rosgraph
  14. catkin
  15. rospack
  16. roslib
  17. rospy

接下来配置您的package.xml包,我们将会一个标签一个标签的分析这个xml文件。首先是description标签
  1. <description>The beginner_tutorials package</description>

在这个标签中的内容可以改变为任何的内容,不过一般是对这个包的一个简述,尽量简单就行。接下来是maintainer标签
  1. <!-- One maintainer tag required,multiple allowed,one person per tag -->
  2. <!-- Example: -->
  3. <!-- <maintainer email="jane.doe@example.com">Jane Doe</maintainer> -->
  4. <maintainer email="user@todo.todo">user</maintainer>

这是一个很重要的标签,因为可以根据这个标签知道它的维护者,另外标签的email属性也是必须的,可有多个maintainer标签。接下来是license标签
  1. <!-- One license tag required,one license per tag -->
  2. <!-- Commonly used license strings: -->
  3. <!-- BSD,MIT,Boost Software License,GPLv2,GPLv3,LGPLv2.1,LGPLv3 -->
  4. <license>TODO</license>

在后面的使用中,一般我们将license修改为BSD。接下来是依赖性的标签
  1. <!-- The *_depend tags are used to specify dependencies -->
  2. <!-- Dependencies can be catkin packages or system dependencies -->
  3. <!-- Examples: -->
  4. <!-- Use build_depend for packages you need at compile time: -->
  5. <!-- <build_depend>genmsg</build_depend> -->
  6. <!-- Use buildtool_depend for build tool packages: -->
  7. <!-- <buildtool_depend>catkin</buildtool_depend> -->
  8. <!-- Use run_depend for packages you need at runtime: -->
  9. <!-- <run_depend>python-yaml</run_depend> -->
  10. <!-- Use test_depend for packages you need only for testing: -->
  11. <!-- <test_depend>gtest</test_depend> -->
  12. <buildtool_depend>catkin</buildtool_depend>
  13. <build_depend>roscpp</build_depend>
  14. <build_depend>rospy</build_depend>
  15. <build_depend>std_msgs</build_depend>

我们向里面添加了run_depend:
  1. <run_depend>roscpp</run_depend>
  2. <run_depend>rospy</run_depend>
  3. <run_depend>std_msgs</run_depend>
好了,经过以上的步骤,我们的package.xml已经配置好了。

猜你在找的XML相关文章