【ROS2】含自定义消息的ROS2节点开发流程

ROS 2 自定义消息(.msg)开发核心原则:接口编译必须先于节点编译

工程规范要求严格分离消息包与功能包。以下为标准开发与迭代流程。


一、 初次创建与运行全流程

Step 1: 创建工作空间与独立包

消息包必须基于 CMake 构建,不受逻辑节点语言限制。

bash 复制代码
mkdir -p ~/dev_ws/src && cd ~/dev_ws/src

# 创建消息包 (必须为 ament_cmake)
ros2 pkg create --build-type ament_cmake custom_msgs

# 创建功能节点包 (以 Python 为例)
ros2 pkg create --build-type ament_python robot_node --dependencies rclpy custom_msgs

Step 2: 定义消息接口

bash 复制代码
cd custom_msgs && mkdir msg
cat <<EOF > msg/RobotStatus.msg
int32 robot_id
string status_text
float64 battery_level
EOF

Step 3: 配置构建依赖

修改 custom_msgs/CMakeLists.txt,追加:

cmake 复制代码
find_package(rosidl_default_generators REQUIRED)

rosidl_generate_interfaces(${PROJECT_NAME}
  "msg/RobotStatus.msg"
)

修改 custom_msgs/package.xml,追加:

xml 复制代码
<buildtool_depend>rosidl_default_generators</buildtool_depend>
<exec_depend>rosidl_default_runtime</exec_depend>
<member_of_group>rosidl_interface_packages</member_of_group>

Step 4: 优先编译消息包(强制前置)

未完成此步将导致逻辑节点报模块缺失错误。

bash 复制代码
cd ~/dev_ws
colcon build --packages-select custom_msgs
source install/setup.bash

Step 5: 编写节点代码

文件:robot_node/robot_node/status_publisher.py

python 复制代码
import rclpy
from rclpy.node import Node
from custom_msgs.msg import RobotStatus 

class StatusPub(Node):
    def __init__(self):
        super().__init__('status_pub_node')
        self.pub = self.create_publisher(RobotStatus, 'robot_status', 10)
        self.timer = self.create_timer(1.0, self.timer_cb)

    def timer_cb(self):
        msg = RobotStatus(robot_id=1, status_text="Nominal", battery_level=98.5)
        self.pub.publish(msg)

def main(args=None):
    rclpy.init(args=args)
    rclpy.spin(StatusPub())
    rclpy.shutdown()

if __name__ == '__main__':
    main()

(注:需在 setup.pyentry_points 中完成节点注册)

Step 6: 编译并运行

bash 复制代码
cd ~/dev_ws
colcon build --packages-select robot_node
source install/setup.bash
ros2 run robot_node status_publisher

二、 后续开发迭代循环

根据修改内容,迭代分为两条固定路径。

场景 A:仅修改逻辑代码

未更改 .msg 文件。

  1. 修改代码 :编辑 .py.cpp
  2. 编译生效
  • C++ :执行 colcon build --packages-select robot_node
  • Python :若初次构建包含 --symlink-install 参数,无需重新编译,保存代码即可。
  1. 运行:重启节点。
场景 B:修改自定义消息结构

更改 .msg 字段(如增删变量),必须严格按以下顺序执行:

  1. 修改定义 :更新 .msg 文件。
  2. 重编消息包colcon build --packages-select custom_msgs
  3. 刷新环境(关键)source install/setup.bash,确保终端加载最新接口结构。
  4. 修改代码:在节点代码中适配新字段。
  5. 重编节点包colcon build --packages-select robot_node(C++ 节点必须重新链接)。
  6. 运行:重启节点。
相关推荐
xwz小王子3 小时前
手术机器人登上Science Robotics:2毫米纤细手臂,从3厘米切口完成腰椎神经减压
算法·机器人
小陶来咯3 小时前
机器人执行动作之前的安全检查模块Check
机器人
五羟基己醛5 小时前
【Robotics】半小时入门具身智能之Win11下IsaacSim环境搭建
机器人·robot·具身智能·isaacsim
视***间5 小时前
算力筑基,智领人形机器人新时代 —— 英伟达 × 宇树科技携手推进具身智能,视程空间基于 NVIDIA 全栈算力产品助力机器人产业落地
人工智能·机器人·nvidia·机器狗·gpt-oss·视程空间·宇树机器人
某林2129 小时前
ROS2 机器人底盘调试避坑指南:从 `/odom` 丢失到彻底跑通的硬核排障实录
stm32·机器人·人机交互
才兄说10 小时前
机器人二次开发机器狗巡检?低电量自主回充
机器人
啵啵鱼爱吃小猫咪10 小时前
示教学习强化学习用的标准数据集
机器人·强化学习·示教学习
小烤箱11 小时前
ROS2 学习资源与学习方法
学习·ros·学习方法·ros2
硅谷秋水12 小时前
Qwen-VLA:跨任务、环境与机器人形态的视觉-语言-动作统一建模
人工智能·深度学习·算法·计算机视觉·语言模型·机器人
叶子Talk14 小时前
COMPTUEX炸场:OpenAI杀入机器人,英特尔288核CPU首秀
机器人