From 00d7cd1a03db34f620342ad5bf2da0816074e667 Mon Sep 17 00:00:00 2001 From: Stephan Hadinger Date: Tue, 24 Nov 2020 19:40:03 +0100 Subject: [PATCH] IR fix SAMSUNG_AC --- lib/lib_basic/IRremoteESP8266-2.7.12/src/IRac.cpp | 4 +++- tasmota/xdrv_05_irremote_full.ino | 4 +++- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/lib/lib_basic/IRremoteESP8266-2.7.12/src/IRac.cpp b/lib/lib_basic/IRremoteESP8266-2.7.12/src/IRac.cpp index d71108bb1..ac3503264 100644 --- a/lib/lib_basic/IRremoteESP8266-2.7.12/src/IRac.cpp +++ b/lib/lib_basic/IRremoteESP8266-2.7.12/src/IRac.cpp @@ -2532,9 +2532,11 @@ bool IRac::sendAc(const stdAc::state_t desired, const stdAc::state_t *prev) { case SAMSUNG_AC: { IRSamsungAc ac(_pin, _inverted, _modulation); + bool prev_power = !send.power; + if (prev != NULL) prev_power = prev->power; samsung(&ac, send.power, send.mode, degC, send.fanspeed, send.swingv, send.quiet, send.turbo, send.light, send.filter, send.clean, - send.beep, prev->power); + send.beep, prev_power); break; } #endif // SEND_SAMSUNG_AC diff --git a/tasmota/xdrv_05_irremote_full.ino b/tasmota/xdrv_05_irremote_full.ino index ccf823db7..31a614395 100644 --- a/tasmota/xdrv_05_irremote_full.ino +++ b/tasmota/xdrv_05_irremote_full.ino @@ -162,7 +162,7 @@ uint64_t reverseBitsInBytes64(uint64_t b) { \*********************************************************************************************/ const bool IR_FULL_RCV_SAVE_BUFFER = false; // false = do not use buffer, true = use buffer for decoding -const uint32_t IR_TIME_AVOID_DUPLICATE = 500; // Milliseconds +const uint32_t IR_TIME_AVOID_DUPLICATE = 50; // Milliseconds // Below is from IRrecvDumpV2.ino // As this program is a special purpose capture/decoder, let us use a larger @@ -463,6 +463,7 @@ uint32_t IrRemoteCmndIrHvacJson(void) state.sleep = root.getInt(PSTR(D_JSON_IRHVAC_SLEEP), state.sleep); //if (json[D_JSON_IRHVAC_CLOCK]) { state.clock = json[D_JSON_IRHVAC_CLOCK]; } // not sure it's useful to support 'clock' + if (irrecv != nullptr) { irrecv->disableIRIn(); } if (stateMode == StateModes::SEND_ONLY || stateMode == StateModes::SEND_STORE) { IRac ac(Pin(GPIO_IRSEND)); bool success = ac.sendAc(state, irhvac_stateful && irac_prev_state.protocol == state.protocol ? &irac_prev_state : nullptr); @@ -471,6 +472,7 @@ uint32_t IrRemoteCmndIrHvacJson(void) if (stateMode == StateModes::STORE_ONLY || stateMode == StateModes::SEND_STORE) { // store state in memory irac_prev_state = state; } + if (irrecv != nullptr) { irrecv->enableIRIn(); } Response_P(PSTR("{\"" D_CMND_IRHVAC "\":%s}"), sendACJsonState(state).c_str()); return IE_RESPONSE_PROVIDED;