mirror of
https://github.com/esphome/esphome.git
synced 2025-01-08 22:01:44 +01:00
Tsl2591 gain publish (#4291)
fixes https://github.com/esphome/issues/issues/4031
This commit is contained in:
parent
1bb90f304c
commit
ddedc1cd76
4 changed files with 55 additions and 5 deletions
|
@ -24,6 +24,7 @@ import esphome.config_validation as cv
|
||||||
from esphome.components import i2c, sensor
|
from esphome.components import i2c, sensor
|
||||||
from esphome.const import (
|
from esphome.const import (
|
||||||
CONF_GAIN,
|
CONF_GAIN,
|
||||||
|
CONF_ACTUAL_GAIN,
|
||||||
CONF_ID,
|
CONF_ID,
|
||||||
CONF_NAME,
|
CONF_NAME,
|
||||||
CONF_INTEGRATION_TIME,
|
CONF_INTEGRATION_TIME,
|
||||||
|
@ -79,7 +80,6 @@ TSL2591Component = tsl2591_ns.class_(
|
||||||
"TSL2591Component", cg.PollingComponent, i2c.I2CDevice
|
"TSL2591Component", cg.PollingComponent, i2c.I2CDevice
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
CONFIG_SCHEMA = (
|
CONFIG_SCHEMA = (
|
||||||
cv.Schema(
|
cv.Schema(
|
||||||
{
|
{
|
||||||
|
@ -106,6 +106,12 @@ CONFIG_SCHEMA = (
|
||||||
device_class=DEVICE_CLASS_ILLUMINANCE,
|
device_class=DEVICE_CLASS_ILLUMINANCE,
|
||||||
state_class=STATE_CLASS_MEASUREMENT,
|
state_class=STATE_CLASS_MEASUREMENT,
|
||||||
),
|
),
|
||||||
|
cv.Optional(CONF_ACTUAL_GAIN): sensor.sensor_schema(
|
||||||
|
icon=ICON_BRIGHTNESS_6,
|
||||||
|
accuracy_decimals=0,
|
||||||
|
device_class=DEVICE_CLASS_ILLUMINANCE,
|
||||||
|
state_class=STATE_CLASS_MEASUREMENT,
|
||||||
|
),
|
||||||
cv.Optional(
|
cv.Optional(
|
||||||
CONF_INTEGRATION_TIME, default="100ms"
|
CONF_INTEGRATION_TIME, default="100ms"
|
||||||
): validate_integration_time,
|
): validate_integration_time,
|
||||||
|
@ -150,6 +156,11 @@ async def to_code(config):
|
||||||
sens = await sensor.new_sensor(conf)
|
sens = await sensor.new_sensor(conf)
|
||||||
cg.add(var.set_calculated_lux_sensor(sens))
|
cg.add(var.set_calculated_lux_sensor(sens))
|
||||||
|
|
||||||
|
if CONF_ACTUAL_GAIN in config:
|
||||||
|
conf = config[CONF_ACTUAL_GAIN]
|
||||||
|
sens = await sensor.new_sensor(conf)
|
||||||
|
cg.add(var.set_actual_gain_sensor(sens))
|
||||||
|
|
||||||
cg.add(var.set_name(config[CONF_NAME]))
|
cg.add(var.set_name(config[CONF_NAME]))
|
||||||
cg.add(var.set_power_save_mode(config[CONF_POWER_SAVE_MODE]))
|
cg.add(var.set_power_save_mode(config[CONF_POWER_SAVE_MODE]))
|
||||||
cg.add(var.set_integration_time(config[CONF_INTEGRATION_TIME]))
|
cg.add(var.set_integration_time(config[CONF_INTEGRATION_TIME]))
|
||||||
|
|
|
@ -130,6 +130,7 @@ void TSL2591Component::dump_config() {
|
||||||
LOG_SENSOR(" ", "Infrared:", this->infrared_sensor_);
|
LOG_SENSOR(" ", "Infrared:", this->infrared_sensor_);
|
||||||
LOG_SENSOR(" ", "Visible:", this->visible_sensor_);
|
LOG_SENSOR(" ", "Visible:", this->visible_sensor_);
|
||||||
LOG_SENSOR(" ", "Calculated lux:", this->calculated_lux_sensor_);
|
LOG_SENSOR(" ", "Calculated lux:", this->calculated_lux_sensor_);
|
||||||
|
LOG_SENSOR(" ", "Actual gain:", this->actual_gain_sensor_);
|
||||||
|
|
||||||
LOG_UPDATE_INTERVAL(this);
|
LOG_UPDATE_INTERVAL(this);
|
||||||
}
|
}
|
||||||
|
@ -140,8 +141,9 @@ void TSL2591Component::process_update_() {
|
||||||
uint16_t infrared = this->get_illuminance(TSL2591_SENSOR_CHANNEL_INFRARED, combined);
|
uint16_t infrared = this->get_illuminance(TSL2591_SENSOR_CHANNEL_INFRARED, combined);
|
||||||
uint16_t full = this->get_illuminance(TSL2591_SENSOR_CHANNEL_FULL_SPECTRUM, combined);
|
uint16_t full = this->get_illuminance(TSL2591_SENSOR_CHANNEL_FULL_SPECTRUM, combined);
|
||||||
float lux = this->get_calculated_lux(full, infrared);
|
float lux = this->get_calculated_lux(full, infrared);
|
||||||
ESP_LOGD(TAG, "Got illuminance: combined 0x%X, full %d, IR %d, vis %d. Calc lux: %f", combined, full, infrared,
|
uint16_t actual_gain = this->get_actual_gain();
|
||||||
visible, lux);
|
ESP_LOGD(TAG, "Got illuminance: combined 0x%X, full %d, IR %d, vis %d. Calc lux: %f. Actual gain: %d.", combined,
|
||||||
|
full, infrared, visible, lux, actual_gain);
|
||||||
if (this->full_spectrum_sensor_ != nullptr) {
|
if (this->full_spectrum_sensor_ != nullptr) {
|
||||||
this->full_spectrum_sensor_->publish_state(full);
|
this->full_spectrum_sensor_->publish_state(full);
|
||||||
}
|
}
|
||||||
|
@ -154,9 +156,14 @@ void TSL2591Component::process_update_() {
|
||||||
if (this->calculated_lux_sensor_ != nullptr) {
|
if (this->calculated_lux_sensor_ != nullptr) {
|
||||||
this->calculated_lux_sensor_->publish_state(lux);
|
this->calculated_lux_sensor_->publish_state(lux);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this->component_gain_ == TSL2591_CGAIN_AUTO) {
|
if (this->component_gain_ == TSL2591_CGAIN_AUTO) {
|
||||||
this->automatic_gain_update(full);
|
this->automatic_gain_update(full);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (this->actual_gain_sensor_ != nullptr) {
|
||||||
|
this->actual_gain_sensor_->publish_state(actual_gain);
|
||||||
|
}
|
||||||
this->status_clear_warning();
|
this->status_clear_warning();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -207,6 +214,10 @@ void TSL2591Component::set_calculated_lux_sensor(sensor::Sensor *calculated_lux_
|
||||||
this->calculated_lux_sensor_ = calculated_lux_sensor;
|
this->calculated_lux_sensor_ = calculated_lux_sensor;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void TSL2591Component::set_actual_gain_sensor(sensor::Sensor *actual_gain_sensor) {
|
||||||
|
this->actual_gain_sensor_ = actual_gain_sensor;
|
||||||
|
}
|
||||||
|
|
||||||
void TSL2591Component::set_integration_time(TSL2591IntegrationTime integration_time) {
|
void TSL2591Component::set_integration_time(TSL2591IntegrationTime integration_time) {
|
||||||
this->integration_time_ = integration_time;
|
this->integration_time_ = integration_time;
|
||||||
}
|
}
|
||||||
|
@ -377,7 +388,6 @@ float TSL2591Component::get_calculated_lux(uint16_t full_spectrum, uint16_t infr
|
||||||
again = 1.0F;
|
again = 1.0F;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
// This lux equation is copied from the Adafruit TSL2591 v1.4.0 and modified slightly.
|
// This lux equation is copied from the Adafruit TSL2591 v1.4.0 and modified slightly.
|
||||||
// See: https://github.com/adafruit/Adafruit_TSL2591_Library/issues/14
|
// See: https://github.com/adafruit/Adafruit_TSL2591_Library/issues/14
|
||||||
// and that library code.
|
// and that library code.
|
||||||
|
@ -448,5 +458,25 @@ void TSL2591Component::automatic_gain_update(uint16_t full_spectrum) {
|
||||||
ESP_LOGD(TAG, "Gain setting: %d", this->gain_);
|
ESP_LOGD(TAG, "Gain setting: %d", this->gain_);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Reads the actual gain used
|
||||||
|
*
|
||||||
|
* Useful for exposing the real gain used when configured in "auto" gain mode
|
||||||
|
*/
|
||||||
|
float TSL2591Component::get_actual_gain() {
|
||||||
|
switch (this->gain_) {
|
||||||
|
case TSL2591_GAIN_LOW:
|
||||||
|
return 1.0F;
|
||||||
|
case TSL2591_GAIN_MED:
|
||||||
|
return 25.0F;
|
||||||
|
case TSL2591_GAIN_HIGH:
|
||||||
|
return 400.0F;
|
||||||
|
case TSL2591_GAIN_MAX:
|
||||||
|
return 9500.0F;
|
||||||
|
default:
|
||||||
|
// Shouldn't get here, but just in case.
|
||||||
|
return NAN;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace tsl2591
|
} // namespace tsl2591
|
||||||
} // namespace esphome
|
} // namespace esphome
|
||||||
|
|
|
@ -217,14 +217,21 @@ class TSL2591Component : public PollingComponent, public i2c::I2CDevice {
|
||||||
*
|
*
|
||||||
* This gets called on update and tries to keep the ADC readings in the middle of the range
|
* This gets called on update and tries to keep the ADC readings in the middle of the range
|
||||||
*/
|
*/
|
||||||
|
|
||||||
void automatic_gain_update(uint16_t full_spectrum);
|
void automatic_gain_update(uint16_t full_spectrum);
|
||||||
|
|
||||||
|
/** Reads the actual gain used
|
||||||
|
*
|
||||||
|
* Useful for exposing the real gain used when configured in "auto" gain mode
|
||||||
|
*/
|
||||||
|
float get_actual_gain();
|
||||||
|
|
||||||
// ========== INTERNAL METHODS ==========
|
// ========== INTERNAL METHODS ==========
|
||||||
// (In most use cases you won't need these. They're for ESPHome integration use.)
|
// (In most use cases you won't need these. They're for ESPHome integration use.)
|
||||||
/** Used by ESPHome framework. */
|
/** Used by ESPHome framework. */
|
||||||
void set_full_spectrum_sensor(sensor::Sensor *full_spectrum_sensor);
|
void set_full_spectrum_sensor(sensor::Sensor *full_spectrum_sensor);
|
||||||
/** Used by ESPHome framework. */
|
/** Used by ESPHome framework. */
|
||||||
|
void set_actual_gain_sensor(sensor::Sensor *actual_gain_sensor);
|
||||||
|
/** Used by ESPHome framework. */
|
||||||
void set_infrared_sensor(sensor::Sensor *infrared_sensor);
|
void set_infrared_sensor(sensor::Sensor *infrared_sensor);
|
||||||
/** Used by ESPHome framework. */
|
/** Used by ESPHome framework. */
|
||||||
void set_visible_sensor(sensor::Sensor *visible_sensor);
|
void set_visible_sensor(sensor::Sensor *visible_sensor);
|
||||||
|
@ -249,6 +256,7 @@ class TSL2591Component : public PollingComponent, public i2c::I2CDevice {
|
||||||
sensor::Sensor *infrared_sensor_{nullptr};
|
sensor::Sensor *infrared_sensor_{nullptr};
|
||||||
sensor::Sensor *visible_sensor_{nullptr};
|
sensor::Sensor *visible_sensor_{nullptr};
|
||||||
sensor::Sensor *calculated_lux_sensor_{nullptr};
|
sensor::Sensor *calculated_lux_sensor_{nullptr};
|
||||||
|
sensor::Sensor *actual_gain_sensor_{nullptr};
|
||||||
TSL2591IntegrationTime integration_time_;
|
TSL2591IntegrationTime integration_time_;
|
||||||
TSL2591ComponentGain component_gain_;
|
TSL2591ComponentGain component_gain_;
|
||||||
TSL2591Gain gain_;
|
TSL2591Gain gain_;
|
||||||
|
|
|
@ -26,6 +26,7 @@ CONF_ACTION_ID = "action_id"
|
||||||
CONF_ACTION_STATE_TOPIC = "action_state_topic"
|
CONF_ACTION_STATE_TOPIC = "action_state_topic"
|
||||||
CONF_ACTIVE = "active"
|
CONF_ACTIVE = "active"
|
||||||
CONF_ACTIVE_POWER = "active_power"
|
CONF_ACTIVE_POWER = "active_power"
|
||||||
|
CONF_ACTUAL_GAIN = "actual_gain"
|
||||||
CONF_ADDRESS = "address"
|
CONF_ADDRESS = "address"
|
||||||
CONF_ADDRESSABLE_LIGHT_ID = "addressable_light_id"
|
CONF_ADDRESSABLE_LIGHT_ID = "addressable_light_id"
|
||||||
CONF_ADVANCED = "advanced"
|
CONF_ADVANCED = "advanced"
|
||||||
|
|
Loading…
Reference in a new issue