temperaturepublisher.h
Go to the documentation of this file.
1 
2 // Copyright (c) 2003-2021 Xsens Technologies B.V. or subsidiaries worldwide.
3 // All rights reserved.
4 //
5 // Redistribution and use in source and binary forms, with or without modification,
6 // are permitted provided that the following conditions are met:
7 //
8 // 1. Redistributions of source code must retain the above copyright notice,
9 // this list of conditions, and the following disclaimer.
10 //
11 // 2. Redistributions in binary form must reproduce the above copyright notice,
12 // this list of conditions, and the following disclaimer in the documentation
13 // and/or other materials provided with the distribution.
14 //
15 // 3. Neither the names of the copyright holders nor the names of their contributors
16 // may be used to endorse or promote products derived from this software without
17 // specific prior written permission.
18 //
19 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
20 // EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
21 // MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
22 // THE COPYRIGHT HOLDERS OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23 // SPECIAL, EXEMPLARY OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
24 // OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
25 // HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY OR
26 // TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
27 // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.THE LAWS OF THE NETHERLANDS
28 // SHALL BE EXCLUSIVELY APPLICABLE AND ANY DISPUTES SHALL BE FINALLY SETTLED UNDER THE RULES
29 // OF ARBITRATION OF THE INTERNATIONAL CHAMBER OF COMMERCE IN THE HAGUE BY ONE OR MORE
30 // ARBITRATORS APPOINTED IN ACCORDANCE WITH SAID RULES.
31 //
32 
33 #ifndef TEMPERATUREPUBLISHER_H
34 #define TEMPERATUREPUBLISHER_H
35 
36 #include "packetcallback.h"
37 #include <sensor_msgs/Temperature.h>
38 
40 {
42  std::string frame_id = DEFAULT_FRAME_ID;
43 
44 
46  {
47  int pub_queue_size = 5;
48  ros::param::get("~publisher_queue_size", pub_queue_size);
49  pub = node.advertise<sensor_msgs::Temperature>("temperature", pub_queue_size);
50  ros::param::get("~frame_id", frame_id);
51  }
52 
53  void operator()(const XsDataPacket &packet, ros::Time timestamp)
54  {
55  if (packet.containsTemperature())
56  {
57  sensor_msgs::Temperature msg;
58 
59  msg.header.stamp = timestamp;
60  msg.header.frame_id = frame_id;
61 
62  msg.temperature = packet.temperature();
63  msg.variance = 0; // unknown
64 
65  pub.publish(msg);
66  }
67  }
68 };
69 
70 #endif
TemperaturePublisher
Definition: temperaturepublisher.h:39
msg
msg
ros::Publisher
ros::param::get
ROSCPP_DECL bool get(const std::string &key, bool &b)
DEFAULT_FRAME_ID
const char * DEFAULT_FRAME_ID
Definition: packetcallback.h:39
packetcallback.h
XsDataPacket
Contains an interpreted data message. The class provides easy access to the contained data through it...
Definition: xsdatapacket.h:301
ros::Publisher::publish
void publish(const boost::shared_ptr< M > &message) const
ros::NodeHandle::advertise
Publisher advertise(AdvertiseOptions &ops)
TemperaturePublisher::pub
ros::Publisher pub
Definition: temperaturepublisher.h:41
TemperaturePublisher::operator()
void operator()(const XsDataPacket &packet, ros::Time timestamp)
Definition: temperaturepublisher.h:53
ros::Time
PacketCallback
Definition: packetcallback.h:41
TemperaturePublisher::TemperaturePublisher
TemperaturePublisher(ros::NodeHandle &node)
Definition: temperaturepublisher.h:45
ros::NodeHandle
TemperaturePublisher::frame_id
std::string frame_id
Definition: temperaturepublisher.h:42


xsens_mti_driver
Author(s):
autogenerated on Sun Sep 3 2023 02:43:20