public interface

CameraDeviceConfig

 androidx.camera.core.CameraDeviceConfig

Subclasses:

ImageAnalysisConfig, PreviewConfig, VideoCaptureConfig, ImageCaptureConfig

Overview

Configuration containing options for configuring a Camera device.

This includes options for camera device intrinsics, such as the lens facing direction.

Summary

Fields
public static final Config.Option<CameraIdFilter>OPTION_CAMERA_ID_FILTER

Option: camerax.core.camera.cameraIdFilter

public static final Config.Option<LensFacing>OPTION_LENS_FACING

Option: camerax.core.camera.lensFacing

Methods
public CameraIdFiltergetCameraIdFilter()

Retrieves the CameraIdFilter that filter out the unavailable camera ids.

public CameraIdFiltergetCameraIdFilter(CameraIdFilter valueIfMissing)

Retrieves the CameraIdFilter that filter out the unavailable camera ids.

public androidx.camera.core.CameraX.LensFacinggetLensFacing()

Retrieves the lens facing direction for the primary camera to be configured.

public androidx.camera.core.CameraX.LensFacinggetLensFacing(LensFacing valueIfMissing)

Returns the lens-facing direction of the camera being configured.

Fields

public static final Config.Option<LensFacing> OPTION_LENS_FACING

Option: camerax.core.camera.lensFacing

public static final Config.Option<CameraIdFilter> OPTION_CAMERA_ID_FILTER

Option: camerax.core.camera.cameraIdFilter

Methods

public androidx.camera.core.CameraX.LensFacing getLensFacing(LensFacing valueIfMissing)

Returns the lens-facing direction of the camera being configured.

Parameters:

valueIfMissing: The value to return if this configuration option has not been set.

Returns:

The stored value or valueIfMissing if the value does not exist in this configuration.

public androidx.camera.core.CameraX.LensFacing getLensFacing()

Retrieves the lens facing direction for the primary camera to be configured.

Returns:

The stored value, if it exists in this configuration.

public CameraIdFilter getCameraIdFilter(CameraIdFilter valueIfMissing)

Retrieves the CameraIdFilter that filter out the unavailable camera ids.

Parameters:

valueIfMissing: The value to return if this configuration option has not been set.

Returns:

The stored value or valueIfMissing if the value does not exist in this configuration.

public CameraIdFilter getCameraIdFilter()

Retrieves the CameraIdFilter that filter out the unavailable camera ids.

Returns:

The stored value, if it exists in this configuration.

Source

/*
 * Copyright (C) 2019 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 androidx.camera.core;

import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.annotation.RestrictTo;
import androidx.annotation.RestrictTo.Scope;
import androidx.camera.core.CameraX.LensFacing;
import androidx.camera.core.Config.Option;

/**
 * Configuration containing options for configuring a Camera device.
 *
 * <p>This includes options for camera device intrinsics, such as the lens facing direction.
 *
 * @hide
 */
@RestrictTo(Scope.LIBRARY_GROUP)
public interface CameraDeviceConfig {

    // Option Declarations:
    // *********************************************************************************************

    /**
     * Option: camerax.core.camera.lensFacing
     *
     * @hide
     */
    @RestrictTo(Scope.LIBRARY_GROUP)
    Option<LensFacing> OPTION_LENS_FACING =
            Option.create("camerax.core.camera.lensFacing", CameraX.LensFacing.class);

    /**
     * Option: camerax.core.camera.cameraIdFilter
     *
     * @hide
     */
    @RestrictTo(Scope.LIBRARY_GROUP)
    Option<CameraIdFilter> OPTION_CAMERA_ID_FILTER =
            Option.create("camerax.core.camera.cameraIdFilter", CameraIdFilter.class);

    // *********************************************************************************************

    /**
     * Returns the lens-facing direction of the camera being configured.
     *
     * @param valueIfMissing The value to return if this configuration option has not been set.
     * @return The stored value or <code>valueIfMissing</code> if the value does not exist in this
     * configuration.
     */
    @Nullable
    CameraX.LensFacing getLensFacing(@Nullable LensFacing valueIfMissing);

    /**
     * Retrieves the lens facing direction for the primary camera to be configured.
     *
     * @return The stored value, if it exists in this configuration.
     * @throws IllegalArgumentException if the option does not exist in this configuration.
     */
    @NonNull
    CameraX.LensFacing getLensFacing();

    /**
     * Retrieves the {@link CameraIdFilter} that filter out the unavailable camera ids.
     *
     * @param valueIfMissing The value to return if this configuration option has not been set.
     * @return The stored value or <code>valueIfMissing</code> if the value does not exist in this
     * configuration.
     */
    @Nullable
    CameraIdFilter getCameraIdFilter(@Nullable CameraIdFilter valueIfMissing);

    /**
     * Retrieves the {@link CameraIdFilter} that filter out the unavailable camera ids.
     *
     * @return The stored value, if it exists in this configuration.
     * @throws IllegalArgumentException if the option does not exist in this configuration.
     */
    @NonNull
    CameraIdFilter getCameraIdFilter();

    /**
     * Builder for a {@link CameraDeviceConfig}.
     *
     * @param <B> The top level builder type for which this builder is composed with.
     * @hide
     */
    @RestrictTo(Scope.LIBRARY_GROUP)
    interface Builder<B> {

        /**
         * Sets the primary camera to be configured based on the direction the lens is facing.
         *
         * <p>If multiple cameras exist with equivalent lens facing direction, the first ("primary")
         * camera for that direction will be chosen.
         *
         * @param lensFacing The direction of the camera's lens.
         * @return the current Builder.
         */
        B setLensFacing(@NonNull CameraX.LensFacing lensFacing);

        /**
         * Sets the {@link CameraIdFilter} that filter out the unavailable camera ids.
         *
         * @param cameraIdFilter The {@link CameraIdFilter}.
         * @return the current Builder.
         */
        B setCameraIdFilter(@NonNull CameraIdFilter cameraIdFilter);
    }
}