# bagtrans 工具 ## 简介 **bagtrans** 是一个 AimRT 官方提供的命令行工具,用于将 AimRT 的 bag 文件转换为 ROS2 的 bag 文件,其中ros2 原生消息会直接转换,pb 消息会转换为 aimrt 提供的 ros2_plugin_proto 中的 RosMsgWrapper 消息类型。 ## 安装 **bagtrans** 工具是一个基于 Python 开发的小程序,并且依赖于 aimrt 提供的 ros2_plugin_protobuf 消息类型,通过以下步骤安装: 1. 编译 aimrt 生成 ros2_plugin_proto 执行您 aimrt 源码库中的`build.sh`文件进行编译,可以在`build.sh`文件中关闭其他您不需要的 CMake 选项以加快编译,但是需要确保`AIMRT_BUILD_ROS2_PLUGIN` 和 `AIMRT_BUILD_RECORD_PLAYBACK_PLUGIN` 选项为`ON`。 2. 在终端中执行以下命令: ``` cd /src/tools/bagtrans python setup.py install ``` **bagtrans**工具将会自动安装到您的 python 环境中。使用 `pip list | grep bagtrans`可查看是否安装成功。可使用 `pip uninstall bagtrans`进行卸载。 ## 使用说明 **bagtrans** 工具的使用方法如下: 每次使用前,需要使用命令 `source /src/tools/bagtrans/build/share/ros2_plugin_proto/local_setup.bash` 以修改环境变量。 transbag 命令的使用方法如下: ```bash bagtrans trans -h, --help 会显示参数说明: options: -h, --help show this help message and exit -s SRC_DIR, --src_dir SRC_DIR aimrtbag source directory. -o OUTPUT_DIR, --output_dir OUTPUT_DIR directory you want to output your files. ``` 其中 `-s` 参数为必填参数,表示 aimrtbag 的源目录,`-o` 参数为必填参数,表示转换后的bag的输出目录,如果输出目录不存在,则会自动创建;如果输出目录存在,则会覆盖。