FKIE Message Filters
Improved filters for processing ROS messages
|
Publish consumed data on a ROS topic. More...
#include <fkie_message_filters/publisher.h>
Public Types | |
using | Input = IO< Inputs... > |
Grouped input types. More... | |
Public Member Functions | |
Publisher () noexcept | |
Constructs an empty publisher. More... | |
Publisher (ros::NodeHandle &nh, const std::string &topic, uint32_t queue_size, bool latch=false, ros::CallbackQueueInterface *callback_queue=nullptr) noexcept | |
Constructor that advertises the given ROS topic. More... | |
void | advertise (ros::NodeHandle &nh, const std::string &topic, uint32_t queue_size, bool latch=false, ros::CallbackQueueInterface *callback_queue=nullptr) noexcept |
Advertise ROS topic. More... | |
void | advertise (ros::NodeHandle &nh, const std::string &topic, uint32_t queue_size, const ros::SubscriberStatusCallback &connect_cb, const ros::SubscriberStatusCallback &disconnect_cb=ros::SubscriberStatusCallback(), const ros::VoidConstPtr &tracked_object=ros::VoidConstPtr(), bool latch=false, ros::CallbackQueueInterface *callback_queue=nullptr) noexcept |
Advertise ROS topic with subscriber status callbacks. More... | |
Connection | connect_to_source (Source< Inputs... > &src) noexcept |
Connect this sink to a source. More... | |
virtual void | disconnect () noexcept override |
Disconnect from all connected sources. More... | |
void | disconnect_from_all_sources () noexcept |
Disconnect from all connected sources. More... | |
virtual bool | is_active () const noexcept override |
Check if the ROS publisher has at least one subscriber. More... | |
virtual void | reset () noexcept |
Reset filter state. More... | |
virtual std::string | topic () const noexcept override |
Return the configured ROS topic. More... | |
Static Public Attributes | |
static constexpr std::size_t | NUM_INPUTS |
Number of input arguments. | |
Protected Member Functions | |
std::tuple< boost::signals2::connection, boost::signals2::connection > | link_with_subscriber (SubscriberBase &sub) |
Add a new subscriber that will be controlled by this publisher. More... | |
virtual void | receive (const Inputs &... in)=0 |
Process incoming data. More... | |
void | update_subscriber_state () |
Cause all linked subscribers to subscribe or unsubscribe to their ROS topics. More... | |
Publish consumed data on a ROS topic.
This class together with the Subscriber class is the generic interface between ROS and this library. All messages which are received from the connected sources will be published on the advertised ROS topic. For maximum flexibility, you can choose one of four ways how to receive messages from your sources:
Publisher<M, RosMessageEvent>
will act as a sink of ros::MessageEvent<const M>
objects (default) Publisher<M, RosMessageConstPtr>
will act as a sink of M::ConstPtr
objects (as of this writing, this is a boost::shared_ptr<const M>
) Publisher<M, RosMessageStdSharedPtr>
will act as a sink of std::shared_ptr<const M>
objects Publisher<M, RosMessage>
will act as a sink of plain M
objectsUnlike regular ROS publishers, this class can be associated with one or more subscriber instances. In that case, the subscribers will subscribe to their ROS topics only if the publisher is actively used. This is a convenient method to save processing power if the filter pipeline is used only intermittently.
|
inherited |
Grouped input types.
This type can be used to define sources with matching types.
|
noexcept |
Constructs an empty publisher.
You need to call advertise() to actually publish to a ROS topic.
|
noexcept |
Constructor that advertises the given ROS topic.
The constructor calls advertise() for you.
|
noexcept |
Advertise ROS topic.
All arguments are passed to the ROS client library; see the ROS documentation for further information. Calling this method will automatically unadvertise any previously advertised ROS topic.
nh
ROS node handle to create the ROS advertisement topic
name of the ROS topic, subject to remapping queue_size
size of the ROS publishing queue latch
if true, the last published message remains available for later subscribers callback_queue
custom ROS callback queue
|
noexcept |
Advertise ROS topic with subscriber status callbacks.
All arguments are passed to the ROS client library; see the ROS documentation for further information. Calling this method will automatically unadvertise any previously advertised ROS topic.
nh
ROS node handle to create the ROS advertisement topic
name of the ROS topic, subject to remapping queue_size
size of the ROS publishing queue connect_cb
callback that is invoked each time a new subscriber connects to the advertised topic disconnect_cb
callback that is invoked each time an existing subscriber disconnects from the advertised topic tracked_object
an associated object whose lifetime will limit the lifetime of the advertised topic latch
if true, the last published message remains available for later subscribers callback_queue
custom ROS callback queue
|
noexceptinherited |
Connect this sink to a source.
Can be called multiple times to connect multiple sources; in that case, the sink receives data from all connected sources. This function does basically the same thing as Source::connect_to_sink(), only from the opposite point of view.
src
the source that is to be connected
|
overridevirtualnoexceptinherited |
Disconnect from all connected sources.
The sink implementation calls disconnect_from_all_sources().
Implements fkie_message_filters::FilterBase.
|
noexceptinherited |
Disconnect from all connected sources.
Severs the connection to all sources. The receive() method will not be called any more.
|
overridevirtualnoexcept |
Check if the ROS publisher has at least one subscriber.
Implements fkie_message_filters::PublisherBase.
|
protectedinherited |
Add a new subscriber that will be controlled by this publisher.
sub
the subscriber
|
protectedpure virtualinherited |
Process incoming data.
Derived classes need to override this method to handle all data that is to be consumed by the sink.
|
inlinevirtualnoexceptinherited |
Reset filter state.
For stateful filters, this method resets the internal state as if the filter had just been created. Existing connections to sources and sinks are unaffected.
The default implementation does nothing.
Reimplemented in fkie_message_filters::Buffer< Inputs >, fkie_message_filters::Buffer< Inputs... >, fkie_message_filters::TfFilter< Inputs >, fkie_message_filters::TfFilter< Inputs... >, fkie_message_filters::Combiner< PolicyTmpl, IOs >, fkie_message_filters::Sequencer< Inputs >, and fkie_message_filters::Sequencer< Inputs... >.
|
overridevirtualnoexcept |
Return the configured ROS topic.
Implements fkie_message_filters::PublisherBase.
|
protectedinherited |
Cause all linked subscribers to subscribe or unsubscribe to their ROS topics.
This will check the return value of is_active() to determine if the publisher is active, and then call SubscriberBase::subscribe_impl() or SubscriberBase::unsubscribe_impl() accordingly.