server_camera.cpp 8.8 KB

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