Loading camera/Android.bp +1 −0 Original line number Diff line number Diff line Loading @@ -43,6 +43,7 @@ cc_library_shared { "ICameraRecordingProxyListener.cpp", "camera2/CaptureRequest.cpp", "camera2/OutputConfiguration.cpp", "camera2/SessionConfiguration.cpp", "camera2/SubmitInfo.cpp", "CameraBase.cpp", "CameraUtils.cpp", Loading camera/aidl/android/hardware/camera2/ICameraDeviceUser.aidl +11 −0 Original line number Diff line number Diff line Loading @@ -19,6 +19,7 @@ package android.hardware.camera2; import android.hardware.camera2.CaptureRequest; import android.hardware.camera2.impl.CameraMetadataNative; import android.hardware.camera2.params.OutputConfiguration; import android.hardware.camera2.params.SessionConfiguration; import android.hardware.camera2.utils.SubmitInfo; import android.view.Surface; Loading Loading @@ -83,6 +84,16 @@ interface ICameraDeviceUser */ void endConfigure(int operatingMode, in CameraMetadataNative sessionParams); /** * Check whether a particular session configuration has camera device * support. * * @param sessionConfiguration Specific session configuration to be verified. * @return true - in case the stream combination is supported. * false - in case there is no device support. */ boolean isSessionConfigurationSupported(in SessionConfiguration sessionConfiguration); void deleteStream(int streamId); /** Loading camera/aidl/android/hardware/camera2/params/SessionConfiguration.aidl 0 → 100644 +20 −0 Original line number Diff line number Diff line /* * Copyright (C) 2018 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. */ package android.hardware.camera2.params; /** @hide */ parcelable SessionConfiguration cpp_header "camera/camera2/SessionConfiguration.h"; camera/camera2/SessionConfiguration.cpp 0 → 100644 +133 −0 Original line number Diff line number Diff line /* ** ** Copyright 2018, 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_TAG "SessionConfiguration" //#define LOG_NDEBUG 0 #include <utils/Log.h> #include <camera/camera2/SessionConfiguration.h> #include <camera/camera2/OutputConfiguration.h> #include <binder/Parcel.h> namespace android { status_t SessionConfiguration::readFromParcel(const android::Parcel* parcel) { status_t err = OK; int operatingMode = 0; if (parcel == nullptr) return BAD_VALUE; if ((err = parcel->readInt32(&operatingMode)) != OK) { ALOGE("%s: Failed to read operating mode from parcel", __FUNCTION__); return err; } int inputWidth = 0; if ((err = parcel->readInt32(&inputWidth)) != OK) { ALOGE("%s: Failed to read input width from parcel", __FUNCTION__); return err; } int inputHeight = 0; if ((err = parcel->readInt32(&inputHeight)) != OK) { ALOGE("%s: Failed to read input height from parcel", __FUNCTION__); return err; } int inputFormat = -1; if ((err = parcel->readInt32(&inputFormat)) != OK) { ALOGE("%s: Failed to read input format from parcel", __FUNCTION__); return err; } std::vector<OutputConfiguration> outputStreams; if ((err = parcel->readParcelableVector(&outputStreams)) != OK) { ALOGE("%s: Failed to read output configurations from parcel", __FUNCTION__); return err; } mOperatingMode = operatingMode; mInputWidth = inputWidth; mInputHeight = inputHeight; mInputFormat = inputFormat; for (auto& stream : outputStreams) { mOutputStreams.push_back(stream); } return err; } status_t SessionConfiguration::writeToParcel(android::Parcel* parcel) const { if (parcel == nullptr) return BAD_VALUE; status_t err = OK; err = parcel->writeInt32(mOperatingMode); if (err != OK) return err; err = parcel->writeInt32(mInputWidth); if (err != OK) return err; err = parcel->writeInt32(mInputHeight); if (err != OK) return err; err = parcel->writeInt32(mInputFormat); if (err != OK) return err; err = parcel->writeParcelableVector(mOutputStreams); if (err != OK) return err; return OK; } bool SessionConfiguration::outputsEqual(const SessionConfiguration& other) const { const std::vector<OutputConfiguration>& otherOutputStreams = other.getOutputConfigurations(); if (mOutputStreams.size() != otherOutputStreams.size()) { return false; } for (size_t i = 0; i < mOutputStreams.size(); i++) { if (mOutputStreams[i] != otherOutputStreams[i]) { return false; } } return true; } bool SessionConfiguration::outputsLessThan(const SessionConfiguration& other) const { const std::vector<OutputConfiguration>& otherOutputStreams = other.getOutputConfigurations(); if (mOutputStreams.size() != otherOutputStreams.size()) { return mOutputStreams.size() < otherOutputStreams.size(); } for (size_t i = 0; i < mOutputStreams.size(); i++) { if (mOutputStreams[i] != otherOutputStreams[i]) { return mOutputStreams[i] < otherOutputStreams[i]; } } return false; } }; // namespace android camera/cameraserver/Android.bp +1 −0 Original line number Diff line number Diff line Loading @@ -29,6 +29,7 @@ cc_binary { "android.hardware.camera.provider@2.4", "android.hardware.camera.device@1.0", "android.hardware.camera.device@3.2", "android.hardware.camera.device@3.4", ], compile_multilib: "32", cflags: [ Loading Loading
camera/Android.bp +1 −0 Original line number Diff line number Diff line Loading @@ -43,6 +43,7 @@ cc_library_shared { "ICameraRecordingProxyListener.cpp", "camera2/CaptureRequest.cpp", "camera2/OutputConfiguration.cpp", "camera2/SessionConfiguration.cpp", "camera2/SubmitInfo.cpp", "CameraBase.cpp", "CameraUtils.cpp", Loading
camera/aidl/android/hardware/camera2/ICameraDeviceUser.aidl +11 −0 Original line number Diff line number Diff line Loading @@ -19,6 +19,7 @@ package android.hardware.camera2; import android.hardware.camera2.CaptureRequest; import android.hardware.camera2.impl.CameraMetadataNative; import android.hardware.camera2.params.OutputConfiguration; import android.hardware.camera2.params.SessionConfiguration; import android.hardware.camera2.utils.SubmitInfo; import android.view.Surface; Loading Loading @@ -83,6 +84,16 @@ interface ICameraDeviceUser */ void endConfigure(int operatingMode, in CameraMetadataNative sessionParams); /** * Check whether a particular session configuration has camera device * support. * * @param sessionConfiguration Specific session configuration to be verified. * @return true - in case the stream combination is supported. * false - in case there is no device support. */ boolean isSessionConfigurationSupported(in SessionConfiguration sessionConfiguration); void deleteStream(int streamId); /** Loading
camera/aidl/android/hardware/camera2/params/SessionConfiguration.aidl 0 → 100644 +20 −0 Original line number Diff line number Diff line /* * Copyright (C) 2018 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. */ package android.hardware.camera2.params; /** @hide */ parcelable SessionConfiguration cpp_header "camera/camera2/SessionConfiguration.h";
camera/camera2/SessionConfiguration.cpp 0 → 100644 +133 −0 Original line number Diff line number Diff line /* ** ** Copyright 2018, 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_TAG "SessionConfiguration" //#define LOG_NDEBUG 0 #include <utils/Log.h> #include <camera/camera2/SessionConfiguration.h> #include <camera/camera2/OutputConfiguration.h> #include <binder/Parcel.h> namespace android { status_t SessionConfiguration::readFromParcel(const android::Parcel* parcel) { status_t err = OK; int operatingMode = 0; if (parcel == nullptr) return BAD_VALUE; if ((err = parcel->readInt32(&operatingMode)) != OK) { ALOGE("%s: Failed to read operating mode from parcel", __FUNCTION__); return err; } int inputWidth = 0; if ((err = parcel->readInt32(&inputWidth)) != OK) { ALOGE("%s: Failed to read input width from parcel", __FUNCTION__); return err; } int inputHeight = 0; if ((err = parcel->readInt32(&inputHeight)) != OK) { ALOGE("%s: Failed to read input height from parcel", __FUNCTION__); return err; } int inputFormat = -1; if ((err = parcel->readInt32(&inputFormat)) != OK) { ALOGE("%s: Failed to read input format from parcel", __FUNCTION__); return err; } std::vector<OutputConfiguration> outputStreams; if ((err = parcel->readParcelableVector(&outputStreams)) != OK) { ALOGE("%s: Failed to read output configurations from parcel", __FUNCTION__); return err; } mOperatingMode = operatingMode; mInputWidth = inputWidth; mInputHeight = inputHeight; mInputFormat = inputFormat; for (auto& stream : outputStreams) { mOutputStreams.push_back(stream); } return err; } status_t SessionConfiguration::writeToParcel(android::Parcel* parcel) const { if (parcel == nullptr) return BAD_VALUE; status_t err = OK; err = parcel->writeInt32(mOperatingMode); if (err != OK) return err; err = parcel->writeInt32(mInputWidth); if (err != OK) return err; err = parcel->writeInt32(mInputHeight); if (err != OK) return err; err = parcel->writeInt32(mInputFormat); if (err != OK) return err; err = parcel->writeParcelableVector(mOutputStreams); if (err != OK) return err; return OK; } bool SessionConfiguration::outputsEqual(const SessionConfiguration& other) const { const std::vector<OutputConfiguration>& otherOutputStreams = other.getOutputConfigurations(); if (mOutputStreams.size() != otherOutputStreams.size()) { return false; } for (size_t i = 0; i < mOutputStreams.size(); i++) { if (mOutputStreams[i] != otherOutputStreams[i]) { return false; } } return true; } bool SessionConfiguration::outputsLessThan(const SessionConfiguration& other) const { const std::vector<OutputConfiguration>& otherOutputStreams = other.getOutputConfigurations(); if (mOutputStreams.size() != otherOutputStreams.size()) { return mOutputStreams.size() < otherOutputStreams.size(); } for (size_t i = 0; i < mOutputStreams.size(); i++) { if (mOutputStreams[i] != otherOutputStreams[i]) { return mOutputStreams[i] < otherOutputStreams[i]; } } return false; } }; // namespace android
camera/cameraserver/Android.bp +1 −0 Original line number Diff line number Diff line Loading @@ -29,6 +29,7 @@ cc_binary { "android.hardware.camera.provider@2.4", "android.hardware.camera.device@1.0", "android.hardware.camera.device@3.2", "android.hardware.camera.device@3.4", ], compile_multilib: "32", cflags: [ Loading