Topics

Publisher

class rclpy.publisher.Publisher(publisher_impl: rpyutils.import_c_library.Publisher, msg_type: MsgType, topic: str, qos_profile: rclpy.qos.QoSProfile, event_callbacks: PublisherEventCallbacks, callback_group: CallbackGroup)

Create a container for a ROS publisher.

Warning

Users should not create a publisher with this constructor, instead they should call Node.create_publisher().

A publisher is used as a primary means of communication in a ROS system by publishing messages on a ROS topic.

Parameters:
  • publisher_impl – Publisher wrapping the underlying rcl_publisher_t object.

  • msg_type – The type of ROS messages the publisher will publish.

  • topic – The name of the topic the publisher will publish to.

  • qos_profile – The quality of service profile to apply to the publisher.

assert_liveliness() None

Manually assert that this Publisher is alive.

If the QoS Liveliness policy is set to MANUAL_BY_TOPIC, the application must call this at least as often as QoSProfile.liveliness_lease_duration.

destroy()

Destroy a container for a ROS publisher.

Warning

Users should not destroy a publisher with this method, instead they should call Node.destroy_publisher().

get_subscription_count() int

Get the amount of subscribers that this publisher has.

property handle
publish(msg: MsgType | bytes) None

Send a message to the topic for the publisher.

Parameters:

msg – The ROS message to publish.

Raises:

TypeError if the type of the passed message isn’t an instance of the provided type when the publisher was constructed.

property topic_name: str
wait_for_all_acked(timeout: rclpy.duration.Duration = rclpy.duration.Duration) bool

Wait until all published message data is acknowledged or until the timeout elapses.

If the timeout is negative then this function will block indefinitely until all published message data is acknowledged. If the timeout is 0 then it will check if all published message has been acknowledged without waiting. If the timeout is greater than 0 then it will return after that period of time has elapsed or all published message data is acknowledged. This function only waits for acknowledgments if the publisher’s QOS profile is RELIABLE. Otherwise this function will immediately return true.

Parameters:

timeout – the duration to wait for all published message data to be acknowledged.

Returns:

true if all published message data is acknowledged before the timeout, otherwise false.

Subscription

class rclpy.subscription.Subscription(subscription_impl: rpyutils.import_c_library.Subscription, msg_type: MsgType, topic: str, callback: Callable, callback_group: CallbackGroup, qos_profile: rclpy.qos.QoSProfile, raw: bool, event_callbacks: SubscriptionEventCallbacks)

Create a container for a ROS subscription.

Warning

Users should not create a subscription with this constructor, instead they should call Node.create_subscription().

Parameters:
  • subscription_implSubscription wrapping the underlying rcl_subscription_t object.

  • msg_type – The type of ROS messages the subscription will subscribe to.

  • topic – The name of the topic the subscription will subscribe to.

  • callback – A user-defined callback function that is called when a message is received by the subscription.

  • callback_group – The callback group for the subscription. If None, then the nodes default callback group is used.

  • qos_profile – The quality of service profile to apply to the subscription.

  • raw – If True, then received messages will be stored in raw binary representation.

class CallbackType(value, names=<not given>, *values, module=None, qualname=None, type=None, start=1, boundary=None)
MessageOnly = 0
WithMessageInfo = 1
property callback
destroy()

Destroy a container for a ROS subscription.

Warning

Users should not destroy a subscription with this method, instead they should call Node.destroy_subscription().

get_publisher_count() int

Get the number of publishers that this subscription has.

property handle
property topic_name