Files
M5PaperOS/src/systeminit.cpp
2021-03-20 18:00:42 +01:00

228 lines
7.3 KiB
C++

#include "systeminit.h"
#include "epdgui/epdgui.h"
#include "frame/frame.h"
#include "Free_Fonts.h"
#include "global_setting.h"
#include "resources/binaryttf.h"
#include <WiFi.h>
QueueHandle_t xQueue_Info = xQueueCreate(20, sizeof(uint32_t));
void WaitForUser(void) {
SysInit_UpdateInfo("$ERR");
while(1) {
M5.update();
if(M5.BtnP.wasReleased()) {
SysInit_UpdateInfo("$RESUME");
return;
}
}
}
void SysInit_Start(void) {
bool ret = false;
Serial.begin(115200);
Serial.flush();
delay(50);
Serial.print("M5EPD initializing...");
pinMode(M5EPD_EXT_PWR_EN_PIN, OUTPUT);
pinMode(M5EPD_EPD_PWR_EN_PIN, OUTPUT);
pinMode(M5EPD_KEY_RIGHT_PIN, INPUT);
pinMode(M5EPD_KEY_PUSH_PIN, INPUT);
pinMode(M5EPD_KEY_LEFT_PIN, INPUT);
delay(100);
M5.enableEXTPower();
// M5.disableEPDPower();
// delay(500);
M5.enableEPDPower();
delay(1000);
M5.EPD.begin(M5EPD_SCK_PIN, M5EPD_MOSI_PIN, M5EPD_MISO_PIN, M5EPD_CS_PIN, M5EPD_BUSY_PIN);
M5.EPD.Clear(true);
M5.EPD.SetRotation(M5EPD_Driver::ROTATE_90);
M5.TP.SetRotation(GT911::ROTATE_90);
disableCore0WDT();
xTaskCreatePinnedToCore(SysInit_Loading, "SysInit_Loading", 4096, NULL, 1, NULL, 0);
// SysInit_UpdateInfo("Initializing SD card...");
bool is_factory_test;
SPI.begin(14, 13, 12, 4);
ret = SD.begin(4, SPI, 20000000);
if(ret == false) {
is_factory_test = true;
SetInitStatus(0, 0);
// log_e("Failed to initialize SD card.");
// SysInit_UpdateInfo("[ERROR] Failed to initialize SD card.");
// WaitForUser();
} else {
is_factory_test = SD.exists("/__factory_test_flag__");
}
SysInit_UpdateInfo("Initializing Touch pad...");
if(M5.TP.begin(21, 22, 36) != ESP_OK) {
SetInitStatus(1, 0);
log_e("Touch pad initialization failed.");
SysInit_UpdateInfo("[ERROR] Failed to initialize Touch pad.");
WaitForUser();
}
M5.BatteryADCBegin();
LoadSetting();
M5EPD_Canvas _initcanvas(&M5.EPD);
if((!is_factory_test) && SD.exists("/font.ttf")) {
_initcanvas.loadFont("/font.ttf", SD);
SetTTFLoaded(true);
} else {
_initcanvas.loadFont(binaryttf, sizeof(binaryttf));
SetTTFLoaded(false);
is_factory_test = true;
}
if(is_factory_test) {
SysInit_UpdateInfo("$OK");
} else {
SysInit_UpdateInfo("Initializing system...");
}
_initcanvas.createRender(26, 128);
Frame_Main *frame_main = new Frame_Main();
EPDGUI_PushFrame(frame_main);
Frame_FactoryTest *frame_factorytest = new Frame_FactoryTest();
EPDGUI_AddFrame("Frame_FactoryTest", frame_factorytest);
if(!is_factory_test) {
Frame_Settings *frame_setting = new Frame_Settings();
EPDGUI_AddFrame("Frame_Settings", frame_setting);
Frame_Settings_Wallpaper *frame_wallpaper = new Frame_Settings_Wallpaper();
EPDGUI_AddFrame("Frame_Settings_Wallpaper", frame_wallpaper);
Frame_Keyboard *frame_keyboard = new Frame_Keyboard();
EPDGUI_AddFrame("Frame_Keyboard", frame_keyboard);
Frame_WifiScan *frame_wifiscan = new Frame_WifiScan();
EPDGUI_AddFrame("Frame_WifiScan", frame_wifiscan);
Frame_WifiPassword *frame_wifipassword = new Frame_WifiPassword();
EPDGUI_AddFrame("Frame_WifiPassword", frame_wifipassword);
Frame_Lifegame *frame_lifegame = new Frame_Lifegame();
EPDGUI_AddFrame("Frame_Lifegame", frame_lifegame);
Frame_Compare *frame_compare = new Frame_Compare();
EPDGUI_AddFrame("Frame_Compare", frame_compare);
Frame_Home *frame_home = new Frame_Home();
EPDGUI_AddFrame("Frame_Home", frame_home);
if(isWiFiConfiged()) {
SysInit_UpdateInfo("Connect to " + GetWifiSSID() + "...");
WiFi.begin(GetWifiSSID().c_str(), GetWifiPassword().c_str());
uint32_t t = millis();
while (1) {
if(millis() - t > 8000) {
break;
}
if(WiFi.status() == WL_CONNECTED) {
frame_wifiscan->SetConnected(GetWifiSSID(), WiFi.RSSI());
break;
}
}
}
}
log_d("done");
while(uxQueueMessagesWaiting(xQueue_Info));
if(!is_factory_test) {
SysInit_UpdateInfo("$OK");
}
Serial.println("OK");
delay(500);
}
void SysInit_Loading(void *pvParameters) {
const uint16_t kPosy = 548;
const uint8_t *kLD[] = {
ImageResource_loading_01_96x96,
ImageResource_loading_02_96x96,
ImageResource_loading_03_96x96,
ImageResource_loading_04_96x96,
ImageResource_loading_05_96x96,
ImageResource_loading_06_96x96,
ImageResource_loading_07_96x96,
ImageResource_loading_08_96x96,
ImageResource_loading_09_96x96,
ImageResource_loading_10_96x96,
ImageResource_loading_11_96x96,
ImageResource_loading_12_96x96,
ImageResource_loading_13_96x96,
ImageResource_loading_14_96x96,
ImageResource_loading_15_96x96,
ImageResource_loading_16_96x96};
M5EPD_Canvas LoadingIMG(&M5.EPD);
M5EPD_Canvas Info(&M5.EPD);
LoadingIMG.createCanvas(96, 96);
Info.createCanvas(540, 50);
Info.setFreeFont(FF18);
Info.setTextSize(1);
Info.setTextDatum(CC_DATUM);
Info.setTextColor(15);
M5.EPD.WritePartGram4bpp(92, 182, 356, 300, ImageResource_logo_356x300);
M5.EPD.UpdateFull(UPDATE_MODE_GC16);
int i = 0;
char *p;
uint32_t time = 0;
while (1) {
if(millis() - time > 250) {
time = millis();
LoadingIMG.pushImage(0, 0, 96, 96, kLD[i]);
LoadingIMG.pushCanvas(220, kPosy + 80, UPDATE_MODE_DU4);
i++;
if (i == 16) {
i = 0;
}
}
if(xQueueReceive(xQueue_Info, &p, 0)) {
String str(p);
free(p);
if(str.indexOf("$OK") >= 0) {
LoadingIMG.pushImage(0, 0, 96, 96, ImageResource_loading_success_96x96);
LoadingIMG.pushCanvas(220, kPosy + 80, UPDATE_MODE_GL16);
break;
} else if(str.indexOf("$ERR") >= 0) {
LoadingIMG.pushImage(0, 0, 96, 96, ImageResource_loading_error_96x96);
LoadingIMG.pushCanvas(220, kPosy + 80, UPDATE_MODE_GL16);
LoadingIMG.fillCanvas(0);
while(1) {
if(xQueueReceive(xQueue_Info, &p, 0)) {
String str(p);
free(p);
if(str.indexOf("$RESUME") >= 0) {
LoadingIMG.pushCanvas(220, kPosy + 80, UPDATE_MODE_GC16);
break;
}
}
}
} else {
Info.fillCanvas(0);
Info.drawString(str, 270, 20);
Info.pushCanvas(0, kPosy, UPDATE_MODE_DU);
}
}
}
vTaskDelete(NULL);
}
void SysInit_UpdateInfo(String info) {
char *p = (char*)malloc(info.length() + 1);
memcpy(p, info.c_str(), info.length());
p[info.length()] = '\0';
if(xQueueSend(xQueue_Info, &p, 0) == 0) {
free(p);
}
}