服务通信自定义srv

服务通信自定义srv

需求分析

在服务通信中,客户端提交两个消息到服务端,服务端求和后反馈给客户端,创建你客户端和服务端。

流程

  1. 按固定格式创建srv文件
  2. 编辑配置文件
  3. 编译生成之间文件
定义srv文件

srv = 请求部分 + 响应部分
srv 建立的步骤

  1. 打开终端,mkdir -p demo04_ws/src
  2. cd demo04_ws
  3. catkin_make
  4. code . 打开VScode
  5. 编辑配置文件 shift+Ctrl + B 修改group行,“group”: {“kind”:“build”,“isDefault”:true}
  6. 创建工作空间
  7. 工作空间下新建文件夹srv,在文件夹下面新建自定义消息文件AddInts.srv
  8. 在addints文件下自定义服务与请求的数据,格式如下:
    在这里插入图片描述
  9. 编辑配置文件 ,第一个是package.xml,另外一个是CMakeLists.txt
package.xml:

在这里插入图片描述
消息的生成依赖和消息的运行依赖

CMakeLists.txt:
  1. find_package()添加服务构建依赖:
    message_generation
  2. 58行与srv相关的文件:
    放开注释,添加addints.srv文件
  3. 71行消息构建依赖,放开注释,添加std_msgs(服务通信的构建依赖于std_msgs)
  4. catki_package() 添加messega.runtime
    注意:find_packge是当前创建的功能包所依赖的包
    catkin_packge 是创建的功能包依赖的包所依赖的包
    配置完成之后编译,自动生成中间文件。
    中间文件:
    devel -> include ->创建的功能包包含C++所依赖的中间文件
    devel -> lib ->python3下包含python依赖的中间文件
    到目前为止,服务通信的中间文件生成完毕。

最后一步需要将中间文件的路径包含到配置文件中,具体的操作为:

  1. 选中include ,在终端中打开。
  2. 通过命令pwd 打印出终端的路径。
  3. 将路径添加到配置文件c_cpp_propertise.json
  4. 完成配置。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值