了解了通信接口的概念,接下來我們再從代碼實(shí)現(xiàn)的角度,研究下如何定義以及使用一個接口。
在之前服務(wù)概念講解的課程中,我們編寫了這樣一個例程,我們再來回顧下。
有三個節(jié)點(diǎn):
第一個驅(qū)動相機(jī)發(fā)布圖像話題;
第二個是機(jī)器視覺識別節(jié)點(diǎn),封裝了一個服務(wù)的服務(wù)端對象,提供目標(biāo)識別位置的查詢服務(wù);
第三個節(jié)點(diǎn)在需要目標(biāo)位置的時候,就可以發(fā)送請求,收到位置進(jìn)行使用了。
接口定義
在這個例程中,我們使用GetObjectPosition.srv定義了服務(wù)通信的接口:
learning_interface/srv/GetObjectPosition.srv
bool get # 獲取目標(biāo)位置的指令---int32 x # 目標(biāo)的X坐標(biāo)int32 y # 目標(biāo)的Y坐標(biāo)
定義中有兩個部分,上邊是獲取目標(biāo)位置的指令,get為true的話,就表示我們需要一次位置,服務(wù)端就會反饋這個x、y坐標(biāo)了。
完成定義后,還需要在功能包的CMakeLists.txt中配置編譯選項(xiàng),讓編譯器在編譯過程中,根據(jù)接口定義,自動生成不同語言的代碼:
...find_package(rosidl_default_generators REQUIRED)rosidl_generate_interfaces(${PROJECT_NAME} "srv/GetObjectPosition.srv")...
功能包的package.xml文件中也需要添加代碼生成的功能依賴:
... < build_depend >rosidl_default_generators< /build_depend > < exec_depend >rosidl_default_runtime< /exec_depend > < member_of_group >rosidl_interface_packages< /member_of_group > ...
程序調(diào)用
我們在代碼中再來重點(diǎn)看下接口的使用方法。
客戶端接口調(diào)用
learning_service/service_object_client.py
#!/usr/bin/env python3# -*- coding: utf-8 -*-"""@作者: 古月居@說明: ROS2服務(wù)示例-請求目標(biāo)識別,等待目標(biāo)位置應(yīng)答"""import rclpy # ROS2 Python接口庫from rclpy.node import Node # ROS2 節(jié)點(diǎn)類from learning_interface.srv import GetObjectPosition # 自定義的服務(wù)接口class objectClient(Node): def __init__(self, name): super().__init__(name) # ROS2節(jié)點(diǎn)父類初始化 self.client = self.create_client(GetObjectPosition, 'get_target_position') while not self.client.wait_for_service(timeout_sec=1.0): self.get_logger().info('service not available, waiting again...') self.request = GetObjectPosition.Request() def send_request(self): self.request.get = True self.future = self.client.call_async(self.request)def main(args=None): rclpy.init(args=args) # ROS2 Python接口初始化 node = objectClient("service_object_client") # 創(chuàng)建ROS2節(jié)點(diǎn)對象并進(jìn)行初始化 node.send_request() while rclpy.ok(): rclpy.spin_once(node) if node.future.done(): try: response = node.future.result() except Exception as e: node.get_logger().info( 'Service call failed %r' % (e,)) else: node.get_logger().info( 'Result of object position:n x: %d y: %d' % (response.x, response.y)) break node.destroy_node() # 銷毀節(jié)點(diǎn)對象 rclpy.shutdown() # 關(guān)閉ROS2 Python接口
服務(wù)端接口調(diào)用
learning_service/service_object_server.py
#!/usr/bin/env python3# -*- coding: utf-8 -*-"""@作者: 古月居(www.guyuehome.
-
通信接口
+關(guān)注
關(guān)注
3文章
234瀏覽量
30954 -
服務(wù)端
+關(guān)注
關(guān)注
0文章
66瀏覽量
6978 -
ROS
+關(guān)注
關(guān)注
1文章
276瀏覽量
16942
發(fā)布評論請先 登錄
相關(guān)推薦
評論