public final class

ExtendedCameraConfigProviderStore

extends java.lang.Object

 java.lang.Object

↳androidx.camera.core.impl.ExtendedCameraConfigProviderStore

Gradle dependencies

compile group: 'androidx.camera', name: 'camera-core', version: '1.5.0-alpha01'

  • groupId: androidx.camera
  • artifactId: camera-core
  • version: 1.5.0-alpha01

Artifact androidx.camera:camera-core:1.5.0-alpha01 it located at Google repository (https://maven.google.com/)

Overview

Stores CameraConfigProvider instances which allow building CameraConfig using keys (extensions modes for example). The provided CameraConfigs are unique to the device.

Summary

Methods
public static voidaddConfig(java.lang.Object key, CameraConfigProvider provider)

Associates the specified CameraConfigProvider with the specified key and stores them.

public static voidclear()

Clear all CameraConfigProvider instances.

public static CameraConfigProvidergetConfigProvider(java.lang.Object key)

Retrieves the CameraConfigProvider associated with the specified key.

from java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait

Methods

public static void addConfig(java.lang.Object key, CameraConfigProvider provider)

Associates the specified CameraConfigProvider with the specified key and stores them.

public static CameraConfigProvider getConfigProvider(java.lang.Object key)

Retrieves the CameraConfigProvider associated with the specified key.

A default CameraConfigProvider.EMPTY will be returned if there isn't a CameraConfigProvider associated with the key.

public static void clear()

Clear all CameraConfigProvider instances.

Source

/*
 * Copyright 2021 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.impl;

import androidx.annotation.GuardedBy;
import androidx.annotation.NonNull;

import java.util.HashMap;
import java.util.Map;

/**
 * Stores {@link CameraConfigProvider} instances which allow building {@link CameraConfig} using
 * keys (extensions modes for example). The provided {@link CameraConfig}s are unique to the device.
 */
public final class ExtendedCameraConfigProviderStore {

    private static final Object LOCK = new Object();

    @GuardedBy("LOCK")
    private static final Map<Object, CameraConfigProvider> CAMERA_CONFIG_PROVIDERS =
            new HashMap<>();

    private ExtendedCameraConfigProviderStore() {
    }

    /**
     * Associates the specified {@link CameraConfigProvider} with the specified key and stores them.
     */
    public static void addConfig(@NonNull Object key, @NonNull CameraConfigProvider provider) {
        synchronized (LOCK) {
            CAMERA_CONFIG_PROVIDERS.put(key, provider);
        }
    }

    /**
     * Retrieves the {@link CameraConfigProvider} associated with the specified key.
     *
     * <p>A default {@link CameraConfigProvider#EMPTY} will be returned if there isn't a
     * {@link CameraConfigProvider} associated with the key.
     */
    @NonNull
    public static CameraConfigProvider getConfigProvider(@NonNull Object key) {
        final CameraConfigProvider provider;
        synchronized (LOCK) {
            provider = CAMERA_CONFIG_PROVIDERS.get(key);
        }

        if (provider == null) {
            return CameraConfigProvider.EMPTY;
        }
        return provider;
    }

    /**
     * Clear all {@link CameraConfigProvider} instances.
     */
    public static void clear() {
        synchronized (LOCK) {
            CAMERA_CONFIG_PROVIDERS.clear();
        }
    }
}