एक साथ कई क्लाइंट को किसी कैमरे का ऐक्सेस दिया जा सकता है. इसके लिए, इस पेज पर बताए गए Java और Android NDK सिस्टम एपीआई का इस्तेमाल करें. इससे सिस्टम कैमरा क्लाइंट के साथ ऐक्सेस शेयर किया जा सकेगा.
प्राइमरी क्लाइंट: शेयर किए गए क्लाइंट में सबसे ज़्यादा प्राथमिकता वाला क्लाइंट. प्राइमरी क्लाइंट, कैप्चर करने के अनुरोध बना सकता है और कैप्चर करने के पैरामीटर में बदलाव कर सकता है.
सेकंडरी क्लाइंट: शेयर किए गए अन्य सभी क्लाइंट, सेकंडरी क्लाइंट होते हैं. सेकंडरी क्लाइंट, कैप्चर करने के अनुरोध नहीं बना सकते. साथ ही, वे कैप्चर करने के पैरामीटर में बदलाव भी नहीं कर सकते. सेकंडरी क्लाइंट, सिर्फ़ स्ट्रीमिंग शुरू या बंद करने के अनुरोध भेज सकते हैं.
स्ट्रीमिंग के लिए, कैमरा सेवा, डिफ़ॉल्ट कैप्चर अनुरोध पैरामीटर का इस्तेमाल करती है. ये पैरामीटर, झलक दिखाने वाले टेंप्लेट के लिए होते हैं. अगर प्राइमरी क्लाइंट स्ट्रीमिंग कर रहा है, तो सेवा, प्राइमरी क्लाइंट की ओर से तय किए गए कैप्चर अनुरोध पैरामीटर का इस्तेमाल करती है.
शेयर किया गया सेशन कॉन्फ़िगर करना
कैमरा डिवाइस शेयर करने के लिए, शेयर किए गए सेशन का कॉन्फ़िगरेशन, /system_ext/etc/ में मौजूद shared_session_config.xml नाम की फ़ाइल में दें. इस कोड के सैंपल में, कैमरा आईडी 0, कैमरा शेयर करने की सुविधा के साथ काम करता है. इसमें दो स्ट्रीम शामिल हैं: ImageReader और SurfaceView.
<SharedCameraSessionConfigurations colorSpace="-1">
<!-- colorSpace: ANDROID_REQUEST_AVAILABLE_COLOR_SPACE_PROFILES_MAP_UNSPECIFIED -->
<SharedCameraSessionConfiguration cameraId="0">
<!-- First OutputConfiguration: All optional fields are provided -->
<OutputConfiguration>
<!-- surfaceType: SURFACE_TYPE_IMAGE_READER -->
<surfaceType>4</surfaceType>
<width>1920</width>
<height>1080</height>
<!-- physicalCameraId is omitted; defaults to "" -->
<!-- streamUseCase: ANDROID_SCALER_AVAILABLE_STREAM_USE_CASES_DEFAULT -->
<streamUseCase>0</streamUseCase>
<!-- timestampBase: TIMESTAMP_BASE_DEFAULT -->
<timestampBase>0</timestampBase>
<!-- mirrorMode: MIRROR_MODE_AUTO -->
<mirrorMode>0</mirrorMode>
<useReadoutTimestamp>0</useReadoutTimestamp>
<!-- format: HAL_PIXEL_FORMAT_RGBA_8888 -->
<format>1</format>
<!-- usage: AHARDWAREBUFFER_USAGE_CPU_READ_OFTEN -->
<usage>3</usage>
<!-- dataSpace: HAL_DATASPACE_UNKNOWN -->
<dataSpace>0</dataSpace>
</OutputConfiguration>
<!-- Second OutputConfiguration: All optional fields are provided -->
<OutputConfiguration>
<!-- surfaceType: SURFACE_TYPE_SURFACE_VIEW -->
<surfaceType>0</surfaceType>
<width>1920</width>
<height>1080</height>
<!-- physicalCameraId is omitted; defaults to "" -->
<!-- streamUseCase: ANDROID_SCALER_AVAILABLE_STREAM_USE_CASES_DEFAULT -->
<streamUseCase>0</streamUseCase>
<!-- timestampBase: TIMESTAMP_BASE_DEFAULT -->
<timestampBase>0</timestampBase>
<!-- mirrorMode: MIRROR_MODE_AUTO -->
<mirrorMode>0</mirrorMode>
<useReadoutTimestamp>0</useReadoutTimestamp>
<!-- format: HAL_PIXEL_FORMAT_IMPLEMENTATION_DEFINED -->
<format>34</format>
<!-- usage: AHARDWAREBUFFER_USAGE_GPU_SAMPLED_IMAGE|AHARDWAREBUFFER_USAGE_COMPOSER_OVERLAY -->
<usage>256|2048</usage>
<!-- dataSpace: HAL_DATASPACE_UNKNOWN -->
<dataSpace>0</dataSpace>
</OutputConfiguration>
</SharedCameraSessionConfiguration>
</SharedCameraSessionConfigurations>
शेयर किए गए सेशन के कॉन्फ़िगरेशन के बारे में क्वेरी करने के लिए, क्लाइंट CameraCharacteristics
के लिए SHARED_SESSION_CONFIGURATION का इस्तेमाल करते हैं. शेयर किए गए मोड में कैमरे को ऐक्सेस करने वाले क्लाइंट को, शेयर किए गए सेशन के कॉन्फ़िगरेशन का इस्तेमाल करना होगा. जब क्लाइंट से मिला सेशन कॉन्फ़िगरेशन, शेयर किए गए सेशन कॉन्फ़िगरेशन से मेल नहीं खाता, तब createCaptureSession कॉल पूरा नहीं होता.
Java API
CameraManager और CameraDevice, शेयर किए गए मोड में कैमरे खोलने के लिए एपीआई उपलब्ध कराते हैं.
CameraManager API
CameraManager ये एपीआई उपलब्ध कराता है:
isCameraDeviceSharingSupported: क्लाइंट इस एपीआई का इस्तेमाल यह पता लगाने के लिए करते हैं कि कोई कैमरा शेयर किए गए मोड के साथ काम करता है या नहीं.openSharedCamera: अगर कोई कैमरा शेयर किए गए मोड के साथ काम करता है, तो क्लाइंट इस एपीआई का इस्तेमाल करके, कैमरे को शेयर किए गए मोड में खोलते हैं.
CameraDevice.StateCallback API
CameraDevice.StateCallback ये एपीआई उपलब्ध कराता है:
onOpenedInSharedMode: क्लाइंट को यह कॉलबैक तब मिलता है, जब शेयर किए गए मोड में कैमरा खोला जाता है. कॉलबैक से पता चलता है कि क्लाइंट, प्राइमरी क्लाइंट है या सेकंडरी क्लाइंट.onClientSharedAccessPriorityChanged: जब कोई शेयर किया गया सेशन खोला जाता है, तो इस कॉलबैक को तब ट्रिगर किया जाता है, जब किसी क्लाइंट की प्राथमिकता बदल जाती है. ऐसा इसलिए होता है, क्योंकि ज़्यादा प्राथमिकता वाले क्लाइंट ने उसी कैमरे को खोला या बंद किया है.
CameraSharedCaptureSession
CameraSharedCaptureSession क्लास, शेयर किए गए कैप्चर सेशन के बारे में बताती है.
शेयर किए गए कैमरा मोड में, सेशन बनाने वाले क्लाइंट को SESSION_SHARED सेशन टाइप का इस्तेमाल करना होगा.
जब सिस्टम कोई सेशन बनाता है, तब CameraCaptureSession को CameraSharedCaptureSession पर कास्ट करें.
सेकंडरी क्लाइंट, createCaptureRequest का इस्तेमाल नहीं कर सकते. इसके बजाय, सेकंडरी क्लाइंट, तय किए गए प्लैटफ़ॉर्म पर स्ट्रीमिंग शुरू करने के लिए startStreaming एपीआई और स्ट्रीमिंग रोकने के लिए stopStreaming एपीआई का इस्तेमाल करते हैं.
Android NDK API
पहले से मौजूद ऐप्लिकेशन, शेयर किए गए मोड में कैमरा खोलने के लिए इन Android NDK API का इस्तेमाल करते हैं:
ACameraManager_isCameraDeviceSharingSupportedACameraManager_openSharedCameraACameraCaptureSessionShared_startStreamingACameraCaptureSessionShared_logicalCamera_startStreamingACameraCaptureSessionShared_stopStreamingACameraDevice_ClientSharedAccessPriorityChangedCallbackonClientSharedAccessPriorityChanged
शेयर किए गए कैमरों की जांच करना
एक से ज़्यादा क्लाइंट वाले कैमरों के लिए, ये टेस्ट देखें:
Vendor test suite (VTS):
VtsAidlCameraServiceTargetTestमेंSharedCameraTestदेखेंCompatibility test suite (CTS):
CtsCameraTestCasesमेंandroid.hardware.multiprocess.camera.cts.SharedCameraTestदेखें
पाबंदियां
शेयर किए गए कैमरे के मोड में, ये विकल्प काम नहीं करते:
- बर्स्ट कैप्चर करने के अनुरोध
- एक्सटेंशन सेशन
- तेज़ स्पीड वाले सेशन
- ऑफ़लाइन सेशन
OutputConfigurationको प्लैटफ़ॉर्म के साथ शेयर करने की सुविधा- फिर से प्रोसेस किए जा सकने वाले कैप्चर सेशन
- तीसरे पक्ष के ऐप्लिकेशन
जब ज़्यादा प्राथमिकता वाला क्लाइंट, कैमरे को सामान्य मोड में खोलता है, तो सिस्टम, कैमरे को शेयर करने वाले सभी क्लाइंट को हटा देता है.