当前位置: 首页 > article >正文

【ROS2小白入门】从 ROS 1 到 ROS 2 的跨越:实战重构机器人底盘 Manager 节点

文章目录一、 构建系统的蜕变CMakeLists.txt 的优雅转身1. 告别 target_link_libraries 避坑指南 1找不到 serial 串口库二、 C 源码大换血彻底消灭 NodeHandle三、 通信机制迁移发布、订阅与异步服务1. 话题发布与订阅使用 std::bind2. 服务端与客户端拥抱异步四、 参数加载与多线程现代 C 的胜利1. 极简的参数加载2. 拥抱 std::thread五、 自定义消息与 Conda 环境的“血泪史” 避坑指南 2头文件“蛇形命名法”强制规定 避坑指南 3ModuleNotFoundError: No module named em结语在机器人底盘开发中Manager大管家节点通常充当着“大脑”的角色负责统筹底层硬件如 BMS 电池管理系统、驱动板并与上层算法导航、视觉进行交互。很多小伙伴在将原有的 ROS 1 机器人项目迁移到 ROS 2Humble时面对满屏的编译报错往往感到无从下手。今天我们就以一个真实的底盘 Manager 节点为例手把手带你完成从 ROS 1 到 ROS 2 的 C 代码重构并盘点那些让人抓狂的“暗坑”一、 构建系统的蜕变CMakeLists.txt的优雅转身在 ROS 2 中构建系统从catkin全面拥抱了ament_cmake。摒弃了过去繁琐的链接宏ROS 2 提供了极其优雅的依赖绑定方式。1. 告别target_link_libraries在 ROS 1 中我们需要手动链接一大堆库。而在 ROS 2 中只要用find_package找到了依赖最后用一个专属宏ament_target_dependencies就能将头文件和库一并绑定给可执行文件# 声明要编译的节点 add_executable(chassis_manager_node src/chassis_manager_node.cpp) # 核心新增将找到的依赖项全部链接到你的节点上 ament_target_dependencies(chassis_manager_node rclcpp std_msgs sensor_msgs nav_msgs my_robot_msgs # 你的自定义消息包 ) 避坑指南 1找不到serial串口库在 ROS 1 时代标配的serial库在 ROS 2 的官方 apt 软件源里并没有直接提供。如果直接#include serial/serial.h编译会直接罢工。解法去 GitHub 克隆开源社区维护的 ROS 2 兼容版serial库如joshnewans/serial到你的工作空间src目录下一起colcon build即可完美反杀二、 C 源码大换血彻底消灭NodeHandleROS 2 的核心理念是全面面向对象。在头文件中出场率极高的ros::NodeHandle必须全部替换为智能指针。重构对比ROS 1:ChassisManager(ros::NodeHandle nh);ROS 2:ChassisManager(rclcpp::Node::SharedPtr node);同时我们在类成员中保存这个node_指针后续所有的日志打印、参数获取全靠它// 日志打印的变迁// 旧ROS_ERROR(Error: %s, e.what());// 新RCLCPP_ERROR(node_-get_logger(),Error: %s,e.what());三、 通信机制迁移发布、订阅与异步服务这是迁移中最耗费体力但也最能体现 ROS 2 架构优势的部分。1. 话题发布与订阅使用std::bind由于回调函数是类成员函数在 ROS 2 创建订阅者时必须使用std::bind显式绑定this指针// 发布者是指针发布时需要用 - 操作符battery_pub_node_-create_publishersensor_msgs::msg::BatteryState(/battery_state,1);battery_pub_-publish(msg);// 订阅者需要显式绑定switch_sub_node_-create_subscriptionmy_robot_msgs::msg::SwitchState(/switch_state,1,std::bind(ChassisManager::switchCallback,this,std::placeholders::_1));(注ROS 2 废弃了latchtrue参数如果需要锁存话题需配置 QoS 的transient_local()策略。)2. 服务端与客户端拥抱异步在 ROS 1 中client.call(req)是阻塞的容易导致主线程卡死。在 ROS 2 多线程环境下我们推荐使用异步调用加.get()阻塞等待的优雅写法// 异步发送请求并阻塞等待结果autocancel_goal_reqstd::make_sharedmy_robot_srvs::srv::CancelGoal::Request();if(cancel_goal_srv_client_-wait_for_service(std::chrono::seconds(2))){cancel_goal_srv_client_-async_send_request(cancel_goal_req).get();RCLCPP_INFO(node_-get_logger(),Navigation goal canceled!);}四、 参数加载与多线程现代 C 的胜利1. 极简的参数加载在 ROS 2 中读取参数必须先声明。而且 ROS 2 原生支持读取数组再也不用像 ROS 1 那样写几十行繁琐的XmlRpc解析代码了// 一行代码搞定字符串数组加载极其优雅ultrasonic_param_.topicsnode_-declare_parameterstd::vectorstd::string(ultrasonic.topics,std::vectorstd::string());2. 拥抱std::thread摒弃臃肿的boost::thread和boost::mutex全面使用 C11/14 标准库的std::thread和std::mutex。致命提醒使用std::thread时必须在析构函数里调用.join()回收线程否则节点退出时整个程序会直接崩溃引发 coredump五、 自定义消息与 Conda 环境的“血泪史”在迁移自定义消息.msg和.srv时我们很容易踩到本次重构中最经典的两个坑 避坑指南 2头文件“蛇形命名法”强制规定在 ROS 1 中消息头文件是大驼峰命名例如#include sensor_msgs/Range.h。但在 ROS 2 中生成器会强制将其全部转为全小写的蛇形命名snake_case加.hpp后缀如果你写成#include sensor_msgs/msg/Range.hpp或者#include my_robot_msgs/msg/SwitchState.hpp编译器会直接报错找不到文件。正确写法#includesensor_msgs/msg/range.hpp#includemy_robot_msgs/msg/switch_state.hpp心法只要是msg或srv的头文件统统全小写加下划线 避坑指南 3ModuleNotFoundError: No module named em在执行colcon build编译自定义消息包时如果突然爆出找不到em或empy的 Python 错误请立刻检查你的终端是否激活了 Anaconda 环境带有(base)前缀CMake 会错误地调用 Conda 环境的 Python 去编译 ROS 2 的接口文件从而导致依赖缺失。解法敲击conda deactivate退出虚拟环境删除工作空间下的build和install文件夹再重新编译即可顺利通关结语从 ROS 1 到 ROS 2 的代码迁移本质上是从旧有的 C98/03 思维向现代 C11/14/17 架构体系的全面进化。虽然在这个过程中我们需要处理命名空间变动、智能指针替换等大量“体力活”但当你看到colcon build最终输出Finished的那一刻你会发现这一切的重构都是值得的你的底盘系统已经在 ROS 2 下焕发新生了

相关文章:

【ROS2小白入门】从 ROS 1 到 ROS 2 的跨越:实战重构机器人底盘 Manager 节点

文章目录一、 构建系统的蜕变:CMakeLists.txt 的优雅转身1. 告别 target_link_libraries🚨 避坑指南 1:找不到 serial 串口库?二、 C 源码大换血:彻底消灭 NodeHandle三、 通信机制迁移:发布、订阅与异步服…...

ArduinoFritzApi:嵌入式设备对接FRITZ!Box的TR-064协议实践

1. ArduinoFritzApi 库深度解析:面向嵌入式系统的 FRITZ!Box 自动化控制实践指南1.1 库定位与工程价值ArduinoFritzApi 是一个专为嵌入式平台设计的轻量级 C 库,其核心目标是实现对 AVM 公司全系智能家庭设备(FRITZ!Box 路由器、FRITZ!DECT 插…...

手把手教你搭建基于Matlab/Simulink的插电式混合动力汽车4驱PHEV模型

基于Matlab/simulink的插电式混合动力汽车建模仿真模型4驱PHEV(比亚迪唐DM混动系统P2P4发动机——三擎四驱),包括整车HCU控制单元、发动机模型、驱动电机模型、ISG电机模型、AMT5档自动变速箱模型、驾驶员模型、电池能量管理控制模型等&#…...

EspNowBus:ESP32轻量级安全无线总线库

1. EspNowBus 项目概述 EspNowBus 是一个面向 ESP32 平台、以组(Group)为组织单元的轻量级 ESP-NOW 消息总线库,专为小型嵌入式无线网络(典型规模 ≈6 节点)设计。其核心工程目标并非追求最大吞吐或最广覆盖&#xff0…...

JPom结合Docker实现SpringBoot项目自动化构建与部署实战

1. 为什么你需要JPomDocker自动化部署方案 每次手动打包SpringBoot项目时,你是不是也经历过这样的痛苦?先在本地mvn clean package,然后scp上传到服务器,接着ssh连上去kill旧进程,最后nohup启动新jar包。更可怕的是半夜…...

3D建模快速上手:零门槛掌握TripoSR AI驱动开源工具

3D建模快速上手:零门槛掌握TripoSR AI驱动开源工具 【免费下载链接】TripoSR 项目地址: https://gitcode.com/GitHub_Trending/tr/TripoSR 在数字创作领域,3D建模曾是专业人士的专属技能,需要掌握复杂的软件操作和几何知识。但今天&a…...

事件驱动RTOS EventOS的创新设计与应用实践

1. 事件驱动型RTOS的创新设计 在嵌入式系统开发领域,实时操作系统(RTOS)一直是关键基础设施。传统RTOS如FreeRTOS、uC/OS等大多采用基于时间片轮转的任务调度机制,而EventOS则开创性地采用了事件驱动架构,这在资源受限的嵌入式环境中具有独特…...

【等保三级Java系统合规落地指南】:20年安全架构师亲授7大关键改造步骤与避坑清单

第一章:等保三级Java系统合规落地的顶层认知与法律依据等保三级(GB/T 22239–2019《信息安全技术 网络安全等级保护基本要求》)并非单纯的技术加固任务,而是覆盖组织管理、制度建设、技术实施与持续运营的全生命周期合规工程。对J…...

7个技巧彻底改变你的Mac菜单栏体验:Ice终极配置指南

7个技巧彻底改变你的Mac菜单栏体验:Ice终极配置指南 【免费下载链接】Ice Powerful menu bar manager for macOS 项目地址: https://gitcode.com/GitHub_Trending/ice/Ice Ice是一款强大的macOS菜单栏管理工具,专门帮助用户整理杂乱的菜单栏图标&…...

从零打造你的CAD开发环境:用OpenCASCADE 7.7.0 + VS2022画个3D盒子(完整Debug/Release配置)

从零打造你的CAD开发环境:用OpenCASCADE 7.7.0 VS2022画个3D盒子(完整Debug/Release配置) 当你第一次尝试在Visual Studio中配置OpenCASCADE(OCCT)时,可能会被那些复杂的路径设置、库文件链接和环境变量搞…...

探索DevOps之路:2024年DevOps路线图

探索DevOps之路:2024年DevOps路线图 【免费下载链接】DevOps-Roadmap DevOps Roadmap for 2026. with learning resources 项目地址: https://gitcode.com/GitHub_Trending/de/DevOps-Roadmap 项目介绍 DevOps Roadmap 2024 是一个精心设计的步骤指南&#…...

VIT模型IP核需要修改的地方

导入路径 "D:\VIT\HG-PIPE\instances\proj_ATTN0\work"选择“open project”整合多个 HLS IP 时 遇到“撞名”此时会报错:Top function not found: there is no function named top INFO: [HLS 200-1510] Running: set_directive_top -name top top...

太吾绘卷Mod终极指南:从零开始打造个性化游戏体验

太吾绘卷Mod终极指南:从零开始打造个性化游戏体验 【免费下载链接】Taiwu_mods 太吾绘卷游戏Mod 项目地址: https://gitcode.com/gh_mirrors/ta/Taiwu_mods 想要为《太吾绘卷》注入全新活力吗?太吾绘卷Mod为这款经典游戏带来了无限可能&#xff0…...

AD5246数字电位器驱动库详解与I²C工程实践

1. AD5246 数字电位器库深度技术解析1.1 器件本质与工程定位AD5246 并非传统意义上的“可编程电阻”,而是一款单通道、IC 接口、128 抽头数字可变电阻器(Digital Rheostat)。其核心价值在于以数字方式精确控制模拟电路中的阻值,替…...

AI如何悄悄改变你的日常生活?5个你已离不开的AI应用场景

AI如何悄悄改变你的日常生活?5个你已离不开的AI应用场景 清晨被智能闹钟以最舒适的渐强音量唤醒,通勤路上听着音乐App精准推荐的歌单,晚上回家对着冰箱说出想吃的菜谱——这些场景中隐藏的AI技术,早已像水电一样成为生活基础设施。…...

3D重建效率革命:从单张图片到高质量模型的全流程指南

3D重建效率革命:从单张图片到高质量模型的全流程指南 【免费下载链接】TripoSR 项目地址: https://gitcode.com/GitHub_Trending/tr/TripoSR 在数字内容创作领域,3D建模长期面临两大核心痛点:一方面,传统3D建模软件如Blen…...

ESP32-CAM人脸识别从入门到实战:5步搞定考勤系统(附完整代码)

ESP32-CAM人脸识别考勤系统实战指南:低成本高精度部署方案 引言:重新定义考勤管理的技术革新 在传统考勤方式逐渐显露出效率瓶颈的今天,基于ESP32-CAM的人脸识别技术为中小企业和教育机构提供了一种革命性的解决方案。这套系统不仅突破了传统…...

永磁同步电机的 MTPA + 弱磁控制算法 Simulink 模型探索

永磁同步电机的MTPA弱磁控制算法simulink模型。 转速从4000变到16000转,效果较好,附赠核心模型对应公式文档。在电机控制领域,永磁同步电机(PMSM)因其高效、高功率密度等优点,被广泛应用于各种工业和民用场…...

研发物料管理新思路:巧用SAP预留功能实现打样耗材精准管控

研发物料管理新思路:巧用SAP预留功能实现打样耗材精准管控 在制造业研发部门,物料管理一直是令人头疼的难题。不同于生产线的标准化流程,研发活动往往伴随着频繁的设计变更、小批量试制和突发性物料需求。传统的手工台账或Excel表格管理方式&…...

SteamShutdown:智能下载管理与自动化电源控制的创新解决方案

SteamShutdown:智能下载管理与自动化电源控制的创新解决方案 【免费下载链接】SteamShutdown Automatic shutdown after Steam download(s) has finished. 项目地址: https://gitcode.com/gh_mirrors/st/SteamShutdown 在数字娱乐时代,游戏下载已…...

从脑电波到股票K线:EMD经验模态分解在5个真实场景下的避坑指南

从脑电波到股票K线:EMD经验模态分解在5个真实场景下的避坑指南 当你第一次看到脑电波信号与股票K线图被放在同一个分析框架下讨论时,可能会觉得这是两个毫不相关的领域。但事实上,无论是神经科学家的EEG数据,还是量化交易员的股价…...

图像处理算法资料(FPGA Verilog): RGB2GRAY、阈值分割、滤波、边缘检测等算...

图像处理算法资料( FPGA Verilog) 分别有RGB2GRAY、阈值分割(二值化)、均值滤波、中值滤波、sobel边缘检测、膨胀、腐蚀、开闭运算。 各个模块的结构与上图的顶层模块结构一致,通过模块之间的组合串联组成 ISP 顶层模块。 使用vivado软件&…...

误删Anaconda?3步极速抢救指南

Anaconda被误删后抢救手册技术文章大纲数据恢复的基本原理解释数据恢复的底层机制,包括文件系统如何处理删除操作,以及为何被删除的数据仍有可能恢复。涵盖不同操作系统(Windows、macOS、Linux)下的差异。立即停止使用受影响磁盘强…...

T/SCSIA0018-2025《四川省信息技术应用创新项目费用测算标准》标准解读

此前四川省存量信息系统信创适配改造项目长期面临费用测算无统一标准、议价争议多、成本虚高、重复计费等行业痛点,给项目估算、审计、结算带来诸多困扰。2025年12月29日发布的T/SCSIA0018-2025《四川省信息技术应用创新项目费用测算标准》,作为省内首个…...

MOS管驱动电路设计要点与常见问题解析

1. 一个简单MOS驱动电路引发的思考前两天在实验室调试电路时,遇到一个很有意思的案例。同事设计了一个使用NMOS管的驱动电路,用于控制LED的开关。乍看之下电路结构很简单,但实际调试时却发现MOS管无法正常导通。这个看似简单的问题背后&#…...

什么是GEO优化(生成式引擎优化)?一文讲透

# 什么是GEO优化(生成式引擎优化)?一文讲透GEO优化即生成式引擎优化,是面向豆包等AI大模型平台的新型营销优化方式,是AI时代企业抢占流量新入口的核心营销手段。沈阳锦恒智联信息科技有限公司是辽宁本地专业的GEO优化服…...

久鼎私域测流模式系统(现成方案)

久鼎私域测流模式系统是一套专注于私域流量监测与分析的解决方案,适用于企业精细化运营私域用户池。其核心功能包括流量来源追踪、用户行为分析、转化效果评估等,支持多平台数据整合。核心功能模块流量监测 实时监控私域流量入口(如小程序、公…...

信号处理学习笔记5:卡尔曼滤波理论

卡尔曼滤波,用直白的话来讲, 就是有多个不确定的结果,经过分析、推理和计算,获得相对准确的结果。 它的核心特点是: 能够预测数据的未来趋势\({x}_{k}^{ }\) 结合当前数据进行修正,使预测更加准确 可以处理…...

nRF54L15实现更快的处理速度

Nordic的nRF54L15系统级芯片相比前代nRF52系列,不仅速度更快、功耗更低,还配备了更丰富的外设,” 刘佳杭继续说道,“基于Arm Cortex-M33处理器的HJ-N54L_SIP不仅能处理更复杂的应用程序,同时显著提升了处理速度。系统级…...

微电网集中式架构vs分布式架构:设计差异与选型依据

微电网作为整合“源、储、荷、网”的新型能源系统,其架构设计直接决定系统的运行效率、可靠性、扩展性与经济性,是微电网规划建设的核心环节。在微电网主流架构中,集中式架构与分布式架构凭借各自的技术特性,适配不同的应用场景与…...