mirror of
https://github.com/Threnklyn/esphome-dev.git
synced 2026-05-19 12:43:28 +02:00
32 lines
822 B
C++
32 lines
822 B
C++
#include "pulse_width.h"
|
|
#include "esphome/core/log.h"
|
|
|
|
namespace esphome {
|
|
namespace pulse_width {
|
|
|
|
static const char *const TAG = "pulse_width";
|
|
|
|
void ICACHE_RAM_ATTR PulseWidthSensorStore::gpio_intr(PulseWidthSensorStore *arg) {
|
|
const bool new_level = arg->pin_->digital_read();
|
|
const uint32_t now = micros();
|
|
if (new_level) {
|
|
arg->last_rise_ = now;
|
|
} else {
|
|
arg->last_width_ = (now - arg->last_rise_);
|
|
}
|
|
}
|
|
|
|
void PulseWidthSensor::dump_config() {
|
|
LOG_SENSOR("", "Pulse Width", this)
|
|
LOG_UPDATE_INTERVAL(this)
|
|
LOG_PIN(" Pin: ", this->pin_);
|
|
}
|
|
void PulseWidthSensor::update() {
|
|
float width = this->store_.get_pulse_width_s();
|
|
ESP_LOGCONFIG(TAG, "'%s' - Got pulse width %.3f s", this->name_.c_str(), width);
|
|
this->publish_state(width);
|
|
}
|
|
|
|
} // namespace pulse_width
|
|
} // namespace esphome
|