【古月居《ros入门21讲》学习笔记】11_客户端Client的编程实现

目录

说明:

1. 服务模型

2. 实现过程(C++)

创建功能包

创建客户端代码(C++)

配置客户端代码编译规则

编译

运行

3. 实现过程(Python)

创建客户端代码(Python)

运行效果


说明:

1. 本系列学习笔记基于B站:古月居《ROS入门21讲》课程,且使用的Ubuntu与ROS系统版本与课程完全一致;

虚拟机版本Linux系统版本ROS系统版本
VMware WorkStation Pro 16Ubuntu18.04Melodic

2. 课程中的所有示例代码均已跑通,且对Pyhon版本的代码也都做了运行验证,并附带验证过程(错误均已修正);

3. 本节是整个笔记的第11节,对应视频课程的第13节,请自行对应学习;

4. 整个系列笔记基本已经完结,但部分章节仍需润色修改 ,后面会陆续发布,请大家持续关注,      创作不易,感谢支持!


1. 服务模型

image-20230529145216517

2. 实现过程(C++)

创建功能包

cd ~/catkin_ws/src
​
catkin_create_pkg learning_service roscpp rospy std_msgs geometry_msgs turtlesim

image-20230529144939926

创建客户端代码(C++)

cd ~/catkin_ws/src/learning_service/src
​
touch turtle_spawn.cpp

  • 初始化ros节点;

  • 创建一个Client实例;

  • 发布服务请求数据;

  • 等待Server处理之后的应答结果,

/**
 * 该例程将请求/spawn服务,服务数据类型turtlesim::Spawn
 */
​
#include <ros/ros.h>
#include <turtlesim/Spawn.h>
​
int main(int argc, char** argv)
{
    // 初始化ROS节点
    ros::init(argc, argv, "turtle_spawn");
​
    // 创建节点句柄
    ros::NodeHandle node;
​
    // 发现/spawn服务后,创建一个服务客户端,连接名为/spawn的service
    ros::service::waitForService("/spawn");
    ros::ServiceClient add_turtle = node.serviceClient<turtlesim::Spawn>("/spawn");
​
    // 初始化turtlesim::Spawn的请求数据
    turtlesim::Spawn srv;
    srv.request.x = 2.0;
    srv.request.y = 2.0;
    srv.request.name = "turtle2";
​
    // 请求服务调用
    ROS_INFO("Call service to spwan turtle[x:%0.6f, y:%0.6f, name:%s]", 
             srv.request.x, srv.request.y, srv.request.name.c_str());
​
    add_turtle.call(srv);
​
    // 显示服务调用结果
    ROS_INFO("Spwan turtle successfully [name:%s]", srv.response.name.c_str());
​
    return 0;
};

image-20230529151718201

配置客户端代码编译规则

add_executable(turtle_spawn src/turtle_spawn.cpp)
target_link_libraries(turtle_spawn ${catkin_LIBRARIES})

image-20230529154351364

编译

cd ~/catkin_ws
​
catkin_make
​
source devel/setup.bash(如已配置 **.bashrc**文件,则此步不需要,配置方法在publisher的章节里)

image-20230529154742330

编译完成后生成的可执行文件及其位置路径如下图

image-20230529154943112

运行

roscore
​
rosrun turtlesim turtlesim_node
​
rosrun learning_service turtle_spawn

运行结果如下图

image-20230529160231261

3. 实现过程(Python)

创建客户端代码(Python)

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# 该例程将请求/spawn服务,服务数据类型turtlesim::Spawn
​
import sys
import rospy
from turtlesim.srv import Spawn
​
def turtle_spawn():
    # ROS节点初始化
    rospy.init_node('turtle_spawn')
​
    # 发现/spawn服务后,创建一个服务客户端,连接名为/spawn的service
    rospy.wait_for_service('/spawn')
    try:
        add_turtle = rospy.ServiceProxy('/spawn', Spawn)
​
        # 请求服务调用,输入请求数据
        response = add_turtle(2.0, 2.0, 0.0, "turtle2")
        return response.name
    except rospy.ServiceException, e:
        print "Service call failed: %s"%e
​
if __name__ == "__main__":
    #服务调用并显示调用结果
    print "Spwan turtle successfully [name:%s]" %(turtle_spawn())
​

cd ~/catkin_ws/src/learning_service
mkdir scripts
cd scripts
touch turtle_spawn.py

image-20230529163842143

给turtle_spawn.py文件赋作为可执行文件权限

image-20230529163711742

运行效果

image-20230529164243087

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

日有所得

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

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

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

打赏作者

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

抵扣说明:

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

余额充值