diff options
| author | 2023-06-28 17:04:45 +0000 | |
|---|---|---|
| committer | 2023-06-28 17:04:45 +0000 | |
| commit | 41fc44e370d482c8a42d1e481bae90e66cc55bf0 (patch) | |
| tree | 3910d0f5632ec6968ba8eaad76fb47536c10e572 | |
| parent | d7b4cc8ae87287fa46bb92fb95b3993fbb444fa7 (diff) | |
| parent | 7ebffbe2c0db80e5a4191d5236ca086bbd55cc17 (diff) | |
Merge "Camera: Address device state listener delay" into udc-qpr-dev
| -rw-r--r-- | core/java/android/hardware/camera2/CameraManager.java | 13 |
1 files changed, 6 insertions, 7 deletions
diff --git a/core/java/android/hardware/camera2/CameraManager.java b/core/java/android/hardware/camera2/CameraManager.java index 85f8ca66715b..a098362f16aa 100644 --- a/core/java/android/hardware/camera2/CameraManager.java +++ b/core/java/android/hardware/camera2/CameraManager.java @@ -67,6 +67,7 @@ import java.util.ArrayList; import java.util.Arrays; import java.util.Comparator; import java.util.HashMap; +import java.util.Iterator; import java.util.Map; import java.util.Set; import java.util.concurrent.Executor; @@ -178,22 +179,20 @@ public final class CameraManager { boolean folded = ArrayUtils.contains(mFoldedDeviceStates, state); mFoldedDeviceState = folded; - ArrayList<WeakReference<DeviceStateListener>> invalidListeners = new ArrayList<>(); - for (WeakReference<DeviceStateListener> listener : mDeviceStateListeners) { - DeviceStateListener callback = listener.get(); + Iterator<WeakReference<DeviceStateListener>> it = mDeviceStateListeners.iterator(); + while(it.hasNext()) { + DeviceStateListener callback = it.next().get(); if (callback != null) { callback.onDeviceStateChanged(folded); } else { - invalidListeners.add(listener); + it.remove(); } } - if (!invalidListeners.isEmpty()) { - mDeviceStateListeners.removeAll(invalidListeners); - } } public synchronized void addDeviceStateListener(DeviceStateListener listener) { listener.onDeviceStateChanged(mFoldedDeviceState); + mDeviceStateListeners.removeIf(l -> l.get() == null); mDeviceStateListeners.add(new WeakReference<>(listener)); } |