[π€ ROS2?] /user_input
#
Caution
This documentation page has been auto-generated.
It may be missing some details.
/user_input
Quick Facts
- Category
- Message type
- Direction
β‘οΈ you normally subscribe to this topic.
Quick snippets#
$ ros2 topic hz /user_input
$ ros2 topic echo /user_input
How to use in your code#
1#!/usr/bin/env python
2
3import rclpy
4from rclpy.node import Node
5
6from pal_interaction_msgs.msg import Input
7
8
9class UserInputSubscriber(Node):
10
11 def __init__(self):
12 super().__init__('user_input_subscriber')
13 self.subscription = self.create_subscription(
14 Input,
15 '/user_input',
16 self.listener_callback,
17 10)
18
19 def listener_callback(self, msg):
20 # see https://github.com/pal-robotics/pal_msgs/tree/indigo-devel/pal_interaction_msgs/msg/Input.msg
21 # for the msg structure
22 self.get_logger().info('I heard: "%s"' % msg.data)
23
24
25if __name__ == '__main__':
26 rclpy.init(args=args)
27
28 subscriber = UserInputSubscriber()
29
30 rclpy.spin(subscriber)
31
32 rclpy.shutdown()
1#include <memory>
2
3#include "rclcpp/rclcpp.hpp"
4#include "pal_interaction_msgs/msg/input.hpp"
5
6using std::placeholders::_1;
7using namespace rclcpp;
8
9class UserInputSubscriber : public rclcpp::Node
10{
11public:
12 UserInputSubscriber()
13 : Node("user_input_subscriber")
14 {
15 subscription_ = this->create_subscription<pal_interaction_msgs::msg::Input>(
16 "/user_input",
17 10,
18 std::bind(&UserInputSubscriber::topic_callback, this, _1));
19 }
20
21private:
22 void topic_callback(const pal_interaction_msgs::msg::Input::SharedPtr msg) const
23 {
24 // see https://github.com/pal-robotics/pal_msgs/tree/indigo-devel/pal_interaction_msgs/msg/Input.msg
25 // for the msg structure
26 RCLCPP_INFO_STREAM(this->get_logger(), "Got " << msg->data);
27 }
28
29 Subscription<pal_interaction_msgs::msg::Input>::SharedPtr subscription_;
30};
31
32int main(int argc, char * argv[])
33{
34init(argc, argv);
35spin(std::make_shared<UserInputSubscriber>());
36shutdown();
37return 0;
38}
You can also access this topic from a webpage displayed on the robotβs touchscreen via this endpoint:
http://<robot>-0c/topic/user_input
(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.