This commit is contained in:
		
							parent
							
								
									36510ace7a
								
							
						
					
					
						commit
						4e3800e332
					
				
					 2 changed files with 26 additions and 10 deletions
				
			
		| 
						 | 
					@ -1,11 +1,10 @@
 | 
				
			||||||
#include "Weather.h"
 | 
					#include "Weather.h"
 | 
				
			||||||
#include "../SevenSegment.h"
 | 
					#include "../SevenSegment.h"
 | 
				
			||||||
#include "../Icons.h"
 | 
					#include "../Icons.h"
 | 
				
			||||||
#include <Fonts/FreeSans9pt7b.h>
 | 
					#include <Fonts/FreeSans12pt7b.h>
 | 
				
			||||||
#include <Fonts/FreeMonoBold9pt7b.h>
 | 
					 | 
				
			||||||
#include <Fonts/FreeMonoBold12pt7b.h>
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
RTC_DATA_ATTR uint64_t WatchFacePages::Weather::m_lastSyncTime = 0;
 | 
					RTC_DATA_ATTR uint64_t WatchFacePages::Weather::m_lastSyncTime = 0;
 | 
				
			||||||
 | 
					RTC_DATA_ATTR int WatchFacePages::Weather::m_lastCalculatedDay = 0XFFFFFFFF;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
WatchFacePages::Weather::Weather(WatchyDisplay & display, WatchFeatures::WatchFeatures & features)
 | 
					WatchFacePages::Weather::Weather(WatchyDisplay & display, WatchFeatures::WatchFeatures & features)
 | 
				
			||||||
  : m_display(display), m_features(features)
 | 
					  : m_display(display), m_features(features)
 | 
				
			||||||
| 
						 | 
					@ -24,18 +23,34 @@ void WatchFacePages::Weather::DrawPage(bool partialRefresh)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
  m_display.setFullWindow();
 | 
					  m_display.setFullWindow();
 | 
				
			||||||
  m_display.fillScreen(GxEPD_WHITE);
 | 
					  m_display.fillScreen(GxEPD_WHITE);
 | 
				
			||||||
  m_display.display(partialRefresh);
 | 
					  m_display.setTextColor(GxEPD_BLACK);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if (m_lastSyncTime == 0) {
 | 
				
			||||||
 | 
					    m_display.setFont(&FreeSans12pt7b);
 | 
				
			||||||
 | 
					    int16_t x, y;
 | 
				
			||||||
 | 
					    uint16_t w, h;
 | 
				
			||||||
 | 
					    m_display.getTextBounds("Have not synced", 0, 0, &x, &y, &w, &h);
 | 
				
			||||||
 | 
					    m_display.setCursor(DISPLAY_WIDTH / 2 - w / 2, 110);
 | 
				
			||||||
 | 
					    m_display.print("Have not synced");
 | 
				
			||||||
 | 
					    m_display.display(partialRefresh);
 | 
				
			||||||
 | 
					    return;
 | 
				
			||||||
 | 
					  } else if (m_features.rtc.GetTimestamp() - m_lastSyncTime > 86400) {
 | 
				
			||||||
 | 
					    m_display.setFont(&FreeSans12pt7b);
 | 
				
			||||||
 | 
					    m_display.setCursor(20, 110);
 | 
				
			||||||
 | 
					    m_display.print("Last sync > 1 day");
 | 
				
			||||||
 | 
					    m_display.display(partialRefresh);
 | 
				
			||||||
 | 
					    return;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void WatchFacePages::Weather::Resync()
 | 
					void WatchFacePages::Weather::Resync()
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
 | 
					  uint64_t currentTime = m_features.rtc.GetTimestamp();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  if(m_lastSyncTime == 0 || currentTime - m_lastSyncTime > WEATHER_UPDATE_INTERVAL) {
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  // if(!m_features.wifi.Connect()) {
 | 
					  // if(!m_features.wifi.Connect()) {
 | 
				
			||||||
  //   return;
 | 
					  //   return;
 | 
				
			||||||
  // }
 | 
					  // }
 | 
				
			||||||
 | 
					 | 
				
			||||||
  // uint64_t currentTime = m_features.rtc.GetTimestamp();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  // if(m_lastSyncTime == 0 || m_lastSyncTime + 60 * 60 * 1000 < millis()) {
 | 
					 | 
				
			||||||
  //   m_lastSyncTime = millis();
 | 
					 | 
				
			||||||
  // }
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
| 
						 | 
					@ -25,4 +25,5 @@ private:
 | 
				
			||||||
  WatchyDisplay & m_display;
 | 
					  WatchyDisplay & m_display;
 | 
				
			||||||
  WatchFeatures::WatchFeatures & m_features;
 | 
					  WatchFeatures::WatchFeatures & m_features;
 | 
				
			||||||
  static RTC_DATA_ATTR uint64_t m_lastSyncTime;
 | 
					  static RTC_DATA_ATTR uint64_t m_lastSyncTime;
 | 
				
			||||||
 | 
					  static RTC_DATA_ATTR int m_lastCalculatedDay;
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue