Action消息规范
消息规范¶
client端和server端进行通讯的规范,是依靠数据特定格式进行定义的。
client端和server端间可以不去区分编程语言,按照规范即可进行通讯,与语言无关。
我们通常用.action
文件来去定义一个传输规范,这个定义出来的规范就是action消息。
action消息包三个部分:
- Goal: client请求的消息规范
- Result:server端响应的结果规范
- Feedback:server端响应的进度反馈规范
对于每一个阶段的消息规范,都是遵循Msg消息定义的格式的。
自定义Action消息¶
Action的消息规范主要是为了描述Client端
和Server端
交互的数据格式,具体来说,就是为了去描述Goal
,Feedback
,Result
的数据格式。
通常我们会新建一个package来管理并且定义Action的消息格式。以当前案例为例,我们会去新建好一个叫做demo_action_msgs
的package,新建过程中,我们添加必要的依赖roscpp
,rospy
,rosmsg
, actionlib_msgs
。然后删除不必要的文件夹src
,include
。
Tip
需要特别注意的是,我们在此处要添加一个额外的依赖actionlib_msgs
,这个依赖是为我们添加action消息必要的依赖
1. 新建action消息描述文件¶
在package下创建名称为action
的文件夹,接着在Action
文件夹中创建CountNumber.action
文件,内容如下:
1 2 3 4 5 6 |
|
Tip
action消息描述文件,必须放到action
目录下,后缀必须是.action
,这个是编码规范。
action文件中,被---
分隔为三个部分。
第一个部分:描述的是Goal
第二个部分:描述的是Result
第三个部分:描述的是Feedback
2. 配置package.xml文件¶
在package.xml
文件中添加运行时消息生成
1 2 |
|
3.配置CMakeLists.txt文件¶
find_package配置¶
配置find_package
,添加message_generation
,效果如下:
1 2 3 4 5 6 7 |
|
generation_message配置¶
配置generation_message
,添加actionlib_msgs
,效果如下:
1 2 3 4 5 |
|
catkin_package配置¶
配置catkin_package
,添加依赖,结果如下:
1 2 3 4 5 6 |
|
add_action_files配置¶
配置add_action_files
,添加action文件,效果如下:
1 2 3 4 |
|
4. 编译action消息¶
来到workspace下面,进行代码编译
1 |
|
Tip
编译完成后,会在devel/include/demo_action_msgs
目录下产出多个头文件。格式如下:
action文件名Action.h
,action文件名Goal.h
,action文件名Result.h
,action文件名Feedback.h
,action文件名ActionGoal.h
,action文件名ActionResult.h
,action文件名ActionFeedback.h