mirror of
https://github.com/esphome/esphome.git
synced 2024-12-31 18:01:45 +01:00
[gree] Add support for YX1FF remote (#7298)
Some checks failed
CI / Test split components (push) Blocked by required conditions
CI / Create common environment (push) Waiting to run
CI / Check black (push) Blocked by required conditions
CI / Check flake8 (push) Blocked by required conditions
CI / Check pylint (push) Blocked by required conditions
CI / Check pyupgrade (push) Blocked by required conditions
CI / Run script/ci-custom (push) Blocked by required conditions
CI / Run pytest (macOS-latest, 3.11) (push) Blocked by required conditions
CI / Run pytest (ubuntu-latest, 3.10) (push) Blocked by required conditions
CI / Run pytest (ubuntu-latest, 3.11) (push) Blocked by required conditions
CI / Run pytest (ubuntu-latest, 3.12) (push) Blocked by required conditions
CI / Run pytest (ubuntu-latest, 3.9) (push) Blocked by required conditions
CI / Run pytest (windows-latest, 3.11) (push) Blocked by required conditions
CI / Check clang-format (push) Blocked by required conditions
CI / Run script/clang-tidy for ESP32 Arduino 1/4 (push) Blocked by required conditions
CI / Run script/clang-tidy for ESP32 Arduino 2/4 (push) Blocked by required conditions
CI / Run script/clang-tidy for ESP32 Arduino 3/4 (push) Blocked by required conditions
CI / Run script/clang-tidy for ESP32 Arduino 4/4 (push) Blocked by required conditions
CI / Run script/clang-tidy for ESP32 IDF (push) Blocked by required conditions
CI / Run script/clang-tidy for ESP8266 (push) Blocked by required conditions
CI / list-components (push) Blocked by required conditions
CI / Component test ${{ matrix.file }} (push) Blocked by required conditions
CI / Split components for testing into 20 groups maximum (push) Blocked by required conditions
CI / CI Status (push) Blocked by required conditions
YAML lint / yamllint (push) Waiting to run
CI for docker images / Build docker containers (aarch64, docker) (push) Has been cancelled
CI for docker images / Build docker containers (aarch64, ha-addon) (push) Has been cancelled
CI for docker images / Build docker containers (aarch64, lint) (push) Has been cancelled
CI for docker images / Build docker containers (amd64, docker) (push) Has been cancelled
CI for docker images / Build docker containers (amd64, ha-addon) (push) Has been cancelled
CI for docker images / Build docker containers (amd64, lint) (push) Has been cancelled
CI for docker images / Build docker containers (armv7, docker) (push) Has been cancelled
CI for docker images / Build docker containers (armv7, ha-addon) (push) Has been cancelled
CI for docker images / Build docker containers (armv7, lint) (push) Has been cancelled
Some checks failed
CI / Test split components (push) Blocked by required conditions
CI / Create common environment (push) Waiting to run
CI / Check black (push) Blocked by required conditions
CI / Check flake8 (push) Blocked by required conditions
CI / Check pylint (push) Blocked by required conditions
CI / Check pyupgrade (push) Blocked by required conditions
CI / Run script/ci-custom (push) Blocked by required conditions
CI / Run pytest (macOS-latest, 3.11) (push) Blocked by required conditions
CI / Run pytest (ubuntu-latest, 3.10) (push) Blocked by required conditions
CI / Run pytest (ubuntu-latest, 3.11) (push) Blocked by required conditions
CI / Run pytest (ubuntu-latest, 3.12) (push) Blocked by required conditions
CI / Run pytest (ubuntu-latest, 3.9) (push) Blocked by required conditions
CI / Run pytest (windows-latest, 3.11) (push) Blocked by required conditions
CI / Check clang-format (push) Blocked by required conditions
CI / Run script/clang-tidy for ESP32 Arduino 1/4 (push) Blocked by required conditions
CI / Run script/clang-tidy for ESP32 Arduino 2/4 (push) Blocked by required conditions
CI / Run script/clang-tidy for ESP32 Arduino 3/4 (push) Blocked by required conditions
CI / Run script/clang-tidy for ESP32 Arduino 4/4 (push) Blocked by required conditions
CI / Run script/clang-tidy for ESP32 IDF (push) Blocked by required conditions
CI / Run script/clang-tidy for ESP8266 (push) Blocked by required conditions
CI / list-components (push) Blocked by required conditions
CI / Component test ${{ matrix.file }} (push) Blocked by required conditions
CI / Split components for testing into 20 groups maximum (push) Blocked by required conditions
CI / CI Status (push) Blocked by required conditions
YAML lint / yamllint (push) Waiting to run
CI for docker images / Build docker containers (aarch64, docker) (push) Has been cancelled
CI for docker images / Build docker containers (aarch64, ha-addon) (push) Has been cancelled
CI for docker images / Build docker containers (aarch64, lint) (push) Has been cancelled
CI for docker images / Build docker containers (amd64, docker) (push) Has been cancelled
CI for docker images / Build docker containers (amd64, ha-addon) (push) Has been cancelled
CI for docker images / Build docker containers (amd64, lint) (push) Has been cancelled
CI for docker images / Build docker containers (armv7, docker) (push) Has been cancelled
CI for docker images / Build docker containers (armv7, ha-addon) (push) Has been cancelled
CI for docker images / Build docker containers (armv7, lint) (push) Has been cancelled
This commit is contained in:
parent
29f0b504b9
commit
3b14b0efce
3 changed files with 66 additions and 6 deletions
|
@ -1,6 +1,6 @@
|
||||||
import esphome.codegen as cg
|
import esphome.codegen as cg
|
||||||
import esphome.config_validation as cv
|
|
||||||
from esphome.components import climate_ir
|
from esphome.components import climate_ir
|
||||||
|
import esphome.config_validation as cv
|
||||||
from esphome.const import CONF_ID, CONF_MODEL
|
from esphome.const import CONF_ID, CONF_MODEL
|
||||||
|
|
||||||
CODEOWNERS = ["@orestismers"]
|
CODEOWNERS = ["@orestismers"]
|
||||||
|
@ -17,6 +17,7 @@ MODELS = {
|
||||||
"yaa": Model.GREE_YAA,
|
"yaa": Model.GREE_YAA,
|
||||||
"yac": Model.GREE_YAC,
|
"yac": Model.GREE_YAC,
|
||||||
"yac1fb9": Model.GREE_YAC1FB9,
|
"yac1fb9": Model.GREE_YAC1FB9,
|
||||||
|
"yx1ff": Model.GREE_YX1FF,
|
||||||
}
|
}
|
||||||
|
|
||||||
CONFIG_SCHEMA = climate_ir.CLIMATE_IR_WITH_RECEIVER_SCHEMA.extend(
|
CONFIG_SCHEMA = climate_ir.CLIMATE_IR_WITH_RECEIVER_SCHEMA.extend(
|
||||||
|
|
|
@ -6,7 +6,15 @@ namespace gree {
|
||||||
|
|
||||||
static const char *const TAG = "gree.climate";
|
static const char *const TAG = "gree.climate";
|
||||||
|
|
||||||
void GreeClimate::set_model(Model model) { this->model_ = model; }
|
void GreeClimate::set_model(Model model) {
|
||||||
|
if (model == GREE_YX1FF) {
|
||||||
|
this->fan_modes_.insert(climate::CLIMATE_FAN_QUIET); // YX1FF 4 speed
|
||||||
|
this->presets_.insert(climate::CLIMATE_PRESET_NONE); // YX1FF sleep mode
|
||||||
|
this->presets_.insert(climate::CLIMATE_PRESET_SLEEP); // YX1FF sleep mode
|
||||||
|
}
|
||||||
|
|
||||||
|
this->model_ = model;
|
||||||
|
}
|
||||||
|
|
||||||
void GreeClimate::transmit_state() {
|
void GreeClimate::transmit_state() {
|
||||||
uint8_t remote_state[8] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00};
|
uint8_t remote_state[8] = {0x00, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00};
|
||||||
|
@ -14,7 +22,7 @@ void GreeClimate::transmit_state() {
|
||||||
remote_state[0] = this->fan_speed_() | this->operation_mode_();
|
remote_state[0] = this->fan_speed_() | this->operation_mode_();
|
||||||
remote_state[1] = this->temperature_();
|
remote_state[1] = this->temperature_();
|
||||||
|
|
||||||
if (this->model_ == GREE_YAN) {
|
if (this->model_ == GREE_YAN || this->model_ == GREE_YX1FF) {
|
||||||
remote_state[2] = 0x60;
|
remote_state[2] = 0x60;
|
||||||
remote_state[3] = 0x50;
|
remote_state[3] = 0x50;
|
||||||
remote_state[4] = this->vertical_swing_();
|
remote_state[4] = this->vertical_swing_();
|
||||||
|
@ -36,8 +44,18 @@ void GreeClimate::transmit_state() {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (this->model_ == GREE_YX1FF) {
|
||||||
|
if (this->fan_speed_() == GREE_FAN_TURBO) {
|
||||||
|
remote_state[2] |= GREE_FAN_TURBO_BIT;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (this->preset_() == GREE_PRESET_SLEEP) {
|
||||||
|
remote_state[0] |= GREE_PRESET_SLEEP_BIT;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Calculate the checksum
|
// Calculate the checksum
|
||||||
if (this->model_ == GREE_YAN) {
|
if (this->model_ == GREE_YAN || this->model_ == GREE_YX1FF) {
|
||||||
remote_state[7] = ((remote_state[0] << 4) + (remote_state[1] << 4) + 0xC0);
|
remote_state[7] = ((remote_state[0] << 4) + (remote_state[1] << 4) + 0xC0);
|
||||||
} else {
|
} else {
|
||||||
remote_state[7] =
|
remote_state[7] =
|
||||||
|
@ -124,6 +142,23 @@ uint8_t GreeClimate::operation_mode_() {
|
||||||
}
|
}
|
||||||
|
|
||||||
uint8_t GreeClimate::fan_speed_() {
|
uint8_t GreeClimate::fan_speed_() {
|
||||||
|
// YX1FF has 4 fan speeds -- we treat low as quiet and turbo as high
|
||||||
|
if (this->model_ == GREE_YX1FF) {
|
||||||
|
switch (this->fan_mode.value()) {
|
||||||
|
case climate::CLIMATE_FAN_QUIET:
|
||||||
|
return GREE_FAN_1;
|
||||||
|
case climate::CLIMATE_FAN_LOW:
|
||||||
|
return GREE_FAN_2;
|
||||||
|
case climate::CLIMATE_FAN_MEDIUM:
|
||||||
|
return GREE_FAN_3;
|
||||||
|
case climate::CLIMATE_FAN_HIGH:
|
||||||
|
return GREE_FAN_TURBO;
|
||||||
|
case climate::CLIMATE_FAN_AUTO:
|
||||||
|
default:
|
||||||
|
return GREE_FAN_AUTO;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
switch (this->fan_mode.value()) {
|
switch (this->fan_mode.value()) {
|
||||||
case climate::CLIMATE_FAN_LOW:
|
case climate::CLIMATE_FAN_LOW:
|
||||||
return GREE_FAN_1;
|
return GREE_FAN_1;
|
||||||
|
@ -161,5 +196,21 @@ uint8_t GreeClimate::temperature_() {
|
||||||
return (uint8_t) roundf(clamp<float>(this->target_temperature, GREE_TEMP_MIN, GREE_TEMP_MAX));
|
return (uint8_t) roundf(clamp<float>(this->target_temperature, GREE_TEMP_MIN, GREE_TEMP_MAX));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
uint8_t GreeClimate::preset_() {
|
||||||
|
// YX1FF has sleep preset
|
||||||
|
if (this->model_ == GREE_YX1FF) {
|
||||||
|
switch (this->preset.value()) {
|
||||||
|
case climate::CLIMATE_PRESET_NONE:
|
||||||
|
return GREE_PRESET_NONE;
|
||||||
|
case climate::CLIMATE_PRESET_SLEEP:
|
||||||
|
return GREE_PRESET_SLEEP;
|
||||||
|
default:
|
||||||
|
return GREE_PRESET_NONE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return GREE_PRESET_NONE;
|
||||||
|
}
|
||||||
|
|
||||||
} // namespace gree
|
} // namespace gree
|
||||||
} // namespace esphome
|
} // namespace esphome
|
||||||
|
|
|
@ -25,7 +25,6 @@ const uint8_t GREE_FAN_AUTO = 0x00;
|
||||||
const uint8_t GREE_FAN_1 = 0x10;
|
const uint8_t GREE_FAN_1 = 0x10;
|
||||||
const uint8_t GREE_FAN_2 = 0x20;
|
const uint8_t GREE_FAN_2 = 0x20;
|
||||||
const uint8_t GREE_FAN_3 = 0x30;
|
const uint8_t GREE_FAN_3 = 0x30;
|
||||||
const uint8_t GREE_FAN_TURBO = 0x80;
|
|
||||||
|
|
||||||
// IR Transmission
|
// IR Transmission
|
||||||
const uint32_t GREE_IR_FREQUENCY = 38000;
|
const uint32_t GREE_IR_FREQUENCY = 38000;
|
||||||
|
@ -70,8 +69,16 @@ const uint8_t GREE_HDIR_MIDDLE = 0x04;
|
||||||
const uint8_t GREE_HDIR_MRIGHT = 0x05;
|
const uint8_t GREE_HDIR_MRIGHT = 0x05;
|
||||||
const uint8_t GREE_HDIR_RIGHT = 0x06;
|
const uint8_t GREE_HDIR_RIGHT = 0x06;
|
||||||
|
|
||||||
|
// Only available on YX1FF
|
||||||
|
// Turbo (high) fan mode + sleep preset mode
|
||||||
|
const uint8_t GREE_FAN_TURBO = 0x80;
|
||||||
|
const uint8_t GREE_FAN_TURBO_BIT = 0x10;
|
||||||
|
const uint8_t GREE_PRESET_NONE = 0x00;
|
||||||
|
const uint8_t GREE_PRESET_SLEEP = 0x01;
|
||||||
|
const uint8_t GREE_PRESET_SLEEP_BIT = 0x80;
|
||||||
|
|
||||||
// Model codes
|
// Model codes
|
||||||
enum Model { GREE_GENERIC, GREE_YAN, GREE_YAA, GREE_YAC, GREE_YAC1FB9 };
|
enum Model { GREE_GENERIC, GREE_YAN, GREE_YAA, GREE_YAC, GREE_YAC1FB9, GREE_YX1FF };
|
||||||
|
|
||||||
class GreeClimate : public climate_ir::ClimateIR {
|
class GreeClimate : public climate_ir::ClimateIR {
|
||||||
public:
|
public:
|
||||||
|
@ -93,6 +100,7 @@ class GreeClimate : public climate_ir::ClimateIR {
|
||||||
uint8_t horizontal_swing_();
|
uint8_t horizontal_swing_();
|
||||||
uint8_t vertical_swing_();
|
uint8_t vertical_swing_();
|
||||||
uint8_t temperature_();
|
uint8_t temperature_();
|
||||||
|
uint8_t preset_();
|
||||||
|
|
||||||
Model model_{};
|
Model model_{};
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in a new issue