server_camera.cpp 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293
  1. #include "server_camera.h"
  2. #include <string>
  3. #include "string.h"
  4. #include "esp_camera.h"
  5. #include "ClassControllCamera.h"
  6. #include "ClassLogFile.h"
  7. #include "esp_log.h"
  8. static const char *TAG = "server_cam";
  9. #define SCRATCH_BUFSIZE2 8192
  10. char scratch2[SCRATCH_BUFSIZE2];
  11. //#define DEBUG_DETAIL_ON
  12. void PowerResetCamera()
  13. {
  14. ESP_LOGD(TAG, "Resetting camera by power down line");
  15. gpio_config_t conf;
  16. conf.intr_type = GPIO_INTR_DISABLE;
  17. conf.pin_bit_mask = 1LL << GPIO_NUM_32;
  18. conf.mode = GPIO_MODE_OUTPUT;
  19. conf.pull_down_en = GPIO_PULLDOWN_DISABLE;
  20. conf.pull_up_en = GPIO_PULLUP_DISABLE;
  21. gpio_config(&conf);
  22. // carefull, logic is inverted compared to reset pin
  23. gpio_set_level(GPIO_NUM_32, 1);
  24. vTaskDelay(1000 / portTICK_PERIOD_MS);
  25. gpio_set_level(GPIO_NUM_32, 0);
  26. vTaskDelay(1000 / portTICK_PERIOD_MS);
  27. }
  28. esp_err_t handler_lightOn(httpd_req_t *req)
  29. {
  30. #ifdef DEBUG_DETAIL_ON
  31. LogFile.WriteHeapInfo("handler_lightOn - Start");
  32. ESP_LOGD(TAG, "handler_lightOn uri: %s", req->uri);
  33. #endif
  34. if (Camera.getCameraInitSuccessful())
  35. {
  36. Camera.LightOnOff(true);
  37. const char* resp_str = (const char*) req->user_ctx;
  38. httpd_resp_send(req, resp_str, strlen(resp_str));
  39. }
  40. else
  41. {
  42. httpd_resp_send_err(req, HTTPD_403_FORBIDDEN, "Camera Light On API not yet initialized. Please retry later...");
  43. return ESP_ERR_NOT_FOUND;
  44. }
  45. #ifdef DEBUG_DETAIL_ON
  46. LogFile.WriteHeapInfo("handler_lightOn - Done");
  47. #endif
  48. return ESP_OK;
  49. }
  50. esp_err_t handler_lightOff(httpd_req_t *req)
  51. {
  52. #ifdef DEBUG_DETAIL_ON
  53. LogFile.WriteHeapInfo("handler_lightOff - Start");
  54. ESP_LOGD(TAG, "handler_lightOff uri: %s", req->uri);
  55. #endif
  56. if (Camera.getCameraInitSuccessful())
  57. {
  58. Camera.LightOnOff(false);
  59. const char* resp_str = (const char*) req->user_ctx;
  60. httpd_resp_send(req, resp_str, strlen(resp_str));
  61. }
  62. else
  63. {
  64. httpd_resp_send_err(req, HTTPD_403_FORBIDDEN, "Camera Light Off API not yet initialized. Please retry later...");
  65. return ESP_ERR_NOT_FOUND;
  66. }
  67. #ifdef DEBUG_DETAIL_ON
  68. LogFile.WriteHeapInfo("handler_lightOff - Done");
  69. #endif
  70. return ESP_OK;
  71. }
  72. esp_err_t handler_capture(httpd_req_t *req)
  73. {
  74. #ifdef DEBUG_DETAIL_ON
  75. LogFile.WriteHeapInfo("handler_capture - Start");
  76. #endif
  77. if (Camera.getCameraInitSuccessful())
  78. {
  79. int quality;
  80. framesize_t res;
  81. Camera.GetCameraParameter(req, quality, res);
  82. #ifdef DEBUG_DETAIL_ON
  83. ESP_LOGD(TAG, "Size: %d, Quality: %d", res, quality);
  84. #endif
  85. Camera.SetQualitySize(quality, res);
  86. esp_err_t result;
  87. result = Camera.CaptureToHTTP(req);
  88. #ifdef DEBUG_DETAIL_ON
  89. LogFile.WriteHeapInfo("handler_capture - Done");
  90. #endif
  91. return result;
  92. }
  93. else
  94. {
  95. httpd_resp_send_err(req, HTTPD_403_FORBIDDEN, "Camera Capture API not yet initialized. Please retry later...");
  96. return ESP_ERR_NOT_FOUND;
  97. }
  98. }
  99. esp_err_t handler_capture_with_ligth(httpd_req_t *req)
  100. {
  101. #ifdef DEBUG_DETAIL_ON
  102. LogFile.WriteHeapInfo("handler_capture_with_ligth - Start");
  103. #endif
  104. if (Camera.getCameraInitSuccessful())
  105. {
  106. char _query[100];
  107. char _delay[10];
  108. int quality;
  109. framesize_t res;
  110. int delay = 2500;
  111. if (httpd_req_get_url_query_str(req, _query, 100) == ESP_OK)
  112. {
  113. ESP_LOGD(TAG, "Query: %s", _query);
  114. if (httpd_query_key_value(_query, "delay", _delay, 10) == ESP_OK)
  115. {
  116. #ifdef DEBUG_DETAIL_ON
  117. ESP_LOGD(TAG, "Delay: %s", _delay);
  118. #endif
  119. delay = atoi(_delay);
  120. if (delay < 0)
  121. delay = 0;
  122. }
  123. }
  124. Camera.GetCameraParameter(req, quality, res);
  125. #ifdef DEBUG_DETAIL_ON
  126. ESP_LOGD(TAG, "Size: %d, Quality: %d", res, quality);
  127. #endif
  128. Camera.SetQualitySize(quality, res);
  129. Camera.LightOnOff(true);
  130. const TickType_t xDelay = delay / portTICK_PERIOD_MS;
  131. vTaskDelay( xDelay );
  132. esp_err_t result;
  133. result = Camera.CaptureToHTTP(req);
  134. Camera.LightOnOff(false);
  135. #ifdef DEBUG_DETAIL_ON
  136. LogFile.WriteHeapInfo("handler_capture_with_ligth - Done");
  137. #endif
  138. return result;
  139. }
  140. else
  141. {
  142. httpd_resp_send_err(req, HTTPD_403_FORBIDDEN, "Camera Capture + flashlight API not yet initialized. Please retry later...");
  143. return ESP_ERR_NOT_FOUND;
  144. }
  145. }
  146. esp_err_t handler_capture_save_to_file(httpd_req_t *req)
  147. {
  148. #ifdef DEBUG_DETAIL_ON
  149. LogFile.WriteHeapInfo("handler_capture_save_to_file - Start");
  150. #endif
  151. if (Camera.getCameraInitSuccessful())
  152. {
  153. char _query[100];
  154. char _delay[10];
  155. int delay = 0;
  156. char filename[100];
  157. std::string fn = "/sdcard/";
  158. int quality;
  159. framesize_t res;
  160. if (httpd_req_get_url_query_str(req, _query, 100) == ESP_OK)
  161. {
  162. ESP_LOGD(TAG, "Query: %s", _query);
  163. if (httpd_query_key_value(_query, "filename", filename, 100) == ESP_OK)
  164. {
  165. fn.append(filename);
  166. #ifdef DEBUG_DETAIL_ON
  167. ESP_LOGD(TAG, "Filename: %s", fn.c_str());
  168. #endif
  169. }
  170. else
  171. fn.append("noname.jpg");
  172. if (httpd_query_key_value(_query, "delay", _delay, 10) == ESP_OK)
  173. {
  174. #ifdef DEBUG_DETAIL_ON
  175. ESP_LOGD(TAG, "Delay: %s", _delay);
  176. #endif
  177. delay = atoi(_delay);
  178. if (delay < 0)
  179. delay = 0;
  180. }
  181. }
  182. else
  183. fn.append("noname.jpg");
  184. Camera.GetCameraParameter(req, quality, res);
  185. #ifdef DEBUG_DETAIL_ON
  186. ESP_LOGD(TAG, "Size: %d, Quality: %d", res, quality);
  187. #endif
  188. Camera.SetQualitySize(quality, res);
  189. esp_err_t result;
  190. result = Camera.CaptureToFile(fn, delay);
  191. const char* resp_str = (const char*) fn.c_str();
  192. httpd_resp_send(req, resp_str, strlen(resp_str));
  193. #ifdef DEBUG_DETAIL_ON
  194. LogFile.WriteHeapInfo("handler_capture_save_to_file - Done");
  195. #endif
  196. return result;
  197. }
  198. else
  199. {
  200. httpd_resp_send_err(req, HTTPD_403_FORBIDDEN, "Camera Capture + save API not yet initialized. Please retry later...");
  201. return ESP_ERR_NOT_FOUND;
  202. }
  203. }
  204. void register_server_camera_uri(httpd_handle_t server)
  205. {
  206. #ifdef DEBUG_DETAIL_ON
  207. ESP_LOGI(TAG, "server_part_camera - Registering URI handlers");
  208. #endif
  209. httpd_uri_t camuri = { };
  210. camuri.method = HTTP_GET;
  211. camuri.uri = "/lighton";
  212. camuri.handler = handler_lightOn;
  213. camuri.user_ctx = (void*) "Light On";
  214. httpd_register_uri_handler(server, &camuri);
  215. camuri.uri = "/lightoff";
  216. camuri.handler = handler_lightOff;
  217. camuri.user_ctx = (void*) "Light Off";
  218. httpd_register_uri_handler(server, &camuri);
  219. camuri.uri = "/capture";
  220. camuri.handler = handler_capture;
  221. camuri.user_ctx = NULL;
  222. httpd_register_uri_handler(server, &camuri);
  223. camuri.uri = "/capture_with_flashlight";
  224. camuri.handler = handler_capture_with_ligth;
  225. camuri.user_ctx = NULL;
  226. httpd_register_uri_handler(server, &camuri);
  227. camuri.uri = "/save";
  228. camuri.handler = handler_capture_save_to_file;
  229. camuri.user_ctx = NULL;
  230. httpd_register_uri_handler(server, &camuri);
  231. }