mirror of
				https://github.com/esphome/esphome.git
				synced 2025-10-30 22:53:59 +00:00 
			
		
		
		
	feat: integrate RealTimeClock into DynamicLampComponent for enhanced time management
This commit is contained in:
		| @@ -1,5 +1,6 @@ | ||||
| import esphome.codegen as cg | ||||
| from esphome.components import output | ||||
| from esphome.components.time import RealTimeClock | ||||
| import esphome.config_validation as cv | ||||
| from esphome.const import CONF_ID | ||||
|  | ||||
| @@ -10,17 +11,22 @@ dynamic_lamp_ns = cg.esphome_ns.namespace('dynamic_lamp') | ||||
| DynamicLampComponent = dynamic_lamp_ns.class_('DynamicLampComponent', cg.Component) | ||||
| CONF_DYNAMIC_LAMP_ID = "dynamic_lamp_id" | ||||
|  | ||||
| CONF_RTC = 'rtc' | ||||
| CONF_SAVE_MODE = 'save_mode' | ||||
| CONF_AVAILABLE_OUTPUTS = 'available_outputs' | ||||
| CONFIG_SCHEMA = cv.Schema({ | ||||
|     cv.GenerateID(CONF_ID): cv.declare_id(DynamicLampComponent), | ||||
|     cv.Required(CONF_RTC): cv.use_id(RealTimeClock), | ||||
|     cv.Required(CONF_AVAILABLE_OUTPUTS): [cv.use_id(output.FloatOutput)], | ||||
|     cv.Optional(CONF_SAVE_MODE, default=0): cv.int_range(0, 1), | ||||
| }).extend(cv.COMPONENT_SCHEMA) | ||||
|  | ||||
|  | ||||
| async def to_code(config): | ||||
|     var = cg.new_Pvariable(config[CONF_ID]) | ||||
|     var = cg.new_Pvariable( | ||||
|         config[CONF_ID], | ||||
|         await cg.get_variable(config[CONF_RTC]), | ||||
|     ) | ||||
|     await cg.register_component(var, config) | ||||
|     for outputPointer in config.get(CONF_AVAILABLE_OUTPUTS, []): | ||||
|         idstr_ = str(outputPointer) | ||||
|   | ||||
| @@ -244,7 +244,7 @@ bool DynamicLampComponent::add_timer(std::string lamp_name, bool timer_active, u | ||||
|   new_timer.friday = friday; | ||||
|   new_timer.saturday = saturday; | ||||
|   new_timer.sunday = sunday; | ||||
|   ESPTime now = this->time_->now(); | ||||
|   ESPTime now = this->rtc_->now(); | ||||
|   time_t begin_date = now.to_time_t(); | ||||
|   time_t end_date = now.increment_days(1).to_time_t(); | ||||
|   new_timer.begin_date = begin_date; | ||||
|   | ||||
| @@ -80,14 +80,15 @@ struct DynamicLampTimer { | ||||
|   bool saturday : 1; | ||||
|   bool sunday : 1; | ||||
|   unsigned char :0; | ||||
|   ESPTime begin_date : 64; | ||||
|   ESPTime end_date : 64; | ||||
|   time_t begin_date : 64; | ||||
|   time_t end_date : 64; | ||||
| }; | ||||
|  | ||||
| class DynamicLamp; | ||||
|  | ||||
| class DynamicLampComponent : public Component { | ||||
|  public: | ||||
|   explicit DynamicLampComponent(time::RealTimeClock *rtc) : rtc_(rtc) {} | ||||
|   void setup() override; | ||||
|   void loop() override; | ||||
|   void dump_config() override; | ||||
| @@ -107,6 +108,7 @@ class DynamicLampComponent : public Component { | ||||
|  | ||||
|  protected: | ||||
|   friend class DynamicLamp; | ||||
|   time::RealTimeClock *rtc_; | ||||
|   void restore_lamp_values_(uint8_t lamp_number); | ||||
|   void set_lamp_values_(uint8_t lamp_number, bool active, uint16_t selected_outputs, uint8_t mode, uint8_t mode_value); | ||||
|   bool write_state_(uint8_t lamp_number, float state); | ||||
| @@ -115,6 +117,7 @@ class DynamicLampComponent : public Component { | ||||
|   LinkedOutput available_outputs_[16]; | ||||
|   uint8_t save_mode_; | ||||
|   uint8_t lamp_count_ = 0; | ||||
|  | ||||
| }; | ||||
|  | ||||
|  | ||||
|   | ||||
		Reference in New Issue
	
	Block a user