Change binary sensor to sensor

This commit is contained in:
Dotsch2005 2024-10-11 09:49:35 +02:00
parent 8358235ac5
commit 818aeb189c
4 changed files with 13 additions and 11 deletions

View file

@ -91,11 +91,10 @@ void RadonEyeRD200::handle_status_response_(const uint8_t *response, uint16_t le
if (alarm_sensor_ != nullptr) { if (alarm_sensor_ != nullptr) {
ESP_LOGD(TAG, " Sensor alarm send!"); ESP_LOGD(TAG, " Sensor alarm send!");
if (data->alarm != 0) { if (data->alarm != 0) {
alarm_sensor_->publish_state(true); alarm_sensor_->publish_state(1);
} else { } else {
alarm_sensor_->publish_state(false); alarm_sensor_->publish_state(0);
} }
delay(25); delay(25);
} else { } else {
ESP_LOGI(TAG, " Sensor alarm not exists!"); ESP_LOGI(TAG, " Sensor alarm not exists!");

View file

@ -8,7 +8,6 @@
#include "esphome/components/ble_client/ble_client.h" #include "esphome/components/ble_client/ble_client.h"
#include "esphome/components/esp32_ble_tracker/esp32_ble_tracker.h" #include "esphome/components/esp32_ble_tracker/esp32_ble_tracker.h"
#include "esphome/components/sensor/sensor.h" #include "esphome/components/sensor/sensor.h"
#include "esphome/components/binary_sensor/binary_sensor.h"
#include "esphome/core/component.h" #include "esphome/core/component.h"
#include "esphome/core/log.h" #include "esphome/core/log.h"
#include "esphome/core/helpers.h" #include "esphome/core/helpers.h"
@ -67,7 +66,7 @@ class RadonEyeRD200 : public PollingComponent, public ble_client::BLEClientNode
esp_ble_gattc_cb_param_t *param) override; esp_ble_gattc_cb_param_t *param) override;
void set_version(int version) { radon_version_ = version; } void set_version(int version) { radon_version_ = version; }
void set_alarm(binary_sensor::BinarySensor *alarm) { alarm_sensor_ = alarm; } void set_alarm(sensor::Sensor *alarm) { alarm_sensor_ = alarm; }
void set_radon(sensor::Sensor *radon) { radon_sensor_ = radon; } void set_radon(sensor::Sensor *radon) { radon_sensor_ = radon; }
void set_radon_day_avg(sensor::Sensor *radon_day_avg) { radon_day_avg_ = radon_day_avg; } void set_radon_day_avg(sensor::Sensor *radon_day_avg) { radon_day_avg_ = radon_day_avg; }
void set_radon_long_term(sensor::Sensor *radon_long_term) { radon_long_term_sensor_ = radon_long_term; } void set_radon_long_term(sensor::Sensor *radon_long_term) { radon_long_term_sensor_ = radon_long_term; }
@ -88,7 +87,7 @@ class RadonEyeRD200 : public PollingComponent, public ble_client::BLEClientNode
void request_read_values_(); void request_read_values_();
int radon_version_{1}; int radon_version_{1};
binary_sensor::BinarySensor *alarm_sensor_{nullptr}; sensor::Sensor *alarm_sensor_{nullptr};
sensor::Sensor *radon_sensor_{nullptr}; sensor::Sensor *radon_sensor_{nullptr};
sensor::Sensor *radon_day_avg_{nullptr}; sensor::Sensor *radon_day_avg_{nullptr};
sensor::Sensor *radon_long_term_sensor_{nullptr}; sensor::Sensor *radon_long_term_sensor_{nullptr};

View file

@ -1,5 +1,5 @@
import esphome.codegen as cg import esphome.codegen as cg
from esphome.components import binary_sensor, ble_client, sensor from esphome.components import ble_client, sensor
import esphome.config_validation as cv import esphome.config_validation as cv
from esphome.const import ( from esphome.const import (
CONF_ALARM, CONF_ALARM,
@ -13,9 +13,10 @@ from esphome.const import (
ICON_RADIOACTIVE, ICON_RADIOACTIVE,
STATE_CLASS_MEASUREMENT, STATE_CLASS_MEASUREMENT,
UNIT_BECQUEREL_PER_CUBIC_METER, UNIT_BECQUEREL_PER_CUBIC_METER,
UNIT_EMPTY,
) )
DEPENDENCIES = ["ble_client", "binary_sensor"] DEPENDENCIES = ["ble_client"]
radon_eye_rd200_ns = cg.esphome_ns.namespace("radon_eye_rd200") radon_eye_rd200_ns = cg.esphome_ns.namespace("radon_eye_rd200")
RadonEyeRD200 = radon_eye_rd200_ns.class_( RadonEyeRD200 = radon_eye_rd200_ns.class_(
@ -27,8 +28,11 @@ CONFIG_SCHEMA = cv.All(
{ {
cv.GenerateID(): cv.declare_id(RadonEyeRD200), cv.GenerateID(): cv.declare_id(RadonEyeRD200),
cv.Optional(CONF_VERSION, default=1): cv.int_range(1, 3), cv.Optional(CONF_VERSION, default=1): cv.int_range(1, 3),
cv.Optional(CONF_ALARM, default=0): binary_sensor.binary_sensor_schema( cv.Optional(CONF_ALARM): sensor.sensor_schema(
unit_of_measurement=UNIT_EMPTY,
icon=ICON_ALARM_LIGHT, icon=ICON_ALARM_LIGHT,
accuracy_decimals=0,
state_class=STATE_CLASS_MEASUREMENT,
), ),
cv.Optional(CONF_RADON): sensor.sensor_schema( cv.Optional(CONF_RADON): sensor.sensor_schema(
unit_of_measurement=UNIT_BECQUEREL_PER_CUBIC_METER, unit_of_measurement=UNIT_BECQUEREL_PER_CUBIC_METER,
@ -70,7 +74,7 @@ async def to_code(config):
cg.add(var.set_version(config[CONF_VERSION])) cg.add(var.set_version(config[CONF_VERSION]))
if CONF_ALARM in config: if CONF_ALARM in config:
sens = await binary_sensor.new_binary_sensor(config[CONF_ALARM]) sens = await sensor.new_sensor(config[CONF_ALARM])
cg.add(var.set_alarm(sens)) cg.add(var.set_alarm(sens))
if CONF_RADON in config: if CONF_RADON in config:
sens = await sensor.new_sensor(config[CONF_RADON]) sens = await sensor.new_sensor(config[CONF_RADON])

View file

@ -19,5 +19,5 @@ sensor:
radon_peak: radon_peak:
name: RD200 Radon Peak name: RD200 Radon Peak
alarm: alarm:
name: Alarm name: RD200 Radon Alarm
update_interval: 10min update_interval: 10min