mirror of
https://github.com/Threnklyn/esphome-dev.git
synced 2026-06-01 18:48:28 +02:00
65d08beaa4
* add xiaomi BLE Thermometer lywsd02 model support * remove battery level * Update sensor.py to pass the lint test https://github.com/esphome/esphome/pull/664 * fix trailing space Co-authored-by: Guoxue <gx@m15.cn> Co-authored-by: mr G1K <mr@g1k.ru>
47 lines
1.4 KiB
C++
47 lines
1.4 KiB
C++
#pragma once
|
|
|
|
#include "esphome/core/component.h"
|
|
#include "esphome/components/sensor/sensor.h"
|
|
#include "esphome/components/esp32_ble_tracker/esp32_ble_tracker.h"
|
|
#include "esphome/components/xiaomi_ble/xiaomi_ble.h"
|
|
|
|
#ifdef ARDUINO_ARCH_ESP32
|
|
|
|
namespace esphome {
|
|
namespace xiaomi_lywsd02 {
|
|
|
|
class XiaomiLYWSD02 : public Component, public esp32_ble_tracker::ESPBTDeviceListener {
|
|
public:
|
|
void set_address(uint64_t address) { address_ = address; }
|
|
|
|
bool parse_device(const esp32_ble_tracker::ESPBTDevice &device) override {
|
|
if (device.address_uint64() != this->address_)
|
|
return false;
|
|
|
|
auto res = xiaomi_ble::parse_xiaomi(device);
|
|
if (!res.has_value())
|
|
return false;
|
|
|
|
if (res->temperature.has_value() && this->temperature_ != nullptr)
|
|
this->temperature_->publish_state(*res->temperature);
|
|
if (res->humidity.has_value() && this->humidity_ != nullptr)
|
|
this->humidity_->publish_state(*res->humidity);
|
|
return true;
|
|
}
|
|
|
|
void dump_config() override;
|
|
float get_setup_priority() const override { return setup_priority::DATA; }
|
|
void set_temperature(sensor::Sensor *temperature) { temperature_ = temperature; }
|
|
void set_humidity(sensor::Sensor *humidity) { humidity_ = humidity; }
|
|
|
|
protected:
|
|
uint64_t address_;
|
|
sensor::Sensor *temperature_{nullptr};
|
|
sensor::Sensor *humidity_{nullptr};
|
|
};
|
|
|
|
} // namespace xiaomi_lywsd02
|
|
} // namespace esphome
|
|
|
|
#endif
|