mirror of
https://github.com/esphome/esphome.git
synced 2025-03-13 22:28:14 +00:00
Fix HX711
This commit is contained in:
parent
f31c1480f3
commit
92f3ae64d6
@ -1,5 +1,6 @@
|
||||
#include "hx711.h"
|
||||
#include "esphome/core/log.h"
|
||||
#include "esphome/core/helpers.h"
|
||||
|
||||
namespace esphome {
|
||||
namespace hx711 {
|
||||
@ -10,6 +11,7 @@ void HX711Sensor::setup() {
|
||||
ESP_LOGCONFIG(TAG, "Setting up HX711 '%s'...", this->name_.c_str());
|
||||
this->sck_pin_->setup();
|
||||
this->dout_pin_->setup();
|
||||
this->sck_pin_->digital_write(false);
|
||||
|
||||
// Read sensor once without publishing to set the gain
|
||||
this->read_sensor_(nullptr);
|
||||
@ -39,10 +41,11 @@ bool HX711Sensor::read_sensor_(uint32_t *result) {
|
||||
this->status_clear_warning();
|
||||
uint32_t data = 0;
|
||||
|
||||
disable_interrupts();
|
||||
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);
|
||||
data |= uint32_t(this->dout_pin_->digital_read()) << (23 - i);
|
||||
this->sck_pin_->digital_write(false);
|
||||
delayMicroseconds(1);
|
||||
}
|
||||
@ -50,10 +53,16 @@ bool HX711Sensor::read_sensor_(uint32_t *result) {
|
||||
// Cycle clock pin for gain setting
|
||||
for (uint8_t i = 0; i < this->gain_; i++) {
|
||||
this->sck_pin_->digital_write(true);
|
||||
delayMicroseconds(1);
|
||||
this->sck_pin_->digital_write(false);
|
||||
delayMicroseconds(1);
|
||||
}
|
||||
enable_interrupts();
|
||||
|
||||
if (data & 0x800000ULL) {
|
||||
data |= 0xFF000000ULL;
|
||||
}
|
||||
|
||||
data ^= 0x800000;
|
||||
if (result != nullptr)
|
||||
*result = data;
|
||||
return true;
|
||||
|
Loading…
x
Reference in New Issue
Block a user