int mm_app_tc_capture_burst(mm_camera_app_t *cam_app) { int rc = MM_CAMERA_OK; int i, j; mm_camera_test_obj_t test_obj; uint8_t num_snapshot = 3; uint8_t num_rcvd_snapshot = 0; printf("\n Verifying capture...\n"); for (i = 0; i < cam_app->num_cameras; i++) { memset(&test_obj, 0, sizeof(mm_camera_test_obj_t)); rc = mm_app_open(cam_app, i, &test_obj); if (rc != MM_CAMERA_OK) { CDBG_ERROR("%s:mm_app_open() cam_idx=%d, err=%d\n", __func__, i, rc); break; } for (j = 0; j < MM_QCAMERA_APP_UTEST_INNER_LOOP; j++) { rc = mm_app_start_capture(&test_obj, num_snapshot); if (rc != MM_CAMERA_OK) { CDBG_ERROR("%s: mm_app_start_capture() cam_idx=%d, err=%d\n", __func__, i, rc); break; } while (num_rcvd_snapshot < num_snapshot) { mm_camera_app_wait(); num_rcvd_snapshot++; } rc = mm_app_stop_capture(&test_obj); if (rc != MM_CAMERA_OK) { CDBG_ERROR("%s: mm_app_stop_capture() cam_idx=%d, err=%d\n", __func__, i, rc); break; } } rc = mm_app_close(&test_obj); if (rc != MM_CAMERA_OK) { CDBG_ERROR("%s:mm_app_close() cam_idx=%d, err=%d\n", __func__, i, rc); break; } } if (rc == MM_CAMERA_OK) { printf("\nPassed\n"); } else { printf("\nFailed\n"); } CDBG("%s:END, rc = %d\n", __func__, rc); return rc; }
int mm_app_take_picture(mm_camera_test_obj_t *test_obj, uint8_t is_burst_mode) { LOGH("\nEnter %s!!\n"); int rc = MM_CAMERA_OK; uint8_t num_snapshot = 1; int num_rcvd_snapshot = 0; if (is_burst_mode) num_snapshot = 6; //stop preview before starting capture. rc = mm_app_stop_preview(test_obj); if (rc != MM_CAMERA_OK) { LOGE(" stop preview failed before capture!!, err=%d\n", rc); return rc; } rc = mm_app_start_capture(test_obj, num_snapshot); if (rc != MM_CAMERA_OK) { LOGE(" mm_app_start_capture(), err=%d\n", rc); return rc; } while (num_rcvd_snapshot < num_snapshot) { LOGH("\nWaiting mm_camera_app_wait !!\n"); mm_camera_app_wait(); num_rcvd_snapshot++; } rc = mm_app_stop_capture(test_obj); if (rc != MM_CAMERA_OK) { LOGE(" mm_app_stop_capture(), err=%d\n", rc); return rc; } //start preview after capture. rc = mm_app_start_preview(test_obj); if (rc != MM_CAMERA_OK) { LOGE(" start preview failed after capture!!, err=%d\n",rc); } return rc; }