2020-03-11 18:24:51 +00:00
|
|
|
/**
|
|
|
|
* espmhp.h
|
|
|
|
*
|
|
|
|
* Header file for esphome-mitsubishiheatpump
|
|
|
|
*
|
2020-07-06 16:29:52 +00:00
|
|
|
* Author: Geoff Davis <geoff@geoffdavis.com>
|
|
|
|
* Author: Phil Genera @pgenera on Github.
|
2021-04-28 17:40:29 +00:00
|
|
|
* Author: @nao-pon on Github
|
2021-05-27 20:38:25 +00:00
|
|
|
* Author: Simon Knopp @sijk on Github
|
2021-06-23 11:35:33 +00:00
|
|
|
* Last Updated: 2021-06-23
|
2020-03-11 18:24:51 +00:00
|
|
|
* License: BSD
|
|
|
|
*
|
|
|
|
* Requirements:
|
2020-03-18 14:44:08 +00:00
|
|
|
* - https://github.com/SwiCago/HeatPump
|
2021-06-23 11:35:33 +00:00
|
|
|
* - ESPHome 1.19.1 or greater
|
2020-03-11 18:24:51 +00:00
|
|
|
*/
|
|
|
|
|
2020-03-18 14:29:30 +00:00
|
|
|
#define USE_CALLBACKS
|
2020-03-11 18:24:51 +00:00
|
|
|
|
2020-03-11 21:51:57 +00:00
|
|
|
#include "esphome.h"
|
2020-06-05 00:26:56 +00:00
|
|
|
#include "esphome/core/preferences.h"
|
|
|
|
|
2020-03-11 18:24:51 +00:00
|
|
|
#include "HeatPump.h"
|
2020-03-11 21:51:57 +00:00
|
|
|
using namespace esphome;
|
|
|
|
|
|
|
|
#ifndef ESPMHP_H
|
|
|
|
#define ESPMHP_H
|
2020-03-11 18:24:51 +00:00
|
|
|
|
2020-03-11 21:51:57 +00:00
|
|
|
static const char* TAG = "MitsubishiHeatPump"; // Logging tag
|
2020-03-11 18:24:51 +00:00
|
|
|
|
2022-11-01 05:38:38 +00:00
|
|
|
static const char* ESPMHP_VERSION = "2.4.1";
|
2020-03-11 18:24:51 +00:00
|
|
|
|
|
|
|
/* If polling interval is greater than 9 seconds, the HeatPump
|
|
|
|
library reconnects, but doesn't then follow up with our data request.*/
|
2020-03-18 14:29:30 +00:00
|
|
|
static const uint32_t ESPMHP_POLL_INTERVAL_DEFAULT = 500; // in milliseconds,
|
2020-03-11 18:24:51 +00:00
|
|
|
// 0 < X <= 9000
|
|
|
|
static const uint8_t ESPMHP_MIN_TEMPERATURE = 16; // degrees C,
|
|
|
|
// defined by hardware
|
|
|
|
static const uint8_t ESPMHP_MAX_TEMPERATURE = 31; // degrees C,
|
|
|
|
//defined by hardware
|
2020-06-03 03:37:10 +00:00
|
|
|
static const float ESPMHP_TEMPERATURE_STEP = 0.5; // temperature setting step,
|
2020-03-11 18:24:51 +00:00
|
|
|
// in degrees C
|
|
|
|
|
|
|
|
class MitsubishiHeatPump : public PollingComponent, public climate::Climate {
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a new MitsubishiHeatPump object
|
|
|
|
*
|
|
|
|
* Args:
|
|
|
|
* hw_serial: pointer to an Arduino HardwareSerial instance
|
|
|
|
* poll_interval: polling interval in milliseconds
|
|
|
|
*/
|
|
|
|
MitsubishiHeatPump(
|
2020-03-11 21:51:57 +00:00
|
|
|
HardwareSerial* hw_serial,
|
|
|
|
uint32_t poll_interval=ESPMHP_POLL_INTERVAL_DEFAULT
|
|
|
|
);
|
2020-03-11 18:24:51 +00:00
|
|
|
|
|
|
|
// Print a banner with library information.
|
|
|
|
void banner() {
|
|
|
|
ESP_LOGI(TAG, "ESPHome MitsubishiHeatPump version %s",
|
|
|
|
ESPMHP_VERSION);
|
2020-03-11 21:51:57 +00:00
|
|
|
}
|
2020-03-11 18:24:51 +00:00
|
|
|
|
2021-05-26 09:20:11 +00:00
|
|
|
// Set the baud rate. Must be called before setup() to have any effect.
|
|
|
|
void set_baud_rate(int);
|
|
|
|
|
2020-03-11 18:24:51 +00:00
|
|
|
// print the current configuration
|
|
|
|
void dump_config() override;
|
|
|
|
|
|
|
|
// handle a change in settings as detected by the HeatPump library.
|
|
|
|
void hpSettingsChanged();
|
|
|
|
|
|
|
|
// Handle a change in status as detected by the HeatPump library.
|
|
|
|
void hpStatusChanged(heatpumpStatus currentStatus);
|
|
|
|
|
|
|
|
// Set up the component, initializing the HeatPump object.
|
|
|
|
void setup() override;
|
|
|
|
|
|
|
|
// This is called every poll_interval.
|
|
|
|
void update() override;
|
|
|
|
|
|
|
|
// Configure the climate object with traits that we support.
|
|
|
|
climate::ClimateTraits traits() override;
|
|
|
|
|
2021-05-26 08:56:57 +00:00
|
|
|
// Get a mutable reference to the traits that we support.
|
|
|
|
climate::ClimateTraits& config_traits();
|
|
|
|
|
2020-03-11 18:24:51 +00:00
|
|
|
// Debugging function to print the object's state.
|
|
|
|
void dump_state();
|
|
|
|
|
|
|
|
// Handle a request from the user to change settings.
|
|
|
|
void control(const climate::ClimateCall &call) override;
|
2021-05-28 04:43:08 +00:00
|
|
|
|
|
|
|
// Use the temperature from an external sensor. Use
|
2021-05-27 22:53:19 +00:00
|
|
|
// set_remote_temp(0) to switch back to the internal sensor.
|
|
|
|
void set_remote_temperature(float);
|
2020-03-11 18:24:51 +00:00
|
|
|
|
|
|
|
protected:
|
|
|
|
// HeatPump object using the underlying Arduino library.
|
|
|
|
HeatPump* hp;
|
|
|
|
|
2021-05-26 08:56:57 +00:00
|
|
|
// The ClimateTraits supported by this HeatPump.
|
|
|
|
climate::ClimateTraits traits_;
|
|
|
|
|
2020-03-11 18:24:51 +00:00
|
|
|
// Allow the HeatPump class to use get_hw_serial_
|
|
|
|
friend class HeatPump;
|
|
|
|
|
|
|
|
//Accessor method for the HardwareSerial pointer
|
|
|
|
HardwareSerial* get_hw_serial_() {
|
|
|
|
return this->hw_serial_;
|
|
|
|
}
|
|
|
|
|
|
|
|
//Print a warning message if we're using the sole hardware UART on an
|
|
|
|
//ESP8266 or UART0 on ESP32
|
|
|
|
void check_logger_conflict_();
|
|
|
|
|
2020-06-05 00:26:56 +00:00
|
|
|
// various prefs to save mode-specific temperatures, akin to how the IR
|
|
|
|
// remote works.
|
|
|
|
ESPPreferenceObject cool_storage;
|
|
|
|
ESPPreferenceObject heat_storage;
|
|
|
|
ESPPreferenceObject auto_storage;
|
|
|
|
|
|
|
|
optional<float> cool_setpoint;
|
|
|
|
optional<float> heat_setpoint;
|
|
|
|
optional<float> auto_setpoint;
|
|
|
|
|
|
|
|
static void save(float value, ESPPreferenceObject& storage);
|
|
|
|
static optional<float> load(ESPPreferenceObject& storage);
|
|
|
|
|
2020-03-11 18:24:51 +00:00
|
|
|
private:
|
|
|
|
// Retrieve the HardwareSerial pointer from friend and subclasses.
|
2020-03-11 21:51:57 +00:00
|
|
|
HardwareSerial *hw_serial_;
|
2021-05-26 09:20:11 +00:00
|
|
|
int baud_ = 0;
|
2020-03-11 18:24:51 +00:00
|
|
|
};
|
2020-03-11 21:51:57 +00:00
|
|
|
|
|
|
|
#endif
|