Fix NPE when converting camera2 supported sizes
StreamConfigurationMap.getOutputSizes() may return null: https://developer.android.com/reference/android/hardware/camera2/params/StreamConfigurationMap#getOutputSizes(java.lang.Class%3CT%3E) Fixes: Fatal Exception: java.lang.NullPointerException: Attempt to get length of null array at org.webrtc.Camera2Enumerator.convertSizes(Camera2Enumerator.java:234) at org.webrtc.Camera2Enumerator.getSupportedSizes(Camera2Enumerator.java:147) at org.webrtc.Camera2Session.findCaptureFormat(Camera2Session.java:325) at org.webrtc.Camera2Session.start(Camera2Session.java:313) at org.webrtc.Camera2Session.<init>(Camera2Session.java:296) at org.webrtc.Camera2Session.create(Camera2Session.java:274) at org.webrtc.Camera2Capturer.createCameraSession(Camera2Capturer.java:35) at org.webrtc.CameraCapturer$5.run(CameraCapturer.java:272) at android.os.Handler.handleCallback(Handler.java:883) at android.os.Handler.dispatchMessage(Handler.java:100) at android.os.Looper.loop(Looper.java:237) at android.os.HandlerThread.run(HandlerThread.java:67) Bug: webrtc:13032 Change-Id: I9154be567cd12c066087818ba22e9cd69e75a22f Reviewed-on: https://webrtc-review.googlesource.com/c/src/+/227291 Reviewed-by: Xavier Lepaul <xalep@webrtc.org> Commit-Queue: Xavier Lepaul <xalep@webrtc.org> Cr-Commit-Position: refs/heads/main@{#34872}
This commit is contained in:
parent
cd0a4f5ff5
commit
1460e15a45
@ -24,6 +24,7 @@ import android.util.AndroidException;
|
||||
import android.util.Range;
|
||||
import androidx.annotation.Nullable;
|
||||
import java.util.ArrayList;
|
||||
import java.util.Collections;
|
||||
import java.util.HashMap;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
@ -230,7 +231,10 @@ public class Camera2Enumerator implements CameraEnumerator {
|
||||
|
||||
// Convert from android.util.Size to Size.
|
||||
private static List<Size> convertSizes(android.util.Size[] cameraSizes) {
|
||||
final List<Size> sizes = new ArrayList<Size>();
|
||||
if (cameraSizes == null || cameraSizes.length == 0) {
|
||||
return Collections.emptyList();
|
||||
}
|
||||
final List<Size> sizes = new ArrayList<>(cameraSizes.length);
|
||||
for (android.util.Size size : cameraSizes) {
|
||||
sizes.add(new Size(size.getWidth(), size.getHeight()));
|
||||
}
|
||||
|
||||
Loading…
x
Reference in New Issue
Block a user