CameraX এক্সটেনশন API

ক্যামেরাএক্স এক্সটেনশনগুলি অ্যাক্সেস করার জন্য একটি এক্সটেনশন API প্রদান করে যা ডিভাইস নির্মাতারা বিভিন্ন Android ডিভাইসে প্রয়োগ করেছে। সমর্থিত এক্সটেনশন মোডগুলির একটি তালিকার জন্য, ক্যামেরা এক্সটেনশনগুলি দেখুন৷

এক্সটেনশন সমর্থন করে এমন ডিভাইসগুলির একটি তালিকার জন্য, সমর্থিত ডিভাইসগুলি দেখুন।

এক্সটেনশন আর্কিটেকচার

নিচের ছবিটি ক্যামেরা এক্সটেনশনের আর্কিটেকচার দেখায়।

চিত্র 1. ক্যামেরা এক্সটেনশন আর্কিটেকচার

একটি CameraX অ্যাপ্লিকেশন CameraX এক্সটেনশন API এর মাধ্যমে এক্সটেনশন ব্যবহার করতে পারে। CameraX এক্সটেনশন API উপলব্ধ এক্সটেনশনগুলির জন্য অনুসন্ধান পরিচালনা করে, একটি এক্সটেনশন ক্যামেরা সেশন কনফিগার করে এবং ক্যামেরা এক্সটেনশন OEM লাইব্রেরির সাথে যোগাযোগ করে। এটি আপনার অ্যাপ্লিকেশনকে নাইট, এইচডিআর, অটো, বোকেহ, বা ফেস রিটাচের মতো ক্ষমতাগুলি ব্যবহার করতে দেয়৷

চিত্র ক্যাপচার এবং পূর্বরূপের জন্য একটি এক্সটেনশন সক্ষম করুন৷

এক্সটেনশন API ব্যবহার করার আগে, ExtensionsManager#getInstanceAsync(Context, CameraProvider) পদ্ধতি ব্যবহার করে একটি ExtensionsManager ইনস্ট্যান্স পুনরুদ্ধার করুন। এটি আপনাকে এক্সটেনশন প্রাপ্যতা তথ্য অনুসন্ধান করার অনুমতি দেবে। তারপর একটি এক্সটেনশন সক্ষম CameraSelector পুনরুদ্ধার করুন। CameraSelector এক্সটেনশন সক্ষম করে bindToLifecycle() পদ্ধতিতে কল করার সময় চিত্র ক্যাপচার এবং পূর্বরূপ ব্যবহারের ক্ষেত্রে এক্সটেনশন মোড প্রয়োগ করা হবে।

চিত্র ক্যাপচার এবং পূর্বরূপ ব্যবহারের ক্ষেত্রে এক্সটেনশন বাস্তবায়ন করতে, নিম্নলিখিত কোড নমুনা পড়ুন:

কোটলিন

import androidx.camera.extensions.ExtensionMode
import androidx.camera.extensions.ExtensionsManager

override fun onCreate(savedInstanceState: Bundle?) {
    super.onCreate(savedInstanceState)

    val lifecycleOwner = this

    val cameraProviderFuture = ProcessCameraProvider.getInstance(applicationContext)
    cameraProviderFuture.addListener({
        // Obtain an instance of a process camera provider
        // The camera provider provides access to the set of cameras associated with the device.
        // The camera obtained from the provider will be bound to the activity lifecycle.
        val cameraProvider = cameraProviderFuture.get()

        val extensionsManagerFuture =
            ExtensionsManager.getInstanceAsync(applicationContext, cameraProvider)
        extensionsManagerFuture.addListener({
            // Obtain an instance of the extensions manager
            // The extensions manager enables a camera to use extension capabilities available on
            // the device.
            val extensionsManager = extensionsManagerFuture.get()

            // Select the camera
            val cameraSelector = CameraSelector.DEFAULT_BACK_CAMERA

            // Query if extension is available.
            // Not all devices will support extensions or might only support a subset of
            // extensions.
            if (extensionsManager.isExtensionAvailable(cameraSelector, ExtensionMode.NIGHT)) {
                // Unbind all use cases before enabling different extension modes.
                try {
                    cameraProvider.unbindAll()

                    // Retrieve a night extension enabled camera selector
                    val nightCameraSelector =
                        extensionsManager.getExtensionEnabledCameraSelector(
                            cameraSelector,
                            ExtensionMode.NIGHT
                        )

                    // Bind image capture and preview use cases with the extension enabled camera
                    // selector.
                    val imageCapture = ImageCapture.Builder().build()
                    val preview = Preview.Builder().build()
                    // Connect the preview to receive the surface the camera outputs the frames
                    // to. This will allow displaying the camera frames in either a TextureView
                    // or SurfaceView. The SurfaceProvider can be obtained from the PreviewView.
                    preview.setSurfaceProvider(surfaceProvider)

                    // Returns an instance of the camera bound to the lifecycle
                    // Use this camera object to control various operations with the camera
                    // Example: flash, zoom, focus metering etc.
                    val camera = cameraProvider.bindToLifecycle(
                        lifecycleOwner,
                        nightCameraSelector,
                        imageCapture,
                        preview
                    )
                } catch (e: Exception) {
                    Log.e(TAG, "Use case binding failed", e)
                }
            }
        }, ContextCompat.getMainExecutor(this))
    }, ContextCompat.getMainExecutor(this))
}

জাভা

import androidx.camera.extensions.ExtensionMode;
import androidx.camera.extensions.ExtensionsManager;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    final LifecycleOwner lifecycleOwner = this;

    final ListenableFuture cameraProviderFuture =
            ProcessCameraProvider.getInstance(getApplicationContext());

    cameraProviderFuture.addListener(() -> {
      try {
          // Obtain an instance of a process camera provider
          // The camera provider provides access to the set of cameras associated with the
          // device. The camera obtained from the provider will be bound to the activity
          // lifecycle.
          final ProcessCameraProvider cameraProvider = cameraProviderFuture.get();

          final ListenableFuture extensionsManagerFuture =
                  ExtensionsManager.getInstanceAsync(getApplicationContext(), cameraProvider);
          extensionsManagerFuture.addListener(() -> {
              // Obtain an instance of the extensions manager
              // The extensions manager enables a camera to use extension capabilities available
              // on the device.
              try {
                  final ExtensionsManager extensionsManager = extensionsManagerFuture.get();

                  // Select the camera
                  final CameraSelector cameraSelector = CameraSelector.DEFAULT_BACK_CAMERA;

                  // Query if extension is available.
                  // Not all devices will support extensions or might only support a subset of
                  // extensions.
                  if (extensionsManager.isExtensionAvailable(
                          cameraSelector,
                          ExtensionMode.NIGHT
                  )) {
                      // Unbind all use cases before enabling different extension modes.
                      cameraProvider.unbindAll();

                      // Retrieve extension enabled camera selector
                      final CameraSelector nightCameraSelector = extensionsManager
                              .getExtensionEnabledCameraSelector(cameraSelector, ExtensionMode.NIGHT);

                      // Bind image capture and preview use cases with the extension enabled camera
                      // selector.
                      final ImageCapture imageCapture = new ImageCapture.Builder().build();
                      final Preview preview = new Preview.Builder().build();
                      // Connect the preview to receive the surface the camera outputs the frames
                      // to. This will allow displaying the camera frames in either a TextureView
                      // or SurfaceView. The SurfaceProvider can be obtained from the PreviewView.
                      preview.setSurfaceProvider(surfaceProvider);

                      cameraProvider.bindToLifecycle(
                              lifecycleOwner,
                              nightCameraSelector,
                              imageCapture,
                              preview
                      );
                  }
              } catch (ExecutionException | InterruptedException e) {
                  throw new RuntimeException(e);
              }
          }, ContextCompat.getMainExecutor(this));

      } catch (ExecutionException | InterruptedException e) {
          throw new RuntimeException(e);
      }

  }, ContextCompat.getMainExecutor(this));
}

এক্সটেনশন নিষ্ক্রিয় করুন

বিক্রেতা এক্সটেনশনগুলি অক্ষম করতে, সমস্ত ব্যবহারের ক্ষেত্রে আবদ্ধ করুন এবং একটি সাধারণ ক্যামেরা নির্বাচকের সাথে চিত্র ক্যাপচার এবং পূর্বরূপ ব্যবহারের কেসগুলিকে পুনরায় বাঁধুন৷ উদাহরণস্বরূপ, CameraSelector.DEFAULT_BACK_CAMERA ব্যবহার করে পিছনের ক্যামেরায় রিবাইন্ড করুন।

নির্ভরতা

CameraX Extensions API camera-extensions লাইব্রেরিতে প্রয়োগ করা হয়। এক্সটেনশনগুলি ক্যামেরাএক্স কোর মডিউল ( core , camera2 , lifecycle ) এর উপর নির্ভর করে৷

গ্রোভি

dependencies {
  def camerax_version = "1.2.0-rc01"
  implementation "androidx.camera:camera-core:${camerax_version}"
  implementation "androidx.camera:camera-camera2:${camerax_version}"
  implementation "androidx.camera:camera-lifecycle:${camerax_version}"
  //the CameraX Extensions library
  implementation "androidx.camera:camera-extensions:${camerax_version}"
    ...
}

কোটলিন

dependencies {
  val camerax_version = "1.2.0-rc01"
  implementation("androidx.camera:camera-core:${camerax_version}")
  implementation("androidx.camera:camera-camera2:${camerax_version}")
  implementation("androidx.camera:camera-lifecycle:${camerax_version}")
  // the CameraX Extensions library
  implementation("androidx.camera:camera-extensions:${camerax_version}")
    ...
}

লিগ্যাসি API অপসারণ

1.0.0-alpha26 এ প্রকাশিত নতুন এক্সটেনশন API-এর সাথে, আগস্ট 2019-এ রিলিজ হওয়া লিগ্যাসি এক্সটেনশন এপিআই এখন অবহেলিত। সংস্করণ 1.0.0-alpha28 দিয়ে শুরু করে, লিগ্যাসি এক্সটেনশন API লাইব্রেরি থেকে সরানো হয়েছে৷ নতুন এক্সটেনশন API ব্যবহার করা অ্যাপ্লিকেশনগুলিকে এখন একটি এক্সটেনশন-সক্ষম CameraSelector অর্জন করতে হবে এবং ব্যবহারের ক্ষেত্রে বাঁধাই করতে এটি ব্যবহার করতে হবে৷

লিগ্যাসি এক্সটেনশন API ব্যবহার করে অ্যাপ্লিকেশনগুলিকে আসন্ন CameraX রিলিজের সাথে ভবিষ্যতের সামঞ্জস্য নিশ্চিত করতে নতুন এক্সটেনশন API-এ স্থানান্তর করা উচিত।

অতিরিক্ত সম্পদ

CameraX সম্পর্কে আরও জানতে, নিম্নলিখিত অতিরিক্ত সংস্থানগুলি দেখুন৷

কোডল্যাব

  • CameraX দিয়ে শুরু করা
  • কোড নমুনা

    CameraX এক্সটেনশনের নমুনা অ্যাপ

    অন্যান্য রেফারেন্স

    ক্যামেরাএক্স বিক্রেতা এক্সটেনশন

    ক্যামেরাএক্স ভেন্ডর এক্সটেনশন ভ্যালিডেশন টুল