Fixed oobe crash

This commit is contained in:
fvanroie 2020-04-08 13:50:27 +02:00
parent 54127235c9
commit ea8d55a0a7

View File

@ -55,55 +55,36 @@ static void peek_password_cb(lv_obj_t * obj, lv_event_t event)
static void kb_event_cb(lv_obj_t * event_kb, lv_event_t event) static void kb_event_cb(lv_obj_t * event_kb, lv_event_t event)
{ {
if(event == LV_EVENT_APPLY) { if(event == LV_EVENT_APPLY) {
DynamicJsonDocument settings(256);
char ssid[32]; char ssid[32];
char pass[32]; char pass[32];
lv_obj_t * obj;
DynamicJsonDocument settings(256); obj = hasp_find_obj_from_id(oobepage[1], 10);
if(obj) {
lv_obj_t * child; strncpy(ssid, lv_textarea_get_text(obj), sizeof(ssid));
child = lv_obj_get_child(oobepage[1], NULL);
while(child) {
if(child->user_data) {
lv_obj_user_data_t objid = 10;
if(objid == child->user_data) {
strncpy(ssid, lv_textarea_get_text(child), sizeof(ssid));
settings[FPSTR(F_CONFIG_SSID)] = ssid; settings[FPSTR(F_CONFIG_SSID)] = ssid;
if(oobekb != NULL) lv_keyboard_set_textarea(oobekb, child); if(oobekb != NULL) lv_keyboard_set_textarea(oobekb, obj);
}
objid = 20;
if(objid == child->user_data) {
strncpy(pass, lv_textarea_get_text(child), sizeof(pass));
settings[FPSTR(F_CONFIG_PASS)] = pass;
}
} }
/* next sibling */ obj = hasp_find_obj_from_id(oobepage[1], 20);
child = lv_obj_get_child(oobepage[1], child); if(obj) {
strncpy(pass, lv_textarea_get_text(obj), sizeof(pass));
settings[FPSTR(F_CONFIG_PASS)] = pass;
} }
if(strlen(ssid) > 0) { if(strlen(ssid) > 0) {
wifiSetConfig(settings.as<JsonObject>()); wifiSetConfig(settings.as<JsonObject>());
lv_obj_t * msgb = lv_cont_create(oobepage[1], NULL);
lv_obj_set_size(msgb, 120, 30);
lv_obj_align(msgb, oobepage[1], LV_ALIGN_CENTER, 0, 0);
lv_obj_t * lbl = lv_label_create(msgb, NULL);
char buffer[128];
snprintf(buffer, sizeof(buffer), PSTR("Connecting to %s..."), ssid);
lv_label_set_text(lbl, buffer);
if(wifiTestConnection()) { if(wifiTestConnection()) {
// dispatchReboot(true); dispatchReboot(true);
} }
// lv_obj_del(msgb);
} }
} else if(event == LV_EVENT_CANCEL) { } else if(event == LV_EVENT_CANCEL) {
oobeSetPage(0); oobeSetPage(0);
lv_obj_set_click(lv_disp_get_layer_sys(NULL), true); lv_obj_set_click(lv_disp_get_layer_sys(NULL), true);
} else {
} else {
/* prevent double presses, swipes and ghost press on tiny keyboard */ /* prevent double presses, swipes and ghost press on tiny keyboard */
if(event == LV_EVENT_RELEASED) lv_keyboard_def_event_cb(event_kb, LV_EVENT_VALUE_CHANGED); if(event == LV_EVENT_RELEASED) lv_keyboard_def_event_cb(event_kb, LV_EVENT_VALUE_CHANGED);
/* Just call the regular event handler */ /* Just call the regular event handler */
@ -120,18 +101,17 @@ static void ta_event_cb(lv_obj_t * ta, lv_event_t event)
else if(event == LV_EVENT_INSERT) { else if(event == LV_EVENT_INSERT) {
const char * str = (const char *)lv_event_get_data(); const char * str = (const char *)lv_event_get_data();
if(str[0] == '\n') { if(str[0] == '\n') {
lv_obj_t * child; lv_obj_t * obj;
child = lv_obj_get_child(oobepage[1], NULL);
while(child) { obj = hasp_find_obj_from_id(oobepage[1], 10);
if(child->user_data && child->user_data > 0 && child->user_data != ta->user_data) { if(ta == obj) { // now ssid, goto pass
if(oobekb != NULL) { obj = hasp_find_obj_from_id(oobepage[1], 20);
lv_keyboard_set_textarea(oobekb, child);
}
} }
/* next sibling */ if(oobekb && obj) {
child = lv_obj_get_child(oobepage[1], child); lv_keyboard_set_textarea(oobekb, obj);
} }
} else { } else {
// printf("%s\n", lv_ta_get_text(ta)); // printf("%s\n", lv_ta_get_text(ta));
} }
@ -155,7 +135,7 @@ static void oobeSetupQR(const char * ssid, const char * pass)
lv_qrcode_update(qr, buffer, strlen(buffer)); lv_qrcode_update(qr, buffer, strlen(buffer));
lv_obj_t * qrlabel = lv_label_create(oobepage[0], NULL); lv_obj_t * qrlabel = lv_label_create(oobepage[0], NULL);
snprintf(buffer, sizeof(buffer), PSTR("Scan to connect:")); snprintf(buffer, sizeof(buffer), PSTR("Scan to connect"));
lv_label_set_text(qrlabel, buffer); lv_label_set_text(qrlabel, buffer);
if(disp->driver.hor_res <= disp->driver.ver_res) { if(disp->driver.hor_res <= disp->driver.ver_res) {
@ -174,7 +154,7 @@ static void oobeSetupQR(const char * ssid, const char * pass)
#endif #endif
lv_obj_t * aplabel = lv_label_create(container, NULL); lv_obj_t * aplabel = lv_label_create(container, NULL);
snprintf(buffer, sizeof(buffer), PSTR("Tap the screen to setup WiFi or\nconnect to this Access Point:")); snprintf(buffer, sizeof(buffer), PSTR("Tap the screen to setup WiFi or connect to this Access Point:"));
lv_label_set_text(aplabel, buffer); lv_label_set_text(aplabel, buffer);
lv_label_set_long_mode(aplabel, LV_LABEL_LONG_BREAK); lv_label_set_long_mode(aplabel, LV_LABEL_LONG_BREAK);
@ -206,7 +186,7 @@ static void oobeSetupSsid(void)
{ {
lv_font_t * defaultfont; lv_font_t * defaultfont;
#if defined(ARDUINO_ARCH_ESP32) #if defined(ARDUINO_ARCH_ESP32)
defaultfont = &lv_font_roboto_12; defaultfont = &lv_font_montserrat_12;
#else #else
defaultfont = LV_FONT_DEFAULT; defaultfont = LV_FONT_DEFAULT;
#endif #endif
@ -227,23 +207,6 @@ static void oobeSetupSsid(void)
labelpos = LV_ALIGN_OUT_LEFT_MID; labelpos = LV_ALIGN_OUT_LEFT_MID;
} }
/*
lv_style_copy(&rel_style, &lv_style_btn_rel);
rel_style.body.radius = 0;
rel_style.body.border.width = 1;
rel_style.text.font = LV_FONT_DEFAULT;
lv_style_copy(&pr_style, &lv_style_btn_pr);
pr_style.body.radius = 0;
pr_style.body.border.width = 1;
rel_style.text.font = LV_FONT_DEFAULT;
*/
// lv_style_list_t * list;
// static lv_style_t robotofont;
// lv_style_init(&robotofont);
// lv_style_set_text_font(&robotofont, LV_STATE_DEFAULT, defaultfont);
oobepage[1] = lv_obj_create(NULL, NULL); oobepage[1] = lv_obj_create(NULL, NULL);
char buffer[32]; char buffer[32];
@ -342,7 +305,6 @@ void oobeSetup()
oobeSetPage(0); oobeSetPage(0);
lv_obj_set_click(lv_disp_get_layer_sys(NULL), true); lv_obj_set_click(lv_disp_get_layer_sys(NULL), true);
lv_obj_set_event_cb(lv_disp_get_layer_sys(NULL), gotoPage1_cb); lv_obj_set_event_cb(lv_disp_get_layer_sys(NULL), gotoPage1_cb);
}
if(oobeAutoCalibrate) { if(oobeAutoCalibrate) {
lv_obj_set_click(lv_disp_get_layer_sys(NULL), true); lv_obj_set_click(lv_disp_get_layer_sys(NULL), true);
@ -351,4 +313,5 @@ void oobeSetup()
} else { } else {
Log.verbose(F("OOBE: Already calibrated")); Log.verbose(F("OOBE: Already calibrated"));
} }
}
} }