ESPHome 2026.5.1
Loading...
Searching...
No Matches
lightwaverf.cpp
Go to the documentation of this file.
2#include "esphome/core/log.h"
3
4#ifdef USE_ESP8266
5
6#include "lightwaverf.h"
7
9
10static const char *const TAG = "lightwaverf.sensor";
11
12static const uint8_t DEFAULT_REPEAT = 10;
13static const bool DEFAULT_INVERT = false;
14static const uint32_t DEFAULT_TICK = 330;
15
17 this->lwtx_.lwtx_setup(pin_tx_, DEFAULT_REPEAT, DEFAULT_INVERT, DEFAULT_TICK);
19}
20
21void LightWaveRF::update() { this->read_tx(); }
22
24 if (this->lwrx_.lwrx_message()) {
27 }
28}
29
30void LightWaveRF::send_rx(const std::vector<uint8_t> &msg, uint8_t repeats, bool inverted, int u_sec) {
31 this->lwtx_.lwtx_setup(pin_tx_, repeats, inverted, u_sec);
32
33 uint32_t timeout = millis();
34 if (this->lwtx_.lwtx_free()) {
35 this->lwtx_.lwtx_send(msg);
36 ESP_LOGD(TAG, "[%i] msg start", timeout);
37 }
38 while (!this->lwtx_.lwtx_free() && millis() - timeout < 1000) {
39 delay(10);
40 }
41 timeout = millis() - timeout;
42 ESP_LOGD(TAG, "[%u] msg sent: %i", millis(), timeout);
43}
44
45void LightWaveRF::print_msg_(uint8_t *msg, uint8_t len) {
46#if ESPHOME_LOG_LEVEL >= ESPHOME_LOG_LEVEL_DEBUG
47 char buffer[65]; // max 10 entries * 6 chars + null
48 ESP_LOGD(TAG, " Received code (len:%i): ", len);
49
50 size_t pos = 0;
51 for (int i = 0; i < len; i++) {
52 pos = buf_append_printf(buffer, sizeof(buffer), pos, "0x%02x, ", msg[i]);
53 }
54 ESP_LOGD(TAG, "[%s]", buffer);
55#endif
56}
57
59 ESP_LOGCONFIG(TAG, "Lightwave RF:");
60 LOG_PIN(" Pin TX: ", this->pin_tx_);
61 LOG_PIN(" Pin RX: ", this->pin_rx_);
62 LOG_UPDATE_INTERVAL(this);
63}
64} // namespace esphome::lightwaverf
65
66#endif
void print_msg_(uint8_t *msg, uint8_t len)
void send_rx(const std::vector< uint8_t > &msg, uint8_t repeats, bool inverted, int u_sec)
void lwrx_setup(InternalGPIOPin *pin)
Set things up to receive LightWaveRF 434Mhz messages pin must be 2 or 3 to trigger interrupts !...
Definition LwRx.cpp:320
bool lwrx_message()
Test if a message has arrived.
Definition LwRx.cpp:175
bool lwrx_getmessage(uint8_t *buf, uint8_t len)
Transfer a message to user buffer.
Definition LwRx.cpp:184
void lwtx_setup(InternalGPIOPin *pin, uint8_t repeats, bool inverted, int u_sec)
Set things up to transmit LightWaveRF 434Mhz messages.
Definition LwTx.cpp:152
void lwtx_send(const std::vector< uint8_t > &msg)
Send a LightwaveRF message (10 nibbles in bytes)
Definition LwTx.cpp:109
bool lwtx_free()
Check for send free.
Definition LwTx.cpp:104
std::string size_t len
size_t size_t pos
Definition helpers.h:1038
void HOT delay(uint32_t ms)
Definition hal.cpp:85
uint32_t IRAM_ATTR HOT millis()
Definition hal.cpp:28
static void uint32_t