常见的srv类型

srv类型相当于两个message通道,一个发送,一个接收

AddTwoInts.srv

#对两个整数求和,虚线前是输入量,后是返回量
#文件位置:自定义srv文件

int32 a
int32 b
——
int32 sum

Empty.srv

#文件位置:std_srvs/Empty.srv
#代表一个空的srv类型


GetMap.srv

#文件位置:nav_msgs/GetMap.srv
#获取地图,注意请求部分为空


nav_msgs/OccupancyGrid map
GetPlan.srv

#文件位置:nav_msgs/GetPlan.srv
#得到一条从当前位置到目标点的路径
geometry_msgs/PoseStamped start #起始点
geometry_msgs/PoseStamped goal #目标点
float32 tolerance #到达目标点的x,y方向的容错距离
——
nav_msgs/Path plan
SetBool.srv

#文件位置:std_srvs/SetBools.srv
bool data # 启动或者关闭硬件
——
bool success # 标示硬件是否成功运行
string message # 运行信息
SetCameraInfo.srv

#文件位置:sensor_msgs/SetCameraInfo.srv
#通过给定的CameraInfo相机信息,来对相机进行标定
sensor_msgs/CameraInfo camera_info #相机信息
——
bool success #如果调用成功,则返回true
string status_message #给出调用成功的细节
SetMap.srv

#文件位置:nav_msgs/SetMap.srv
#以初始位置为基准,设定新的地图
nav_msgs/OccupancyGrid map
geometry_msgs/PoseWithCovarianceStamped initial_pose
——
bool success
TalkerListener.srv

#文件位置: 自定义srv文件
——
bool success # 标示srv是否成功运行
string message # 信息,如错误信息等
Trigger.srv

#文件位置:std_srvs/Trigger.srv
——
bool success # 标示srv是否成功运行
string message # 信息,如错误信息等

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 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
发出的红包

打赏作者

N1CROWN

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值