/*
* Copyright (C) 2015 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
//#define LOG_NDEBUG 0
#define LOG_TAG "NdkCameraCaptureSession"
#define ATRACE_TAG ATRACE_TAG_CAMERA
#include <utils/Log.h>
#include <utils/Mutex.h>
#include <utils/StrongPointer.h>
#include <utils/Trace.h>
#include <camera/NdkCameraDevice.h>
#include <camera/NdkCaptureRequest.h>
#include <camera/NdkCameraCaptureSession.h>
#include "impl/ACameraCaptureSession.h"
#include "impl/ACameraCaptureSession.inc"
using namespace android;
EXPORT
void ACameraCaptureSession_close(ACameraCaptureSession* session) {
ATRACE_CALL();
if (session != nullptr) {
session->closeByApp();
}
return;
}
EXPORT
camera_status_t ACameraCaptureSession_getDevice(
ACameraCaptureSession* session, ACameraDevice **device) {
ATRACE_CALL();
if (session == nullptr || device == nullptr) {
ALOGE("%s: Error: invalid input: session %p, device %p",
__FUNCTION__, session, device);
return ACAMERA_ERROR_INVALID_PARAMETER;
}
if (session->isClosed()) {
ALOGE("%s: session %p is already closed", __FUNCTION__, session);
*device = nullptr;
return ACAMERA_ERROR_SESSION_CLOSED;
}
*device = session->getDevice();
if (*device == nullptr) {
// Should not reach here
ALOGE("%s: unknown failure: device is null", __FUNCTION__);
return ACAMERA_ERROR_UNKNOWN;
}
return ACAMERA_OK;
}
EXPORT
camera_status_t ACameraCaptureSession_capture(
ACameraCaptureSession* session, /*optional*/ACameraCaptureSession_captureCallbacks* cbs,
int numRequests, ACaptureRequest** requests,
/*optional*/int* captureSequenceId) {
ATRACE_CALL();
if (session == nullptr || requests == nullptr || numRequests < 1) {
ALOGE("%s: Error: invalid input: session %p, numRequest %d, requests %p",
__FUNCTION__, session, numRequests, requests);
return ACAMERA_ERROR_INVALID_PARAMETER;
}
if (session->isClosed()) {
ALOGE("%s: session %p is already closed", __FUNCTION__, session);
if (captureSequenceId != nullptr) {
*captureSequenceId = CAPTURE_SEQUENCE_ID_NONE;
}
return ACAMERA_ERROR_SESSION_CLOSED;
}
return session->capture(
cbs, numRequests, requests, captureSequenceId);
}
EXPORT
camera_status_t ACameraCaptureSession_logicalCamera_capture(
ACameraCaptureSession* session,
/*optional*/ACameraCaptureSession_logicalCamera_captureCallbacks* lcbs,
int numRequests, ACaptureRequest** requests,
/*optional*/int* captureSequenceId) {
ATRACE_CALL();
if (session == nullptr || requests == nullptr || numRequests < 1) {
ALOGE("%s: Error: invalid input: session %p, numRequest %d, requests %p",
__FUNCTION__, session, numRequests, requests);
return ACAMERA_ERROR_INVALID_PARAMETER;
}
if (session->isClosed()) {
ALOGE("%s: session %p is already closed", __FUNCTION__, session);
if (captureSequenceId) {
*captureSequenceId = CAPTURE_SEQUENCE_ID_NONE;
}
return ACAMERA_ERROR_SESSION_CLOSED;
}
return session->capture(
lcbs, numRequests, requests, captureSequenceId);
}
EXPORT
camera_status_t ACameraCaptureSession_setRepeatingRequest(
ACameraCaptureSession* session, /*optional*/ACameraCaptureSession_captureCallbacks* cbs,
int numRequests, ACaptureRequest** requests,
/*optional*/int* captureSequenceId) {
ATRACE_CALL();
if (session == nullptr || requests == nullptr || numRequests < 1) {
ALOGE("%s: Error: invalid input: session %p, numRequest %d, requests %p",
__FUNCTION__, session, numRequests, requests);
return ACAMERA_ERROR_INVALID_PARAMETER;
}
if (session->isClosed()) {
ALOGE("%s: session %p is already closed", __FUNCTION__, session);
if (captureSequenceId) {
*captureSequenceId = CAPTURE_SEQUENCE_ID_NONE;
}
return ACAMERA_ERROR_SESSION_CLOSED;
}
return session->setRepeatingRequest(cbs, numRequests, requests, captureSequenceId);
}
EXPORT
camera_status_t ACameraCaptureSession_logicalCamera_setRepeatingRequest(
ACameraCaptureSession* session,
/*optional*/ACameraCaptureSession_logicalCamera_captureCallbacks* lcbs,
int numRequests, ACaptureRequest** requests,
/*optional*/int* captureSequenceId) {
ATRACE_CALL();
if (session == nullptr || requests == nullptr || numRequests < 1) {
ALOGE("%s: Error: invalid input: session %p, numRequest %d, requests %p",
__FUNCTION__, session, numRequests, requests);
return ACAMERA_ERROR_INVALID_PARAMETER;
}
if (session->isClosed()) {
ALOGE("%s: session %p is already closed", __FUNCTION__, session);
if (captureSequenceId) {
*captureSequenceId = CAPTURE_SEQUENCE_ID_NONE;
}
return ACAMERA_ERROR_SESSION_CLOSED;
}
return session->setRepeatingRequest(lcbs, numRequests, requests, captureSequenceId);
}
EXPORT
camera_status_t ACameraCaptureSession_stopRepeating(ACameraCaptureSession* session) {
ATRACE_CALL();
if (session == nullptr) {
ALOGE("%s: Error: session is null", __FUNCTION__);
return ACAMERA_ERROR_INVALID_PARAMETER;
}
if (session->isClosed()) {
ALOGE("%s: session %p is already closed", __FUNCTION__, session);
return ACAMERA_ERROR_SESSION_CLOSED;
}
return session->stopRepeating();
}
EXPORT
camera_status_t ACameraCaptureSession_abortCaptures(ACameraCaptureSession* session) {
ATRACE_CALL();
if (session == nullptr) {
ALOGE("%s: Error: session is null", __FUNCTION__);
return ACAMERA_ERROR_INVALID_PARAMETER;
}
if (session->isClosed()) {
ALOGE("%s: session %p is already closed", __FUNCTION__, session);
return ACAMERA_ERROR_SESSION_CLOSED;
}
return session->abortCaptures();
}
EXPORT
camera_status_t ACameraCaptureSession_updateSharedOutput(ACameraCaptureSession* session,
ACaptureSessionOutput* output) {
ATRACE_CALL();
if (session == nullptr) {
ALOGE("%s: Error: session is null", __FUNCTION__);
return ACAMERA_ERROR_INVALID_PARAMETER;
}
if (session->isClosed()) {
ALOGE("%s: session %p is already closed", __FUNCTION__, session);
return ACAMERA_ERROR_SESSION_CLOSED;
}
return session->updateOutputConfiguration(output);
}