【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. 运行:重启节点。
相关推荐
zzzzzz3107 天前
假如我是掘金管理员,我先给评论区装个'代码审查'系统
python·程序员·机器人
通信小呆呆8 天前
当算法有了“五感”:多模态数据融合如何向人体感官协同学习?
人工智能·学习·算法·机器学习·机器人
生成论实验室8 天前
机器人:一个自主运动的系统
人工智能·算法·语言模型·机器人·自动驾驶·agi·安全架构
Dick5078 天前
ROS2 常用命令表
人工智能·学习·算法·机器人
沫儿笙8 天前
川崎机器人二保焊节气设备
人工智能·机器人
C++ 老炮儿的技术栈8 天前
Qt工控实战:自研机器人TCP长连接客户端(粘包处理+心跳保活+自动重连完整源码解析)
qt·tcp/ip·机器人
Deepoch8 天前
VLA多模态架构加持 采摘机器人实现精细化智能采收
人工智能·机器人·开发板·具身模型·deepoc·采摘
选与握8 天前
$\pi_{0.7}$: 一个具备涌现能力的可引导的通用机器人基础模型
机器人·vla·pi07
梦想的旅途28 天前
企业微信外部群自动化:一期交付应聚焦双向会话闭环
java·开发语言·机器人·自动化·maven·企业微信