12 const uint8_t data_type = adv_data[0];
13 const auto *data = &adv_data[1];
16 if (adv_data.size() != 14)
19 const uint8_t temp_sign = (data[1] >> 7) & 1;
20 const float temp_val = (data[1] & 0x7F) + (data[2] / 100.0f);
21 const float temperature = temp_sign == 0 ? temp_val : -1 * temp_val;
23 const float humidity = data[0] * 0.5f;
25 const float acceleration_x =
static_cast<int16_t
>(
encode_uint16(data[5], data[6])) / 1000.0f;
26 const float acceleration_y =
static_cast<int16_t
>(
encode_uint16(data[7], data[8])) / 1000.0f;
27 const float acceleration_z =
static_cast<int16_t
>(
encode_uint16(data[9], data[10])) / 1000.0f;
28 const float battery_voltage =
encode_uint16(data[11], data[12]) / 1000.0f;
37 sqrtf(acceleration_x * acceleration_x + acceleration_y * acceleration_y + acceleration_z * acceleration_z);
43 if (adv_data.size() != 24)
47 const float humidity =
encode_uint16(data[2], data[3]) / 400.0f;
49 const float acceleration_x =
static_cast<int16_t
>(
encode_uint16(data[6], data[7])) / 1000.0f;
50 const float acceleration_y =
static_cast<int16_t
>(
encode_uint16(data[8], data[9])) / 1000.0f;
51 const float acceleration_z =
static_cast<int16_t
>(
encode_uint16(data[10], data[11])) / 1000.0f;
53 const uint16_t power_info =
encode_uint16(data[12], data[13]);
54 const float battery_voltage = ((power_info >> 5) + 1600.0f) / 1000.0f;
55 const float tx_power = ((power_info & 0x1F) * 2.0f) - 40.0f;
57 const float movement_counter = float(data[14]);
58 const float measurement_sequence_number = float(
encode_uint16(data[15], data[16]));
61 result.
humidity = data[2] == 0xFF && data[3] == 0xFF ? NAN : humidity;
63 result.
acceleration_x = data[6] == 0xFF && data[7] == 0xFF ? NAN : acceleration_x;
64 result.
acceleration_y = data[8] == 0xFF && data[9] == 0xFF ? NAN : acceleration_y;
65 result.
acceleration_z = data[10] == 0xFF && data[11] == 0xFF ? NAN : acceleration_z;
66 if ((data[6] != 0xFF || data[7] != 0xFF) && (data[8] != 0xFF || data[9] != 0xFF) &&
67 (data[10] != 0xFF || data[11] != 0xFF)) {
69 sqrtf(acceleration_x * acceleration_x + acceleration_y * acceleration_y + acceleration_z * acceleration_z);
73 result.
battery_voltage = (power_info >> 5) == 0x7FF ? NAN : battery_voltage;
74 result.
tx_power = (power_info & 0x1F) == 0x1F ? NAN : tx_power;
102 if (!res.has_value())
105 char addr_buf[MAC_ADDRESS_PRETTY_BUFFER_SIZE];
106 ESP_LOGD(TAG,
"Got RuuviTag (%s):", device.
address_str_to(addr_buf));
108 if (res->humidity.has_value()) {
109 ESP_LOGD(TAG,
" Humidity: %.2f%%", *res->humidity);
111 if (res->temperature.has_value()) {
112 ESP_LOGD(TAG,
" Temperature: %.2f°C", *res->temperature);
114 if (res->pressure.has_value()) {
115 ESP_LOGD(TAG,
" Pressure: %.2fhPa", *res->pressure);
117 if (res->acceleration.has_value()) {
118 ESP_LOGD(TAG,
" Acceleration: %.3fG", *res->acceleration);
120 if (res->acceleration_x.has_value()) {
121 ESP_LOGD(TAG,
" Acceleration X: %.3fG", *res->acceleration_x);
123 if (res->acceleration_y.has_value()) {
124 ESP_LOGD(TAG,
" Acceleration Y: %.3fG", *res->acceleration_y);
126 if (res->acceleration_z.has_value()) {
127 ESP_LOGD(TAG,
" Acceleration Z: %.3fG", *res->acceleration_z);
129 if (res->battery_voltage.has_value()) {
130 ESP_LOGD(TAG,
" Battery Voltage: %.3fV", *res->battery_voltage);
132 if (res->tx_power.has_value()) {
133 ESP_LOGD(TAG,
" TX Power: %.0fdBm", *res->tx_power);
135 if (res->movement_counter.has_value()) {
136 ESP_LOGD(TAG,
" Movement Counter: %.0f", *res->movement_counter);
138 if (res->measurement_sequence_number.has_value()) {
139 ESP_LOGD(TAG,
" Measurement Sequence Number: %.0f", *res->measurement_sequence_number);