1
0
mirror of https://github.com/esphome/esphome.git synced 2025-02-21 20:38:16 +00:00
Otto Winter 8e75980ebd
Cleanup dashboard JS (#491)
* Cleanup dashboard JS

* Add vscode

* Save start_mark/end_mark

* Updates

* Updates

* Remove need for cv.nameable

It's a bit hacky but removes so much bloat from integrations

* Add enum helper

* Document APIs, and Improvements

* Fixes

* Fixes

* Update PULL_REQUEST_TEMPLATE.md

* Updates

* Updates

* Updates
2019-04-22 21:56:30 +02:00

64 lines
1.6 KiB
C++

#include "hx711.h"
#include "esphome/core/log.h"
namespace esphome {
namespace hx711 {
static const char *TAG = "hx711";
void HX711Sensor::setup() {
ESP_LOGCONFIG(TAG, "Setting up HX711 '%s'...", this->name_.c_str());
this->sck_pin_->setup();
this->dout_pin_->setup();
// Read sensor once without publishing to set the gain
this->read_sensor_(nullptr);
}
void HX711Sensor::dump_config() {
LOG_SENSOR("", "HX711", this);
LOG_PIN(" DOUT Pin: ", this->dout_pin_);
LOG_PIN(" SCK Pin: ", this->sck_pin_);
LOG_UPDATE_INTERVAL(this);
}
float HX711Sensor::get_setup_priority() const { return setup_priority::DATA; }
void HX711Sensor::update() {
uint32_t result;
if (this->read_sensor_(&result)) {
ESP_LOGD(TAG, "'%s': Got value %u", this->name_.c_str(), result);
this->publish_state(result);
}
}
bool HX711Sensor::read_sensor_(uint32_t *result) {
if (this->dout_pin_->digital_read()) {
ESP_LOGW(TAG, "HX711 is not ready for new measurements yet!");
this->status_set_warning();
return false;
}
this->status_clear_warning();
uint32_t data = 0;
for (uint8_t i = 0; i < 24; i++) {
this->sck_pin_->digital_write(true);
delayMicroseconds(1);
data |= uint32_t(this->dout_pin_->digital_read()) << (24 - i);
this->sck_pin_->digital_write(false);
delayMicroseconds(1);
}
// Cycle clock pin for gain setting
for (uint8_t i = 0; i < this->gain_; i++) {
this->sck_pin_->digital_write(true);
this->sck_pin_->digital_write(false);
}
data ^= 0x800000;
if (result != nullptr)
*result = data;
return true;
}
} // namespace hx711
} // namespace esphome