1 /* 2 * Copyright 2024 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17 package androidx.camera.core.internal.compat.quirk; 18 19 import androidx.camera.core.impl.Quirk; 20 import androidx.camera.core.impl.Quirks; 21 22 import org.jspecify.annotations.NonNull; 23 24 /** 25 * A Quirk interface denotes devices have specific issue and can be workaround by enabling 26 * surface processing (OpenGL) pipeline. 27 * 28 * <p>Subclasses of this quirk may contain device specific information. 29 */ 30 public interface SurfaceProcessingQuirk extends Quirk { 31 32 /** 33 * Returns if the device specific issue can be workaround by enabling surface processing 34 * (OpenGL) pipeline 35 */ workaroundBySurfaceProcessing()36 default boolean workaroundBySurfaceProcessing() { 37 return true; 38 } 39 40 /** 41 * Returns if input quirks contains at least one {@link SurfaceProcessingQuirk} which 42 * {@link SurfaceProcessingQuirk#workaroundBySurfaceProcessing()} is true. 43 */ workaroundBySurfaceProcessing(@onNull Quirks quirks)44 static boolean workaroundBySurfaceProcessing(@NonNull Quirks quirks) { 45 for (SurfaceProcessingQuirk quirk : quirks.getAll(SurfaceProcessingQuirk.class)) { 46 if (quirk.workaroundBySurfaceProcessing()) { 47 return true; 48 } 49 } 50 return false; 51 } 52 } 53