1. 创建工程
ros2_ws/ # 工作空间根目录
├── src/ # 源代码目录,放置 package 源码
│ ├── package_1/ # 第一个 ROS 2 包(可以是节点、库等)
│ │ ├── package.xml # 包描述文件
│ │ ├── CMakeLists.txt # 构建配置(C++ 或 Python)
│ │ └── ... # 节点源代码或 Python 模块等
│ └── package_2/ # 第二个 ROS 2 包
│ ├── package.xml
│ ├── CMakeLists.txt
│ └── ...
├── install/ # 编译安装输出(由 colcon build 生成)
├── build/ # 构建中间文件(由 colcon build 生成)
└── log/ # 构建和运行日志(由 colcon build 生成)
1.1. 创建ROS2包
# 在src目录下执行
ros2 pkg create --build-type ament_cmake my_package --dependencies rclcpp std_msgs
参数/选项 | 说明 | 示例 |
---|---|---|
--build-type |
指定包的构建类型,常用值有 ament_cmake 、ament_python 等 |
--build-type ament_cmake |
--dependencies |
指定该包依赖的 ROS 2 包,多个包用空格分隔 | --dependencies rclcpp std_msgs |
- 执行后示例:
- 执行后多出文件夹:
my_package/
├── CMakeLists.txt # 构建脚本(CMake)
├── package.xml # 包元信息(名称、版本、依赖等)
├── src/ # 源码目录(需手动创建或添加)
│ └── my_node.cpp # 你可以在这里写节点代码
├── include/my_package/ # 头文件目录(可选)
└── launch/ # 可选:存放 launch 文件
- 自动创建的package.xml
<?xml version="1.0"?>
<?xml-model href="http://download.ros.org/schema/package_format3.xsd" schematypens="http://www.w3.org/2001/XMLSchema"?>
<package format="3">
<name>my_package</name>
<version>0.0.0</version>
<description>TODO: Package description</description>
<maintainer email="nvidia@todo.todo">nvidia</maintainer>
<license>TODO: License declaration</license>
<buildtool_depend>ament_cmake</buildtool_depend>
<depend>rclcpp</depend>
<depend>std_msgs</depend>
<test_depend>ament_lint_auto</test_depend>
<test_depend>ament_lint_common</test_depend>
<export>
<build_type>ament_cmake</build_type>
</export>
</package>
- 自动创建的CMakeLists.txt
cmake_minimum_required(VERSION 3.8)
project(my_package)
if(CMAKE_COMPILER_IS_GNUCXX OR CMAKE_CXX_COMPILER_ID MATCHES "Clang")
add_compile_options(-Wall -Wextra -Wpedantic)
endif()
# find dependencies
find_package(ament_cmake REQUIRED)
find_package(rclcpp REQUIRED)
find_package(std_msgs REQUIRED)
if(BUILD_TESTING)
find_package(ament_lint_auto REQUIRED)
# the following line skips the linter which checks for copyrights
# comment the line when a copyright and license is added to all source files
set(ament_cmake_copyright_FOUND TRUE)
# the following line skips cpplint (only works in a git repo)
# comment the line when this package is in a git repo and when
# a copyright and license is added to all source files
set(ament_cmake_cpplint_FOUND TRUE)
ament_lint_auto_find_test_dependencies()
endif()
ament_package()
1.2. 编写节点
touch src/my_node.cpp
1.3. 编译
# 进入工作空间
cd ros2_ws
# 全部编译
colcon build
# 只编译选中的包
colcon build --packages-select my_robot_driver
# python开发的节点编译
# Python 包开发(修改脚本无需重编译)
colcon build --symlink-install
# 激活环境
source install/setup.bash
- 清理构建(相当于 make clean)
# colcon 没有 clean 命令,直接删除这三个目录即可。
rm -rf build/ install/ log/
1.4. 运行节点
# 激活环境
source install/setup.bash
ros2 run my_package my_node
2. launch文件组合节点
可以一次性启动一个或多个节点,而不需要每个节点单独 ros2 run
launch文件示例:
from launch import LaunchDescription
from launch_ros.actions import Node
def generate_launch_description():
return LaunchDescription([
Node(
namespace='ns', # 节点命名空间
package='my_package', # 节点所在的 ROS 2 包
executable='my_node', # 节点可执行文件名
name='node_name', # 节点名称(可选,默认使用可执行文件名)
output='screen', # 日志输出方式,可选 'screen' 或 'log'
parameters=[{'param_name': 'value'}], # 参数列表
remappings=[('/old/topic', '/new/topic')], # 话题重映射
arguments=['--arg1', 'value1'] # 命令行参数
),
# =====================
# 启动相机节点
# =====================
Node(
namespace='camera',
package='my_camera_pkg',
executable='camera_node',
output='screen',
parameters=[{
'device_id': 0, # 摄像头设备号
'frame_rate': 30, # 帧率
'image_width': 640,
'image_height': 480
}]
),
# =====================
# 启动激光雷达节点
# =====================
Node(
namespace='lidar',
package='my_lidar_pkg',
executable='lidar_node',
output='screen',
parameters=[{
'port': '/dev/ttyUSB1',
'baudrate': 115200,
'scan_rate': 10 # 扫描频率 Hz
}]
),
])
启动方式:
ros2 launch my_robot_launch cam_lidar.launch.py
3. ROS2调试工具
3.1. 查看节点信息
ros2 node info /node_name
3.2. 查看话题类型与消息
ros2 topic info /topic_name
ros2 topic type /topic_name
ros2 interface show sensor_msgs/Imu
4. 录包与播包
4.1. 录包命令
ros2 bag record [选项] [话题列表]
-a 或 --all: 录制所有当前活跃的话题
-o <目录名> 或 --output <目录名>
例如:
ros2 bag record /imu/data /camera/image_raw /lidar/points
- 停止录制:Ctrl+C
4.2. ROS2录包结构
my_bag/
├── metadata.yaml
├── db.sqlite3
└── index/
└── ...
文件/文件夹 | 作用 |
---|---|
metadata.yaml | 记录 bag 的元信息,包括话题、类型、频率、时长和序列化信息 |
db.sqlite3 | 核心数据库文件,存储所有消息数据 |
index/ | 可选索引文件夹,用于快速定位特定时间段消息 |
4.3. 播包命令
录包
ros2 bag play <bag_name>
查看信息:
ros2 bag info <bag_name>