ROS中 package.xml CMakeList.txt launch文件

2024-02-04 23:38

本文主要是介绍ROS中 package.xml CMakeList.txt launch文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

主要介绍ROS package程序包里package.xml,cmakelist.txt,launch文件,分别介绍文件里的语法组成,对于后续开发ROS程序有很大帮助。一个catkin程序包必须包含 package.xml和CMakeList.txt文件,这个package.xml文件提供有关程序包的元信息,而catkin metapackages中必须包含一个对CMakeList.txt文件的引用。

Part 1: 最简单的程序包:

my_package/
      CMakeLists.txt
      package.xm

一个简单catkin工作空间:
Workspace_folder                       -- WORKSPACE
        src/                           -- SOURCE SPACE
              CMakeLists.txt               -- ‘Toplevel’CMake file, provided by catkin
              package_1/
                      CMakeLists.txt       -- CMakeLists.txt file for package_1
                      package.xml          -- Package manifest for package_1
              …
              package_n/
                      CMakeLists.txt       -- CMakeLists.txt file for package_n
                      package.xml          -- Package manifest for package_n

Part 2: package.xml

每一个package.xml文件都以<package>作为根标签

<package>
...
</package>

在<package>内部至少得包含以下一系列标签:

<name> - 标签名
<version> - 程序包版本号
<description> - 程序包内容描述
<maintainer> - 维护程序包人名
<license> - 软件协议如GPL, BSD, ASL等


最简单package.xml文件example:

<package>
  <name>foo_core</name>
  <version>1.2.4</version>
  <description>
  This package provides foo capability.
  </description>
  <maintainer email="ivana@willowgarage.com">Ivana Bildbotz</maintainer>
  <license>BSD</license>
</package>


接下来的标签用来描述程序包的各种依赖项,这些依赖项分为build_depend、buildtool_depend、run_depend、test_depend。buildtool_depend指的编译package所需要systemtools,build_depend指的编译这个package所需要的package,run_depend运行这个包里代码所需的package或library,test_depend指的是单元测试所需的额外依赖项。

<buildtool_depend> <build_depend> <run_depend> <test_depend> 至少得有一个依赖的项。

<package>
  <name>foo_core</name>
  <version>1.2.4</version>
  <description>
    This package provides foo capability.
  </description>
  <maintaineremail="ivana@willowgarage.com">Ivana Bildbotz</maintainer>
  <license>BSD</license>
 <buildtool_depend>catkin</buildtool_depend>
</package>

此外,还有<url> <author>等标签。

Part 3: CMakeList.txt

CMakeList.txt文件需要以以下格式,否则不能正确编译

1,Required CMake Version (cmake_minimum_required)
2,Package Name (project())
3,Find other CMake/Catkin packages needed for build (find_package())
4,Message/Service/Action Generators (add_message_files(), add_service_files(), add_action_files())
5,Invoke message/service/action generation (generate_messages())
6,Specify package build info export (catkin_package())
7,Libraries/Executables to build (add_library()/add_executable()/target_link_libraries())
8,Tests to build (catkin_add_gtest())
9,Install rules (install())

(1)  CMakeLists.txt最开始指出CMake所需版本,Catkin 要求2.8.3或者更高

cmake_minimum_required(VERSION 2.8.3)

(2)  接下来项是package name

project(beginner_tutorials)

(3)  find_package用来指明build project所需要其他的CMake package

find_package(catkin REQUIRED COMPONENTS roscpp rospy std_msgs genmsg)   依赖于catkin roscpp rospy std_msgs message_generation。

(4)  catkin_package() 是一个catkin Cmake宏,必须在 add_library()和add_executable()之前,catkin_package()包含5个可选的参数:

INCLUDE_DIRS - The exported include paths (i.e. cflags) for the package

LIBRARIES - The exported libraries from the project

CATKIN_DEPENDS - Other catkin projects that this project depends on

DEPENDS - Non-catkin CMake projects that this project depends on

CFG_EXTRAS - Additional configuration options

例如

catkin_package(
     INCLUDE_DIRS include
     LIBRARIES ${PROJECT_NAME}
     CATKIN_DEPENDS roscpp nodelet
     DEPENDS eigen opencv)

(5)  Build Targets:编译目标有多种形式,通常是可执行目标文件或者可执行文件编译和运行所需要的库文件。

1.  include_directories()   link_directories()

include_directories(<dir1>, <dir2>, ..., <dirN>)

link_directories(<dir1>, <dir2>, ..., <dirN>)

例如使用catkin和Boost,则  include_directories(include ${Boost_INCLUDE_DIRS}  ${catkin_INCLUDE_DIRS}) 第一个参数”include”指的是package内的include/路径

link_directories()可以用来添加额外库的路径,但是一般不推荐。  比如:  link_directories(~/my_libs)

2.  add_executable()

add_executable(myProgramsrc/main.cpp src/some_file.cpp src/another_file.cpp)

把src/main.cpp  src/some_file.cpp  src/another_file.cpp.编译成可执行文件myProgram

3. add_library() 

add_library(${PROJECT_NAME} ${${PROJECT_NAME}_SRCS})

4. target_link_libraries()

target_link_libraries() 指明可执行文件运行所需要的链接库

语法:target_link_libraries(<executableTargetName>,<lib1>, <lib2>, ... <libN>)

例子:

add_executable(foo src/foo.cpp)
add_library(moo src/moo.cpp)
target_link_libraries(foo moo)  -- This links foo against libmoo.so

(6)  messages services actions

有3个宏分别用来添加messages  services 和actions: add_message_files()  add_service_files()  add_action_files(),紧接着  generate_messages()生成对应的messages,services,actions 。这些宏必须在 catkin_package()宏之前,如下:

find_package(catkinREQUIRED COMPONENTS ...)
 add_message_files(...)
 add_service_files(...)
 add_action_files(...)
 generate_messages(...)
 catkin_package(...)
 ...

(7)  catkin_package()

catkin_package(
 ...
 CATKIN_DEPENDS message_runtime ...
 ...)

必须有个CATKIN_DEPENDS 、message_runtime。

Part 4: launch

例如下面launch xml文件

<launch>
  <groupns="turtlesim1">
    <nodepkg="turtlesim"name="sim"type="turtlesim_node"/>
  </group>
  <groupns="turtlesim2">
    <nodepkg="turtlesim"name="sim"type="turtlesim_node"/>
  </group>
  <nodepkg="turtlesim"name="mimic"type="mimic">
    <remapfrom="input"to="turtlesim1/turtle1"/>
    <remapfrom="output"to="turtlesim2/turtle1"/>
  </node>
</launch>

<launch>  以launch标签开头以表明这是一个launch文件 

<groupns="turtlesim1">
    <nodepkg="turtlesim"name="sim"type="turtlesim_node"/>
  </group>
  <groupns="turtlesim2">
    <nodepkg="turtlesim"name="sim"type="turtlesim_node"/>
  </group>

创建了两个节点分组并以'命名空间(namespace)'标签来区分,其中一个名为turtulesim1,另一个名为turtlesim2,两个组里面都使用相同的turtlesim节点并命名为'sim'。这样可以同时启动两个turtlesim模拟器而不会产生命名冲突。

<nodepkg="turtlesim"name="mimic"type="mimic">
    <remapfrom="input"to="turtlesim1/turtle1"/>
    <remapfrom="output"to="turtlesim2/turtle1"/>
  </node>

在这里我们启动模仿节点,并将所有话题的输入和输出分别重命名为turtlesim1和turtlesim2,这样就会使turtlesim2模仿turtlesim1。

 </launch>  这个是launch文件的结束标签。



这篇关于ROS中 package.xml CMakeList.txt launch文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

解析 XML 和 INI

XML 1.TinyXML库 TinyXML是一个C++的XML解析库  使用介绍: https://www.cnblogs.com/mythou/archive/2011/11/27/2265169.html    使用的时候,只要把 tinyxml.h、tinystr.h、tinystr.cpp、tinyxml.cpp、tinyxmlerror.cpp、tinyxmlparser.

ROS话题通信流程自定义数据格式

ROS话题通信流程自定义数据格式 需求流程实现步骤定义msg文件编辑配置文件编译 在 ROS 通信协议中,数据载体是一个较为重要组成部分,ROS 中通过 std_msgs 封装了一些原生的数据类型,比如:String、Int32、Int64、Char、Bool、Empty… 但是,这些数据一般只包含一个 data 字段,结构的单一意味着功能上的局限性,当传输一些复杂的数据,比如:

CMake笔记之CMAKE_INSTALL_PREFIX详解以及ROS中可执行文件为什么会在devel_lib中

CMake笔记之CMAKE_INSTALL_PREFIX详解以及ROS中可执行文件为什么会在devel_lib中 code review! 文章目录 CMake笔记之CMAKE_INSTALL_PREFIX详解以及ROS中可执行文件为什么会在devel_lib中1.`CMAKE_INSTALL_PREFIX`详解变量作用设置 `CMAKE_INSTALL_PREFIX`示例影响范围常

pom.xml第一行报错

错误信息:org.apache.maven.archiver.MavenArchiver.getManifest(org.apache.maven.project.MavenProject,org.apache.maven.archiver.MavenArchiveConfiguration)  解决办法:  Help–>Install From Site Connectivity(instal

oracle数据导出txt及导入txt

oracle数据导出txt及导入txt ORACLE数据导出TXT及从TXT导入: 导出到TXT文件: 1、用PL/SQL DEV打开CMD窗口。 2、spool d:/output.txt; 3、set heading off; --去掉表头 4、select * from usergroup; 5、spool off; www.2ct

ROS话题通信机制实操C++

ROS话题通信机制实操C++ 创建ROS工程发布方(二狗子)订阅方(翠花)编辑配置文件编译并执行注意订阅的第一条数据丢失 ROS话题通信的理论查阅ROS话题通信流程理论 在ROS话题通信机制实现中,ROS master 不需要实现,且连接的建立也已经被封装了,需要关注的关键点有三个: 发布方(二狗子)订阅方(翠花)数据(此处为普通文本) 创建ROS工程 创建一个ROS工程

关于C#读写XML的公用类

XmlHelper有很多种写法,以泛型的方式保存和读取xml,可以做到像下面这么简化又实用: 调用处 var sysParam = XmlHelper.LoadFromXML<TSysParam>(ApplicationDir.SystemParamFile);  //无参数文件时,初始化系统参数到XML文件  XmlHelper.SaveAsXML(ApplicationDir.System

maven settings.xml无效排查过程

1.首先执行mvn help:effective-settings,查找当前maven仓库地址 2.错误信息 [ERROR] Error executing Maven. [ERROR] 2 problems were encountered while building the effective settings [FATAL] Non-parseable settings /Users/x

SpringBoot-注解@ImportResource引入自定义spring的配置xml文件和配置类

1、注解@ImportResource 我们知道Spring的配置文件是可以有很多个的,我们在web.xml中如下配置就可以引入它们: SprongBoot默认已经给我们配置好了Spring,它的内部相当于已经有一个配置文件,那么我们想要添加新的配置文件怎么办? 注解@ImportResource就在干这个的: ① 创建一个新的spring配置文件 ② 程序口入,主类上加注解

在eclipse中进行nutch1.7二次开发通过ant编译build.xml出现Class not found javac1.8

把nutch1.7通过svn导入到本地后打算进行二次开发却在开始用ant进行build.xml构建的时候出现Class not found javac1.8 暂且不管哪个sonar没有找到的问题,我们先把那个Class not found :javac1.8的问题: 多半是因为Ant版本太低,低于1.9,无法和java1.8兼容,因为我的java运行环境是1.8的,Ant版本也是1.8,所