From a35817e716e9c28f7b5468a66c5f6862f76a21f4 Mon Sep 17 00:00:00 2001 From: Owen Date: Mon, 28 Sep 2020 20:32:12 +0200 Subject: [PATCH] Less flashy notification LED, face recognition stubs --- app_httpd.cpp | 37 ++++++--------------------- esp32-cam-webserver.ino | 1 + index_ov2640.h | 4 +-- index_ov3660.h | 55 ++++++++++++++++++++++++++++++++++++++--- storage.cpp | 13 ++++++++++ storage.h | 4 +++ 6 files changed, 79 insertions(+), 35 deletions(-) diff --git a/app_httpd.cpp b/app_httpd.cpp index 623abb3..d9efeca 100644 --- a/app_httpd.cpp +++ b/app_httpd.cpp @@ -529,7 +529,7 @@ static esp_err_t cmd_handler(httpd_req_t *req){ httpd_resp_send_404(req); return ESP_FAIL; } - + int val = atoi(value); sensor_t * s = esp_camera_sensor_get(); int res = 0; @@ -577,6 +577,12 @@ static esp_err_t cmd_handler(httpd_req_t *req){ lampVal = constrain(val,0,100); setLamp(lampVal); } + else if(!strcmp(variable, "save_face")) { + if (filesystem) saveFaceDB(SPIFFS); + } + else if(!strcmp(variable, "clear_face")) { + if (filesystem) removeFaceDB(SPIFFS); + } else if(!strcmp(variable, "save_prefs")) { if (filesystem) savePrefs(SPIFFS); } @@ -607,7 +613,6 @@ static esp_err_t status_handler(httpd_req_t *req){ static char json_response[1024]; sensor_t * s = esp_camera_sensor_get(); char * p = json_response; - flashLED(75); *p++ = '{'; p+=sprintf(p, "\"lamp\":%d,", lampVal); p+=sprintf(p, "\"framesize\":%u,", s->status.framesize); @@ -650,7 +655,6 @@ static esp_err_t status_handler(httpd_req_t *req){ } static esp_err_t info_handler(httpd_req_t *req){ - flashLED(75); static char json_response[256]; char * p = json_response; *p++ = '{'; @@ -666,49 +670,23 @@ static esp_err_t info_handler(httpd_req_t *req){ } static esp_err_t favicon_16x16_handler(httpd_req_t *req){ - flashLED(75); httpd_resp_set_type(req, "image/png"); httpd_resp_set_hdr(req, "Content-Encoding", "identity"); return httpd_resp_send(req, (const char *)favicon_16x16_png, favicon_16x16_png_len); } static esp_err_t favicon_32x32_handler(httpd_req_t *req){ - httpd_resp_set_type(req, "image/png"); httpd_resp_set_hdr(req, "Content-Encoding", "identity"); return httpd_resp_send(req, (const char *)favicon_32x32_png, favicon_32x32_png_len); } static esp_err_t favicon_ico_handler(httpd_req_t *req){ - flashLED(75); httpd_resp_set_type(req, "image/x-icon"); httpd_resp_set_hdr(req, "Content-Encoding", "identity"); return httpd_resp_send(req, (const char *)favicon_ico, favicon_ico_len); } -static esp_err_t save_prefs_handler(httpd_req_t *req){ - flashLED(75); - savePrefs(SPIFFS); - httpd_resp_set_type(req, "text/css"); - httpd_resp_set_hdr(req, "Content-Encoding", "identity"); - char resp[] = "Preferences saved"; - return httpd_resp_send(req, resp, strlen(resp)); -} - -static esp_err_t remove_prefs_handler(httpd_req_t *req){ - flashLED(75); - httpd_resp_set_type(req, "text/css"); - httpd_resp_set_hdr(req, "Content-Encoding", "identity"); - if (filesystem) { - removePrefs(SPIFFS); - char resp[] = "Preferences file removed, reboot will revert to default settings"; - return httpd_resp_send(req, resp, strlen(resp)); - } else { - char resp[] = "No internal filesystem; save/restore functions disabled"; - return httpd_resp_send(req, resp, strlen(resp)); - } -} - // DEBUG extern void dumpPrefs(fs::FS &fs); static esp_err_t dump_prefs_handler(httpd_req_t *req){ @@ -724,7 +702,6 @@ static esp_err_t dump_prefs_handler(httpd_req_t *req){ static esp_err_t style_handler(httpd_req_t *req){ - flashLED(75); httpd_resp_set_type(req, "text/css"); httpd_resp_set_hdr(req, "Content-Encoding", "identity"); return httpd_resp_send(req, (const char *)style_css, style_css_len); diff --git a/esp32-cam-webserver.ino b/esp32-cam-webserver.ino index 8cf1736..e4003dd 100644 --- a/esp32-cam-webserver.ino +++ b/esp32-cam-webserver.ino @@ -360,6 +360,7 @@ void setup() { if (filesystem) { filesystemStart(); loadPrefs(SPIFFS); + loadFaceDB(SPIFFS); } else { Serial.println("No Internal Filesystem, cannot save preferences or face DB"); } diff --git a/index_ov2640.h b/index_ov2640.h index 0876e69..5633ce9 100644 --- a/index_ov2640.h +++ b/index_ov2640.h @@ -322,8 +322,8 @@ const uint8_t index_ov2640_html[] = R"=====( const recognize = document.getElementById('face_recognize') const framesize = document.getElementById('framesize') const swapButton = document.getElementById('swap-viewer') - const saveFaceButton = document.getElementById('save_face') - const clearFaceButton = document.getElementById('clear_face') + // const saveFaceButton = document.getElementById('save_face') + // const clearFaceButton = document.getElementById('clear_face') const savePrefsButton = document.getElementById('save_prefs') const clearPrefsButton = document.getElementById('clear_prefs') const rebootButton = document.getElementById('reboot') diff --git a/index_ov3660.h b/index_ov3660.h index 70126b3..c31d64b 100644 --- a/index_ov3660.h +++ b/index_ov3660.h @@ -272,9 +272,20 @@ const uint8_t index_ov3660_html[] = R"=====( -
- -
+
+ + + +
+
+ + + + +
@@ -324,6 +335,11 @@ const uint8_t index_ov3660_html[] = R"=====( const recognize = document.getElementById('face_recognize') const framesize = document.getElementById('framesize') const swapButton = document.getElementById('swap-viewer') + // const saveFaceButton = document.getElementById('save_face') + // const clearFaceButton = document.getElementById('clear_face') + const savePrefsButton = document.getElementById('save_prefs') + const clearPrefsButton = document.getElementById('clear_prefs') + const rebootButton = document.getElementById('reboot') const hide = el => { el.classList.add('hidden') @@ -489,6 +505,7 @@ const uint8_t index_ov3660_html[] = R"=====( // Attach actions to controls streamLink.onclick = () => { + stopStream(); window.open(streamURL + "view", "_blank"); } @@ -598,6 +615,38 @@ const uint8_t index_ov3660_html[] = R"=====( swapButton.onclick = () => { window.open('/view','_self'); } + +// saveFaceButton.onclick = () => { +// if (confirm("Saving the current face database?")) { +// updateConfig(saveFaceButton); +// } +// } + +// clearFaceButton.onclick = () => { +// if (confirm("Removing the face database?")) { +// updateConfig(clearFaceButton); +// } +// } + + savePrefsButton.onclick = () => { + if (confirm("Save the current preferences?")) { + updateConfig(savePrefsButton); + } + } + + clearPrefsButton.onclick = () => { + if (confirm("Remove the saved preferences?")) { + updateConfig(clearPrefsButton); + } + } + + rebootButton.onclick = () => { + if (confirm("Reboot the Camera Module?")) { + updateConfig(rebootButton); + // Some sort of countdown here? + location.reload(); + } + } }) diff --git a/storage.cpp b/storage.cpp index 17f4175..20e2cc5 100644 --- a/storage.cpp +++ b/storage.cpp @@ -170,6 +170,19 @@ void removePrefs(fs::FS &fs) { } } +void saveFaceDB(fs::FS &fs) { + // Stub! + return; +} +void loadFaceDB(fs::FS &fs) { + // Stub! + return; +} +void removeFaceDB(fs::FS &fs) { + // Stub! + return; +} + void filesystemStart(){ while ( !SPIFFS.begin(FORMAT_SPIFFS_IF_FAILED) ) { // if we sit in this loop something is wrong; diff --git a/storage.h b/storage.h index 7fa5871..dfcb998 100644 --- a/storage.h +++ b/storage.h @@ -9,4 +9,8 @@ extern void loadPrefs(fs::FS &fs); extern void removePrefs(fs::FS &fs); extern void savePrefs(fs::FS &fs); +extern void loadFaceDB(fs::FS &fs); +extern void removeFaceDB(fs::FS &fs); +extern void saveFaceDB(fs::FS &fs); + extern void filesystemStart();