[ROS2 π€] /play_motion_builder_node/list_joint_groups
#
Caution
This documentation page has been auto-generated.
It may be missing some details.
/play_motion_builder_node/list_joint_groups
Quick Facts
- Category
- Message type
play_motion_builder_msgs/srv/ListJointGroups
Quick snippets#
$ ros2 service call /play_motion_builder_node/list_joint_groups play_motion_builder_msgs/srv/ListJointGroups
# (tip: press Tab to complete the message prototype)
How to use in your code#
1#!/usr/bin/env python
2
3import sys
4import rclpy
5from rclpy.node import Node
6
7from play_motion_builder_msgs.srv import ListJointGroups
8
9class ListJointGroupsClientAsync(Node):
10
11 def __init__(self):
12 super().__init__('play_motion_builder_node_list_joint_groups_client_async')
13 self.cli = self.create_client(ListJointGroups, 'play_motion_builder_node_list_joint_groups')
14 while not self.cli.wait_for_service(timeout_sec=1.0):
15 self.get_logger().info('service not available, waiting again...')
16 self.req = ListJointGroups.Request()
17
18 def send_request(self, a, b):
19 # TODO: adapt to the service's parameters
20 # self.req.a = a
21 # self.req.b = b
22 self.future = self.cli.call_async(self.req)
23 rclpy.spin_until_future_complete(self, self.future)
24 return self.future.result()
25
26
27if __name__ == '__main__':
28 rclpy.init(args=args)
29
30 srv_client = ListJointGroupsClientAsync()
31
32 # TODO: adapt to your parameters
33 response = srv_client.send_request(sys.argv[1], sys.argv[2])
34 srv_client.get_logger().info(
35 'Result of play_motion_builder_node_list_joint_groups: %s' % response)
36
37 rclpy.shutdown()
1#include "rclcpp/rclcpp.hpp"
2#include "play_motion_builder_msgs/srv/list_joint_groups.hpp"
3
4#include <chrono>
5#include <cstdlib>
6#include <memory>
7
8using namespace std::chrono_literals;
9using namespace std;
10using namespace rclcpp;
11
12int main(int argc, char **argv)
13{
14 init(argc, argv);
15
16 shared_ptr<Node> node = Node::make_shared("play_motion_builder_node/list_joint_groups_client");
17 Client<play_motion_builder_msgs::srv::ListJointGroups>::SharedPtr client =
18 node->create_client<play_motion_builder_msgs::srv::ListJointGroups>("play_motion_builder_node/list_joint_groups");
19
20 auto request = make_shared<play_motion_builder_msgs::srv::ListJointGroups::Request>();
21
22 // TODO: adapt to the service's parameters
23 // request->a = ...;
24 // request->b = ...;
25
26 while (!client->wait_for_service(1s)) {
27 if (!ok()) {
28 RCLCPP_ERROR(get_logger("rclcpp"), "Interrupted while waiting for the service. Exiting.");
29 return 0;
30 }
31 RCLCPP_INFO(get_logger("rclcpp"), "service not available, waiting again...");
32 }
33
34 auto result = client->async_send_request(request);
35 // Wait for the result.
36 if (spin_until_future_complete(node, result) == FutureReturnCode::SUCCESS)
37 {
38 // TODO: do something with the result
39 // result.get()->...;
40 } else {
41 RCLCPP_ERROR(get_logger("rclcpp"), "Failed to call service play_motion_builder_node/list_joint_groups");
42 }
43
44 shutdown();
45 return 0;
46}
You can also access this service from a webpage displayed on the robotβs touchscreen via this endpoint:
http://<robot>-0c/service/list_joint_groups
(replace <robot>-0c
by the serial number of your own robot).
See js-api for the general documentation of the REST endpoints and code samples.