From d0abbade1ecae715a0729bdcab4e65b8efb7e30c Mon Sep 17 00:00:00 2001 From: GrKoR Date: Sat, 7 May 2022 16:12:07 +0300 Subject: [PATCH] =?UTF-8?q?=D0=BE=D1=81=D0=BE=D0=B1=D0=B5=D0=BD=D0=BD?= =?UTF-8?q?=D0=BE=D1=81=D1=82=D0=B8=20=D1=80=D0=B0=D0=B1=D0=BE=D1=82=D1=8B?= =?UTF-8?q?=20=D0=B4=D0=B8=D1=81=D0=BF=D0=BB=D0=B5=D1=8F=20Fixes=20#31?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README-EN.md | 5 ++-- README.md | 5 ++-- components/aux_ac/aux_ac.h | 39 +++++++++++++++++++++++++------- components/aux_ac/climate.py | 3 +++ examples/advanced/ac_common.yaml | 1 + tests/test-ext.yaml | 1 + 6 files changed, 42 insertions(+), 12 deletions(-) diff --git a/README-EN.md b/README-EN.md index 2a0ca72..a3d8633 100644 --- a/README-EN.md +++ b/README-EN.md @@ -123,12 +123,13 @@ climate: - **name** (**Required**, string): The name of the climate device. At least one of `id` or `name` is required! - **id** (*Optional*, [ID](https://esphome.io/guides/configuration-types.html#config-id)): Manually specify the ID used for code generation. At least one of `id` or `name` is required! - **uart_id** (*Optional*, [ID](https://esphome.io/guides/configuration-types.html#config-id)): Manually specify the ID of the [UART Bus](https://esphome.io/components/uart.html) if you want to use multiple UART buses. -- **period** (*Optional*, [time](https://esphome.io/guides/configuration-types.html#config-time)): Period between status requests to the AC. Defaults to ``7s``. `Aux_ac` will receive the new air conditioner status only after a regular request, even if you change the settings of AC using IR-remote. -- **show_action** (*Optional*, boolean): Whether to show current action of the device (experimental). For example in the HEAT-COOL mode AC hardware may be in one of the following actions: +- **period** (*Optional*, [time](https://esphome.io/guides/configuration-types.html#config-time), default ``7s``): Period between status requests to the AC. `Aux_ac` will receive the new air conditioner status only after a regular request, even if you change the settings of AC using IR-remote. +- **show_action** (*Optional*, boolean, default ``true``): Whether to show current action of the device (experimental). For example in the HEAT-COOL mode AC hardware may be in one of the following actions: - HEATING: AC is heating the air in the room; - IDLE: AC is working in the FAN mode cause the target temperature is reached; - COOLING: AC is cooling the air. The same thing will be in HEAT or COOL modes, with the only difference of the list of actions (IDLE + HEATING or IDLE + COOLING). + - **display_inverted** (*Optional*, boolean, default ``false``): It configures display driver logic level. As it turned out in the issue [#31](https://github.com/GrKoR/esphome_aux_ac_component/issues/31), different models of conditioners manage display different way. Rovex ACs powers off display by bit `1` in command packet and power it on by bit `0`. Many other conditioners do this vice versa. - **indoor_temperature** (*Optional*): The information for the air temperature sensor - **name** (**Required**, string): The name for the temperature sensor. - **id** (*Optional*, [ID](https://esphome.io/guides/configuration-types.html#config-id)): Set the ID of this sensor for use in lambdas. diff --git a/README.md b/README.md index 26dc263..cf6c2d8 100644 --- a/README.md +++ b/README.md @@ -125,12 +125,13 @@ climate: - **name** (**Обязательный**, строка): Имя кондиционера. Как минимум один из параметров `id` или `name` должен быть указан! - **id** (*Опциональный*, [ID](https://esphome.io/guides/configuration-types.html#config-id)): Укажите идентификатор кондиционера чтобы обращаться к нему из кода. Как минимум один из параметров `id` или `name` должен быть указан! - **uart_id** (*Опциональный*, [ID](https://esphome.io/guides/configuration-types.html#config-id)): Укажите ID [шины UART](https://esphome.io/components/uart.html), к которой подключен кондиционер. Если сконфигурирована одна шина, то компонент подключит её автоматически. Если шин несколько, то лучше указать вручную. -- **period** (*Опциональный*, [время](https://esphome.io/guides/configuration-types.html#config-time)): Период между запросами статуса кондиционера. По умолчанию ``7s``. `Aux_ac` получает новое состояние кондиционера только после регулярного запроса, потому что сам кондиционер об изменении параметров своеё работы не уведомляет. Поэтому нужно запрашивать его, вдруг пользователь установил иной режим работы с помощью ИК-пульта. -- **show_action** (*Опциональный*, логическое): Показывать ли текущую задачу кондиционера (экспериментальная функция). Например, в режиме HEAT-COOL кондиционер может выполнять одну из следующих задач: +- **period** (*Опциональный*, [время](https://esphome.io/guides/configuration-types.html#config-time), по умолчанию ``7s``): Период между запросами статуса кондиционера. `Aux_ac` получает новое состояние кондиционера только после регулярного запроса, потому что сам кондиционер об изменении параметров своеё работы не уведомляет. Поэтому нужно запрашивать его, вдруг пользователь установил иной режим работы с помощью ИК-пульта. +- **show_action** (*Опциональный*, логическое, по умолчанию ``true``): Показывать ли текущую задачу кондиционера (экспериментальная функция). Например, в режиме HEAT-COOL кондиционер может выполнять одну из следующих задач: - НАГРЕВ: нагревает воздух в комнате; - ПРОСТОЙ: кондиционер работает в режиме вентилятора для перемешивания воздуха в комнате, поскольку целевая температура уже достигнута; - ОХЛАЖДЕНИЕ: кондиционер охлаждает воздух в комнате. Аналогично будут отображаться действия кондиционера и для режимов ОТОПЛЕНИЕ и ОХЛАЖДЕНИЕ. Единственная разница будет в количестве действий: ПРОСТОЙ+НАГРЕВ для режима отопления и ПРОСТОЙ+ОХЛАЖДЕНИЕ для режима охлаждения комнаты. +- **display_inverted** (*Опциональный*, логическое, по умолчанию ``false``): Настраивает способ управления дисплеем. Как выяснилось (issue [#31](https://github.com/GrKoR/esphome_aux_ac_component/issues/31)), включение-выключение дисплея обрабатывается кондиционерами по разному. Кондиционеры Rovex включают дисплей по `0` в соответствующем бите команды и выключают по биту `1`. Многие другие модели кондиционеров поступают наоборот. - **indoor_temperature** (*Опциональный*): Параметры создаваемого датчика температуры воздуха, если такой датчик нужен - **name** (**Обязательный**, строка): Имя датчика температуры. - **id** (*Опциональный*, [ID](https://esphome.io/guides/configuration-types.html#config-id)): Можно указать свой ID для датчика для использования в лямбдах. diff --git a/components/aux_ac/aux_ac.h b/components/aux_ac/aux_ac.h index 4de777d..c4fe321 100644 --- a/components/aux_ac/aux_ac.h +++ b/components/aux_ac/aux_ac.h @@ -469,6 +469,11 @@ class AirCon : public esphome::Component, public esphome::climate::Climate { // по дефолту показываем bool _show_action = true; + // как отрабатывается включание-выключение дисплея. + // если тут false, то 1 в соответствующем бите включает дисплей, а 0 выключает. + // если тут true, то 1 потушит дисплей, а 0 включит. + bool _display_inverted = false; + // поддерживаемые кондиционером опции std::set _supported_modes{}; std::set _supported_swing_modes{}; @@ -1858,11 +1863,19 @@ class AirCon : public esphome::Component, public esphome::climate::Climate { if (sensor_display_ != nullptr) switch (_current_ac_state.display) { case AC_DISPLAY_ON: - sensor_display_->publish_state(true); + if (this->get_display_inverted()) { + sensor_display_->publish_state(false); + } else { + sensor_display_->publish_state(true); + } break; case AC_DISPLAY_OFF: - sensor_display_->publish_state(false); + if (this->get_display_inverted()) { + sensor_display_->publish_state(true); + } else { + sensor_display_->publish_state(false); + } break; default: @@ -1877,6 +1890,7 @@ class AirCon : public esphome::Component, public esphome::climate::Climate { ESP_LOGCONFIG(Constants::TAG, " [x] Firmware version: %s", Constants::AC_FIRMWARE_VERSION.c_str()); ESP_LOGCONFIG(Constants::TAG, " [x] Period: %dms", this->get_period()); ESP_LOGCONFIG(Constants::TAG, " [x] Show action: %s", this->get_show_action() ? "true" : "false"); + ESP_LOGCONFIG(Constants::TAG, " [x] Display inverted: %s", this->get_display_inverted() ? "true" : "false"); if ((this->sensor_indoor_temperature_) != nullptr) { ESP_LOGCONFIG(Constants::TAG, "%s%s '%s'", " ", LOG_STR_LITERAL("Indoor Temperature"), (this->sensor_indoor_temperature_)->get_name().c_str()); if (!(this->sensor_indoor_temperature_)->get_device_class().empty()) { @@ -2407,18 +2421,27 @@ class AirCon : public esphome::Component, public esphome::climate::Climate { // выключает экран bool displayOffSequence(){ - return displaySequence(AC_DISPLAY_OFF); + ac_display dsp = AC_DISPLAY_OFF; + if (this->get_display_inverted()) dsp = AC_DISPLAY_ON; + return displaySequence(dsp); } // включает экран bool displayOnSequence(){ - return displaySequence(AC_DISPLAY_ON); + ac_display dsp = AC_DISPLAY_ON; + if (this->get_display_inverted()) dsp = AC_DISPLAY_OFF; + return displaySequence(dsp); } - void set_period(uint32_t ms) { this->_update_period = ms; }; - uint32_t get_period() { return this->_update_period; }; - void set_show_action(bool show_action) { this->_show_action = show_action; }; - bool get_show_action() {return this->_show_action; }; + void set_period(uint32_t ms) { this->_update_period = ms; } + uint32_t get_period() { return this->_update_period; } + + void set_show_action(bool show_action) { this->_show_action = show_action; } + bool get_show_action() { return this->_show_action; } + + void set_display_inverted(bool display_inverted) { this->_display_inverted = display_inverted; } + bool get_display_inverted() { return this->_display_inverted; } + void set_supported_modes(const std::set &modes) { this->_supported_modes = modes; } void set_supported_swing_modes(const std::set &modes) { this->_supported_swing_modes = modes; } void set_supported_presets(const std::set &presets) { this->_supported_presets = presets; } diff --git a/components/aux_ac/climate.py b/components/aux_ac/climate.py index c781771..532b08a 100644 --- a/components/aux_ac/climate.py +++ b/components/aux_ac/climate.py @@ -35,6 +35,7 @@ CONF_SHOW_ACTION = 'show_action' CONF_INDOOR_TEMPERATURE = 'indoor_temperature' CONF_DISPLAY_STATE = 'display_state' +CONF_DISPLAY_INVERTED = 'display_inverted' ICON_DISPLAY = "mdi:numeric" aux_ac_ns = cg.esphome_ns.namespace("aux_ac") @@ -89,6 +90,7 @@ CONFIG_SCHEMA = cv.All( cv.GenerateID(): cv.declare_id(AirCon), cv.Optional(CONF_PERIOD, default="7s"): cv.time_period, cv.Optional(CONF_SHOW_ACTION, default="true"): cv.boolean, + cv.Optional(CONF_DISPLAY_INVERTED, default="false"): cv.boolean, cv.Optional(CONF_INDOOR_TEMPERATURE): sensor.sensor_schema( unit_of_measurement=UNIT_CELSIUS, icon=ICON_THERMOMETER, @@ -141,6 +143,7 @@ async def to_code(config): cg.add(var.set_period(config[CONF_PERIOD].total_milliseconds)) cg.add(var.set_show_action(config[CONF_SHOW_ACTION])) + cg.add(var.set_display_inverted(config[CONF_DISPLAY_INVERTED])) if CONF_SUPPORTED_MODES in config: cg.add(var.set_supported_modes(config[CONF_SUPPORTED_MODES])) if CONF_SUPPORTED_SWING_MODES in config: diff --git a/examples/advanced/ac_common.yaml b/examples/advanced/ac_common.yaml index b10d636..dcf8048 100644 --- a/examples/advanced/ac_common.yaml +++ b/examples/advanced/ac_common.yaml @@ -63,6 +63,7 @@ climate: uart_id: ac_uart_bus period: 7s show_action: true + display_inverted: true indoor_temperature: name: ${upper_devicename} AC Indoor Temperature id: ${devicename}_indoor_temp diff --git a/tests/test-ext.yaml b/tests/test-ext.yaml index 80a5c23..1211d76 100644 --- a/tests/test-ext.yaml +++ b/tests/test-ext.yaml @@ -56,6 +56,7 @@ climate: uart_id: ac_uart_bus period: 7s # период опроса состояния сплита, по дефолту 7 сек show_action: true # надо ли показывать текущий режим работы: при HEAT_COOL mode сплит может греть (HEAT), охлаждать (COOL) или бездействовать (IDLE) + display_inverted: true # как отрабатывать вкл/выкл дисплея: у Rovex "1" выключает дисплей, у многих других "1" дисплей включает indoor_temperature: # сенсор, показывающий температуру воздуха на внутреннем блоке кондиционера; имеет все те же параметры, как и любой сенсор ESPHome name: AC Indoor Temperature id: ac_indoor_temp