Static Rendering and Clock Improvement

added date to clock and removed all scrolling from weather
This commit is contained in:
Chuck
2025-04-08 18:26:32 -05:00
parent ec11f57375
commit f569881394
3 changed files with 149 additions and 187 deletions

View File

@@ -19,12 +19,8 @@ class DisplayController:
self.weather = WeatherManager(self.config, self.display_manager)
self.current_display = 'clock'
self.last_switch = time.time()
self.scroll_position = 0
self.scroll_speed = 1 # Reduced scroll speed
self.last_scroll = time.time()
self.scroll_interval = 0.2 # Increased scroll interval for smoother scrolling
self.force_clear = True # Start with a clear screen
self.update_interval = 0.1 # Consistent update interval
self.update_interval = 0.5 # Slower updates for better stability
logger.info("DisplayController initialized with display_manager: %s", id(self.display_manager))
def run(self):
@@ -40,7 +36,6 @@ class DisplayController:
self.current_display = 'weather'
elif self.current_display == 'weather':
self.current_display = 'hourly'
self.scroll_position = 0 # Reset scroll position when switching to hourly
elif self.current_display == 'hourly':
self.current_display = 'daily'
else: # daily
@@ -48,20 +43,9 @@ class DisplayController:
logger.info("Switching display to: %s", self.current_display)
self.last_switch = current_time
self.force_clear = True # Clear screen on mode switch
self.force_clear = True
self.display_manager.clear() # Ensure clean transition
# Update scroll position for hourly forecast if needed
if self.current_display == 'hourly' and current_time - self.last_scroll > self.scroll_interval:
self.scroll_position += self.scroll_speed
self.last_scroll = current_time
# Reset scroll position if we've gone through all forecasts
if self.scroll_position > self.display_manager.matrix.width * 3:
self.scroll_position = 0
self.force_clear = True
self.display_manager.clear()
# Display current screen
try:
if self.current_display == 'clock':
@@ -69,7 +53,7 @@ class DisplayController:
elif self.current_display == 'weather':
self.weather.display_weather(force_clear=self.force_clear)
elif self.current_display == 'hourly':
self.weather.display_hourly_forecast(self.scroll_position, force_clear=self.force_clear)
self.weather.display_hourly_forecast(force_clear=self.force_clear)
else: # daily
self.weather.display_daily_forecast(force_clear=self.force_clear)
except Exception as e:
@@ -80,7 +64,7 @@ class DisplayController:
# Reset force clear flag after use
self.force_clear = False
# Consistent sleep time for all modes
# Sleep between updates
time.sleep(self.update_interval)
except KeyboardInterrupt: