ROS2 -Windows编译ros2包(colcon)

2024-08-24 19:48
文章标签 编译 windows ros2 colcon

本文主要是介绍ROS2 -Windows编译ros2包(colcon),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

步骤

1 在windows上安装ROS2 FOXY。

参考:windows安装ros
安装时将对应版本名改为foxy即可。安装时最好保证已经安装了chocolatey和visual studio.

  • 快速安装chocolatey:
Set-ExecutionPolicy Bypass -Scope Process -Force; [System.Net.ServicePointManager]::SecurityProtocol = [System.Net.ServicePointManager]::SecurityProtocol -bor 3072; iex ((New-Object System.Net.WebClient).DownloadString('https://chocolatey.org/install.ps1'))
  • 快速安装ros2和编译工具colcon(注意要用管理员模式启动):
set ChocolateyInstall=d:\
choco source add -n=ros-win -s="https://aka.ms/ros/public" --priority=1
choco install ros-foxy-desktop -y --execution-timeout=0  

2 编译

大部分教程中都使用ament编译。
本文则使用colcon。

colcon 的设计理念可以在这里查到。概括来说,colcon 的目标就是成为一个通用的编译工具,现在主要用来编译 ROS,ROS 2 以及 Gazebo,未来可能使用更广泛。所以尽管 colcon 最早的开发动力来自 ROS 2,但它的定位并不是 ROS 2 的附属品。 colcon 有非常详细的文档,可以在这里查阅。

在 ROS 2 Ardent 版本中编译工具是 ament_tools,从 ROS 2 Bouncy 版本开始,colcon 就成了默认的编译工具。

1 创建包

创建包:

mkdir ros2_ws\src
cd ros2_ws\src
ros2 pkg create <package_name>

创建cpp包:

ros2 pkg create --build-type ament_cmake <package_name>

创建Python包:

ros2 pkg create --build-type ament_python <package_name>

创建包的时候顺便创建节点名,可以添加 --node-name <node_name>
例如:

ros2 pkg create --node-name test_node test_package 

示例:
在这里插入图片描述

2 CMakeList

cmakelist撰写顺序

  1. Required CMake Version (cmake_minimum_required) //cmake版本

  2. Package Name (project()) //包的名字,也是项目名字,并且可以在之后需要使用项目名称时用${PROJECT_NAME}
    替代,好处是,改变项目名字时,只需要改变这里的名字,后续的都会改变。

  3. Find other CMake/Catkin packages needed for build (find_package()) //查找依赖包,并且给出找到包的导出路径、库文件等。

  4. Enable Python module support (colcon_python_setup())

  5. Message/Service/Action Generators(add_message_files(), add_service_files(), add_action_files())

  6. Invoke message/service/action generation (generate_messages())

  7. Specify package build info export (colcon_package())

  8. Libraries/Executables to build (add_library()/add_executable()/target_link_libraries())

  9. Tests to build (colcon_add_gtest())

  10. Install rules (install())

catkin_package:

catkin_package的相关信息是一个catkin提供的CMake宏,需要对build系统具体说明catkin的信息用来产生pkg-config和CMake文件。
catkin_package()必须写在add_library() 或add_executable()之前,有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. For a better understanding, see this explanation.

  • CFG_EXTRAS - Additional configuration options

CmakeLists.txt自动寻找依赖包:

find_package(catkin REQUIRED COMPONENTS nodelet)

配置运行包到CmakeLists.txt:

add_executable(<PACKAGE_NAME> src/main.cpp src/file1.cpp src/file2.cpp)

配置依赖到CmakeLists.txt:

在package.xml文件中,添加编译和运行的ROS依赖库,例如msg包

<build_depend>xx_msgs</build_depend>
<run_depend>xx_msgs</run_depend>

如果不是ros固有的包,而是其他cpp文件。
将cpp文件添加至每个包的src目录下,h文件添加至每个包的include目录下。(无论是运行还是依赖)
add_library是默认建立共享库。
target_link_libraries指定要链接的库,一般放到add_executable()之后。

## include中如果有h头文件
include_directories(include${catkin_INCLUDE_DIRS}
)
## 需要添加的库
add_library(base64include/<PACKAGE_NAME>/XX.hsrc/XX.cpp
)add_dependencies(XX ${${PROJECT_NAME}_EXPORTED_TARGETS} ${colcon_EXPORTED_TARGETS})
target_link_libraries(<需要调用XX的PACKAGE_NAME> XX ${colcon_LIBRARIES})

3 编译运行

  1. –symlink-install :使用符号链接而不是复制文件,如
    以动态链接库为例,会在install目录中使用符号链接,指向build目录下生成的库文件(如 *.so).
    没有该选项,则两个目录都会有该库文件

  2. –packages-select :只编译指定包,如
    colcon build --packages-select autoware_map_msgs vector_map_msgs

  3. –packages-ignore : 忽略指定包,同上

  4. –continue-on-error :在编译出错之后继续编译其他模块

  5. –cmake-args ,–ament-cmake-args, --catkin-cmake-args :传递参数给对应的package

编译src下所有的包:

colcon build --symlink-install

编译指定的包:

colcon build --packages-select  <package1> <package2>

运行
.\setup.bat 或者 .\setup.ps1

 .\setup.bat
ros2 run <package_name> <file_name or execute_name>

参考:
1、ros2框架与colcon
2、colcon相关教程

这篇关于ROS2 -Windows编译ros2包(colcon)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

基于UE5和ROS2的激光雷达+深度RGBD相机小车的仿真指南(五):Blender锥桶建模

前言 本系列教程旨在使用UE5配置一个具备激光雷达+深度摄像机的仿真小车,并使用通过跨平台的方式进行ROS2和UE5仿真的通讯,达到小车自主导航的目的。本教程默认有ROS2导航及其gazebo仿真相关方面基础,Nav2相关的学习教程可以参考本人的其他博客Nav2代价地图实现和原理–Nav2源码解读之CostMap2D(上)-CSDN博客往期教程: 第一期:基于UE5和ROS2的激光雷达+深度RG

maven 编译构建可以执行的jar包

💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」👈,「stormsha的知识库」👈持续学习,不断总结,共同进步,为了踏实,做好当下事儿~ 专栏导航 Python系列: Python面试题合集,剑指大厂Git系列: Git操作技巧GO

在 Windows 上部署 gitblit

在 Windows 上部署 gitblit 在 Windows 上部署 gitblit 缘起gitblit 是什么安装JDK部署 gitblit 下载 gitblit 并解压配置登录注册为 windows 服务 修改 installService.cmd 文件运行 installService.cmd运行 gitblitw.exe查看 services.msc 缘起

Windows如何添加右键新建菜单

Windows如何添加右键新建菜单 文章目录 Windows如何添加右键新建菜单实验环境缘起以新建`.md`文件为例第一步第二步第三步 总结 实验环境 Windows7 缘起 因为我习惯用 Markdown 格式写文本,每次新建一个.txt后都要手动修改为.md,真的麻烦。如何在右键新建菜单中添加.md选项呢? 网上有很多方法,这些方法我都尝试了,要么太麻烦,要么不凑效

Windows下Nginx的安装及开机启动

1、将nginx-1.16.1.zip解压拷贝至D:\web\nginx目录下。 2、启动Nginx,两种方法: (1)直接双击nginx.exe,双击后一个黑色的弹窗一闪而过。 (2)打开cmd命令窗口,切换到nginx目录下,输入命令 nginx.exe 或者 start nginx ,回车即可。 3、检查nginx是否启动成功。 直接在浏览器地址栏输入网址 http://lo

Windows环境利用VS2022编译 libvpx 源码教程

libvpx libvpx 是一个开源的视频编码库,由 WebM 项目开发和维护,专门用于 VP8 和 VP9 视频编码格式的编解码处理。它支持高质量的视频压缩,广泛应用于视频会议、在线教育、视频直播服务等多种场景中。libvpx 的特点包括跨平台兼容性、硬件加速支持以及灵活的接口设计,使其可以轻松集成到各种应用程序中。 libvpx 的安装和配置过程相对简单,用户可以从官方网站下载源代码

C++实现俄罗斯方块(Windows控制台版)

C++实现俄罗斯方块(Windows控制台版) 在油管上看到一个使用C++控制台编写的俄罗斯方块小游戏,源代码200多行,B站上也有相关的讲解视频,非常不错,值得学习。 B站讲解视频地址为:【百万好评】国外技术大神C++游戏编程实战教程,油管580W收藏,新手10小时入门,并快速达到游戏开发能力(中英字幕) B站 CSDN博主千帐灯无此声还为此写了一篇博客:C++实现俄罗斯方块(源码+详解),讲

Golang test编译使用

创建文件my_test.go package testsimport "testing"func TestMy(t *testing.T) {t.Log("TestMy")} 通常用法: $ go test -v -run TestMy my_test.go=== RUN TestMyTestMy: my_test.go:6: TestMy--- PASS: TestMy (0.

Windows下php扩展开发c++动态库

PHP扩展开发,从零了解到初步完成一个小项目,经过三天的仔细研究,现整理如下 一、需求介绍 PHP扩展开发,调用自己之前的c++动态库,完成功能 二、项目之前 系统:windows xp  开发工具:vs 2008 web环境:apache2.4  PHP5.3.29-VC9-ts-x86 aphach和PHP 环境之前已经搭建完成 PHP源码:去官网http://www.php.n

C++/《C/C++程序编译流程》

程序的基本流程如图:   1.预处理        预处理相当于根据预处理指令组装新的C/C++程序。经过预处理,会产生一个没有宏定义,没有条件编译指令,没有特殊符号的输出文件,这个文件的含义同原本的文件无异,只是内容上有所不同。 读取C/C++源程序,对其中的伪指令(以#开头的指令)进行处理将所有的“#define”删除,并且展开所有的宏定义处理所有的条件编译指令,如:“#if”、“