humidity.cpp
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2019, Open Source Robotics Foundation
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions are met:
7  *
8  * * Redistributions of source code must retain the above copyright
9  * notice, this list of conditions and the following disclaimer.
10  * * Redistributions in binary form must reproduce the above copyright
11  * notice, this list of conditions and the following disclaimer in the
12  * documentation and/or other materials provided with the distribution.
13  * * Neither the name of the copyright holder nor the names of its
14  * contributors may be used to endorse or promote products derived from
15  * this software without specific prior written permission.
16  *
17  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
18  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
21  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
22  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
23  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
24  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
25  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
26  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27  * POSSIBILITY OF SUCH DAMAGE.
28  */
29 
30 #include <functional>
31 #include <stdexcept>
32 
33 #include <libphidget22/phidget22.h>
34 
35 #include "phidgets_api/phidget22.h"
36 #include "phidgets_api/humidity.h"
37 
38 namespace phidgets {
39 
40 Humidity::Humidity(int32_t serial_number, int hub_port, bool is_hub_port_device,
41  std::function<void(double)> humidity_handler)
42  : humidity_handler_(humidity_handler)
43 {
44  PhidgetReturnCode ret = PhidgetHumiditySensor_create(&humidity_handle_);
45  if (ret != EPHIDGET_OK)
46  {
47  throw Phidget22Error("Failed to create HumiditySensor handle", ret);
48  }
49 
51  reinterpret_cast<PhidgetHandle>(humidity_handle_), serial_number,
52  hub_port, is_hub_port_device, 0);
53 
54  ret = PhidgetHumiditySensor_setOnHumidityChangeHandler(
56  if (ret != EPHIDGET_OK)
57  {
58  throw Phidget22Error("Failed to set change handler for Humidity", ret);
59  }
60 }
61 
63 {
64  PhidgetHandle handle = reinterpret_cast<PhidgetHandle>(humidity_handle_);
65  helpers::closeAndDelete(&handle);
66 }
67 
68 double Humidity::getHumidity() const
69 {
70  double current_humidity;
71  PhidgetReturnCode ret =
72  PhidgetHumiditySensor_getHumidity(humidity_handle_, &current_humidity);
73  if (ret != EPHIDGET_OK)
74  {
75  throw Phidget22Error("Failed to get humidity", ret);
76  }
77  return current_humidity;
78 }
79 
80 void Humidity::setDataInterval(uint32_t interval_ms) const
81 {
82  PhidgetReturnCode ret =
83  PhidgetHumiditySensor_setDataInterval(humidity_handle_, interval_ms);
84  if (ret != EPHIDGET_OK)
85  {
86  throw Phidget22Error("Failed to set data interval", ret);
87  }
88 }
89 
90 void Humidity::humidityChangeHandler(double humidity) const
91 {
92  humidity_handler_(humidity);
93 }
94 
96  PhidgetHumiditySensorHandle /* humidity_handle */, void *ctx,
97  double humidity)
98 {
99  ((Humidity *)ctx)->humidityChangeHandler(humidity);
100 }
101 
102 } // namespace phidgets
phidgets
Definition: accelerometer.h:39
humidity.h
phidgets::Humidity::humidity_handle_
PhidgetHumiditySensorHandle humidity_handle_
Definition: humidity.h:60
phidgets::helpers::openWaitForAttachment
void openWaitForAttachment(PhidgetHandle handle, int32_t serial_number, int hub_port, bool is_hub_port_device, int channel)
Definition: phidget22.cpp:57
phidgets::Humidity
Definition: humidity.h:41
phidgets::Humidity::humidity_handler_
std::function< void(double)> humidity_handler_
Definition: humidity.h:59
phidgets::helpers::closeAndDelete
void closeAndDelete(PhidgetHandle *handle) noexcept
Definition: phidget22.cpp:93
phidget22.h
phidgets::Humidity::setDataInterval
void setDataInterval(uint32_t interval_ms) const
Definition: humidity.cpp:80
phidgets::Phidget22Error
Definition: phidget22.h:46
phidgets::Humidity::getHumidity
double getHumidity() const
Definition: humidity.cpp:68
phidgets::Humidity::~Humidity
~Humidity()
Definition: humidity.cpp:62
phidgets::Humidity::HumidityChangeHandler
static void HumidityChangeHandler(PhidgetHumiditySensorHandle humidity_handle, void *ctx, double humidity)
Definition: humidity.cpp:95
phidgets::Humidity::Humidity
Humidity(int32_t serial_number, int hub_port, bool is_hub_port_device, std::function< void(double)> humidity_handler)
Definition: humidity.cpp:40
phidgets::Humidity::humidityChangeHandler
void humidityChangeHandler(double humidity) const
Definition: humidity.cpp:90


phidgets_api
Author(s): Tully Foote, Ivan Dryanovski
autogenerated on Sun May 11 2025 02:20:27