Files
esphome-dev/esphome/components/sds011/sds011.h
T
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

49 lines
1.3 KiB
C++

#pragma once
#include "esphome/core/component.h"
#include "esphome/components/sensor/sensor.h"
#include "esphome/components/uart/uart.h"
namespace esphome {
namespace sds011 {
class SDS011Component : public Component, public uart::UARTDevice {
public:
SDS011Component() = default;
/// Manually set the rx-only mode. Defaults to false.
void set_rx_mode_only(bool rx_mode_only);
void set_pm_2_5_sensor(sensor::Sensor *pm_2_5_sensor) { pm_2_5_sensor_ = pm_2_5_sensor; }
void set_pm_10_0_sensor(sensor::Sensor *pm_10_0_sensor) { pm_10_0_sensor_ = pm_10_0_sensor; }
void setup() override;
void dump_config() override;
void loop() override;
float get_setup_priority() const override;
void set_update_interval(uint32_t val) { /* ignore */
}
void set_update_interval_min(uint8_t update_interval_min);
protected:
void sds011_write_command_(const uint8_t *command);
uint8_t sds011_checksum_(const uint8_t *command_data, uint8_t length) const;
optional<bool> check_byte_() const;
void parse_data_();
uint16_t get_16_bit_uint_(uint8_t start_index) const;
sensor::Sensor *pm_2_5_sensor_{nullptr};
sensor::Sensor *pm_10_0_sensor_{nullptr};
uint8_t data_[10];
uint8_t data_index_{0};
uint32_t last_transmission_{0};
uint8_t update_interval_min_;
bool rx_mode_only_;
};
} // namespace sds011
} // namespace esphome