【从0开始自动驾驶】ros2编写自定义消息 msg文件和msg文件嵌套

在工作空间内新建一个功能包

ros2 pkg create --build-type ament_cmake test_msg

可以看见创建了一个名为test_msg的功能包
cd到功能包内,创建msg文件夹

cd test_msg
mkdir msg

在msg内创建对应的msg文件

需要注意的是:

  • ROS2中的msg文件应大写字母开头
  • msg文件中的header,在ros2中需写成std_msgs/Header
  • msg文件名不支持下划线
  • msg文件中的变量定义不支持大写字母
  • msg文件名首字母应大写 msg文件中不应有=的赋值操作

创建名为TestMsg.msg的文件

- 此次创建的msg文件存在自定义msg的引用,即文件中的TestSubMsg

int64 x
TestSubMsg test_sub

创建名为TestSubMsg.msg的文件(在前一个msg文件中引用)

float32 test

在这里插入图片描述

修改CmakeList.txt

添加如下内容
注意!

  • 若msg文件内使用了自定义的msg格式,则编译时应先加入自定义msg格式
find_package(ament_cmake REQUIRED)
find_package(rosidl_default_generators REQUIRED)

rosidl_generate_interfaces(${PROJECT_NAME}
  "msg/TestSubMsg.msg"
  "msg/TestMsg.msg"
 )

在这里插入图片描述

修改package.xml文件

添加如下内容

<build_depend>rosidl_default_generators</build_depend>
<exec_depend>rosidl_default_runtime</exec_depend>
<member_of_group>rosidl_interface_packages</member_of_group>

编译

注意!!!
一定要停用conda环境

conda deactivate
conda deactivate
conda deactivate

直接编译整个包

colcon build

在这里插入图片描述

在这里插入图片描述

ROS 2中,如果要录制自定义消息类型(message),首先你需要确保自定义消息已经被正确地定义并且已经在Node上发布。以下是录制自定义msg类型的步骤: 1. **创建自定义消息**: - 使用ROS msg工具(如`rosmsg`, `rosidl_generator_cpp`等)生成对应的消息文件。例如,假设你有一个名为`MyCustomMsg`的自定义消息,你可以通过以下命令生成: ```shell ros2 interface add my_custom_msg MyCustomMsg.xml ``` 这会创建一个`.msg`文件和对应的`.srv`文件(如果有服务的话)。 2. **将消息包含到node中**: - 在你的节点代码中,使用`import`语句引入刚刚生成的消息定义。 3. **开始录制**: - 使用`ros2 bag record`命令,指定要记录的主题名(topic)以及包含自定义msg的节点,加上自定义msg的type作为参数: ```shell ros2 bag record --duration=60 /my_topic --topics '/my_topic' --clock your_node_name ``` `your_node_name`应替换为你的节点名称。`--duration`参数设置录制的时间长度,`--clock`选项确保时间戳的一致性。 4. **确认消息类型已被识别**: 在运行前,确保你的节点已经注册了自定义消息类型,并且在`ros2 topic list`中能看到`/my_topic`主题显示为`YourMessageType`。 5. **结束录制并验证**: 录制结束后,你可以通过`ros2 bag info`检查是否成功记录了自定义消息。 注意,自定义消息必须先在ROS 2的命名空间(namespace)中注册才能被其他节点接收。如果还没有注册,需要在相应的节点启动时使用`ros2 topic pub`命令发布几条消息以便初始化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值