ROS实操入门系列(八)ROS service通讯之自定义复杂srv消息类型解决实际需求(详解)


srv消息 是ROS service通讯节点间传递的内容。srv消息描述的是业务间传递数据,也可以理解为业务间数据的抽象化。

rossrv 命令

  1. 查看提供的service消息类型
    rossrv list  
    
  2. 查看某个类型的请求和响应
    rossrv show 具体的消息类型
    
    ---分隔了request和response
    
    在这里插入图片描述

需求

  1. 已知需要提供一套服务功能,此服务提供Team查询服务。要求是,提供一个Student数据,返回得到Team,实现这套服务,并且实现客户端调试调用。此处的需求没有实际的数据含义,我们只是为了演示复杂数据类型在ros的service通讯中如何传递使用。
  2. 根据分析,我们需要有一个ServiceClient节点和ServiceServer节点。ServiceClient节点传递请求数据(例如:学生信息Student)。ServiceServer节点处理请求数据,并且将Team结果返回。这里的Student数据正好和我们前面章节创建的/Student是一致的。这里的Team数据正好和我们前面章节创建到的Team是一致的。在此处,我们需要做的就是,定义一套数据传输规范来协调client和server的消息格式。

自定义消息

  1. 在Ros中,如果没有现成的消息类型来描述要去传递的消息时,我们会自定义消息。通常我们会新建一个Package来去自定义消息,这个Package一般不去写任何的业务逻辑,只是用来声明自定义的消息类型,可以只定义一种消息类型,也可以定义多种消息类型,根据业务需求来定。所以,我们会单独的创建一个package,用来定义消息.

  2. 创建package
    包名取名也是有讲究的,业务名_srvs。大家可以看看std_srvs,都是遵循这个规则。

  3. 创建srv目录
    在package包下新建srv文件夹

  4. 创建srv文件
    在srv文件夹下创建.srv文件. srv文件就是自定义消息文件,用来描述消息格式的。例如案例中, 我们会去创建FindTeam.srv文件, 内容如下:在这里插入图片描述

  5. 配置package.xml

    <build_depend>message_generation</build_depend>
    <exec_depend>message_runtime</exec_depend>
    
  6. 配置CMakeLists.txt

    find_package(catkin REQUIRED COMPONENTS
      roscpp
      rosmsg
      rospy
      message_generation
      geometry_msgs
    )
    
    add_service_files(
       FILES
       FindTeam.srv
     )
     这里的FindTeam.srv要和你创建的srv文件名称一致,且必须时在srv目录下,否则编译会出现问题
    
    generate_messages(
       DEPENDENCIES
       std_msgs  # Or other packages containing msgs
       geometry_msgs
     )
     这个配置的作用是添加生成消息的依赖,默认的时候要添加std_msgs
    
    catkin_package(
    #  INCLUDE_DIRS include
    #  LIBRARIES demo_msg
       CATKIN_DEPENDS roscpp rosmsg rospy message_runtime
    #  DEPENDS system_lib
    )
    为catkin编译提供了依赖 message_runtime
    
  7. 编译项目(如果遇到编译失败问题,请参考上一章的解决办法)

    cd 工作空间
    catkin_make
    
  8. 命令校验

    rossrv show team_srvs/FindTeam
    

    在这里插入图片描述

编写代码

  1. 编写server端在这里插入图片描述

  2. 编写client端在这里插入图片描述

  3. 运行两个文件在这里插入图片描述

https://www.lanqiao.cn/courses/2947,提供准备好的云主机ros环境,进行实操,课程包括了 Topic 通讯, Service 通讯,ROS 自定义消息,URDF可视化,TF坐标转换等技术要点。每个技术点都会结合例子先把原理讲解清楚,为了达到学以致用的目的,我们会再进行知识拓展,针对每个技术点实现对应的生动有趣的需求,保证学完后会有很大的收获。

  • 3
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ROS中,可以使用自定义srv类型定义ROS服务的请求和响应。本教程将向您展示如何创建和使用自定义srv类型。 1. 创建srv文件 首先,您需要创建一个新的srv文件。srv文件定义了服务的请求和响应数据结构。在终端中输入以下命令创建一个新的srv文件: ``` $ cd ~/catkin_ws/src $ mkdir my_srv_pkg $ cd my_srv_pkg $ mkdir srv $ touch srv/MyCustomService.srv ``` 然后,打开MyCustomService.srv文件,并添加以下内容: ``` int64 A int64 B --- int64 C ``` 这个srv文件定义了一个服务请求和响应。请求包含两个int64类型的参数A和B,响应包含一个int64类型的参数C。 2. 编译srv文件 要使用自定义srv类型,需要将其编译为ROS包。在终端中输入以下命令编译srv文件: ``` $ cd ~/catkin_ws $ catkin_make ``` 3. 创建服务节点 要使用自定义srv类型,需要创建一个服务节点。在终端中输入以下命令创建一个新的服务节点: ``` $ cd ~/catkin_ws/src/my_srv_pkg $ mkdir src $ touch src/my_service_node.cpp ``` 然后,在my_service_node.cpp文件中添加以下内容: ```cpp #include "ros/ros.h" #include "my_srv_pkg/MyCustomService.h" bool my_service_callback(my_srv_pkg::MyCustomService::Request &req, my_srv_pkg::MyCustomService::Response &res) { res.C = req.A + req.B; ROS_INFO("Request: A=%ld, B=%ld", (long int)req.A, (long int)req.B); ROS_INFO("Sending back response: %ld", (long int)res.C); return true; } int main(int argc, char **argv) { ros::init(argc, argv, "my_service_node"); ros::NodeHandle nh; ros::ServiceServer service = nh.advertiseService("my_custom_service", my_service_callback); ROS_INFO("Ready to receive service requests."); ros::spin(); return 0; } ``` 这个服务节点将会创建一个名为“my_custom_service”的服务,使用my_service_callback()函数作为回调函数来响应服务请求。my_service_callback()函数将会从请求中获取参数A和B,并将它们相加后将结果存储在响应参数C中,并打印出来。最后,服务节点将等待服务请求并响应它们。 4. 测试服务 要测试自定义srv类型,您可以使用rospy进行测试。在终端中输入以下命令测试服务: ``` $ roscore $ rosrun my_srv_pkg my_service_node ``` 在另一个终端中输入以下命令来发送服务请求: ``` $ rosservice call /my_custom_service "A: 5 B: 10" ``` 您应该会看到类似以下的输出: ``` Request: A=5, B=10 Sending back response: 15 ``` 这表明服务节点已经正确响应了服务请求,并将结果返回给了请求者。 这就是本教程的全部内容。现在您已经知道如何创建和使用自定义srv类型定义ROS服务。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值