mirror of
https://github.com/esphome/esphome.git
synced 2025-09-28 16:12:24 +01:00
* dht: Fix sensor reading from DHT22 (#239) Looking at the datasheet for DHT22, it claims to need a delay of 18ms, not 800us. Change to use the same delay as DHT11. Tested working with NodeMCUv3 and DHT22 sensor with board with built-in resistor. * dht: Add model DHT22_TYPE2 with 2ms delay instead of 0.8ms The model DHT22_TYPE2 is exactly the same as DHT22, but uses a different delay. * dht: Fix bogus negative temperature reading on DHT22_TYPE2 The workaround for negative numbers associated with DHT22s can be skipped on these sensors.
46 lines
1.7 KiB
Python
46 lines
1.7 KiB
Python
import esphome.codegen as cg
|
|
import esphome.config_validation as cv
|
|
from esphome import pins
|
|
from esphome.components import sensor
|
|
from esphome.const import CONF_HUMIDITY, CONF_ID, CONF_MODEL, CONF_PIN, CONF_TEMPERATURE, \
|
|
ICON_THERMOMETER, UNIT_CELSIUS, ICON_WATER_PERCENT, UNIT_PERCENT
|
|
from esphome.cpp_helpers import gpio_pin_expression
|
|
|
|
dht_ns = cg.esphome_ns.namespace('dht')
|
|
DHTModel = dht_ns.enum('DHTModel')
|
|
DHT_MODELS = {
|
|
'AUTO_DETECT': DHTModel.DHT_MODEL_AUTO_DETECT,
|
|
'DHT11': DHTModel.DHT_MODEL_DHT11,
|
|
'DHT22': DHTModel.DHT_MODEL_DHT22,
|
|
'AM2302': DHTModel.DHT_MODEL_AM2302,
|
|
'RHT03': DHTModel.DHT_MODEL_RHT03,
|
|
'SI7021': DHTModel.DHT_MODEL_SI7021,
|
|
'DHT22_TYPE2': DHTModel.DHT_MODEL_DHT22_TYPE2,
|
|
}
|
|
DHT = dht_ns.class_('DHT', cg.PollingComponent)
|
|
|
|
CONFIG_SCHEMA = cv.Schema({
|
|
cv.GenerateID(): cv.declare_id(DHT),
|
|
cv.Required(CONF_PIN): pins.gpio_input_pin_schema,
|
|
cv.Optional(CONF_TEMPERATURE): sensor.sensor_schema(UNIT_CELSIUS, ICON_THERMOMETER, 1),
|
|
cv.Optional(CONF_HUMIDITY): sensor.sensor_schema(UNIT_PERCENT, ICON_WATER_PERCENT, 0),
|
|
cv.Optional(CONF_MODEL, default='auto detect'): cv.enum(DHT_MODELS, upper=True, space='_'),
|
|
}).extend(cv.polling_component_schema('60s'))
|
|
|
|
|
|
def to_code(config):
|
|
var = cg.new_Pvariable(config[CONF_ID])
|
|
yield cg.register_component(var, config)
|
|
|
|
pin = yield gpio_pin_expression(config[CONF_PIN])
|
|
cg.add(var.set_pin(pin))
|
|
|
|
if CONF_TEMPERATURE in config:
|
|
sens = yield sensor.new_sensor(config[CONF_TEMPERATURE])
|
|
cg.add(var.set_temperature_sensor(sens))
|
|
if CONF_HUMIDITY in config:
|
|
sens = yield sensor.new_sensor(config[CONF_HUMIDITY])
|
|
cg.add(var.set_humidity_sensor(sens))
|
|
|
|
cg.add(var.set_dht_model(config[CONF_MODEL]))
|