min未队列缓冲区计数超过camera2

时间:2016-03-16 13:22:53

标签: android android-5.0-lollipop android-camera2

我有一个Android应用程序拍摄没有预览图面的照片。我用Lollipop的新camera2实现了这个 - api 21

代码是这样的:

                final CaptureRequest.Builder jpegRequest = camera.createCaptureRequest(CameraDevice.TEMPLATE_STILL_CAPTURE);
                // Render to our image reader:
                jpegRequest.addTarget(imageReaderSurface);
                // Configure auto-focus (AF) and auto-exposure (AE) modes:
                jpegRequest.set(CaptureRequest.CONTROL_AF_MODE, CameraMetadata.CONTROL_AF_MODE_CONTINUOUS_PICTURE);
                jpegRequest.set(CaptureRequest.CONTROL_AE_MODE, autoExposureModeFinal);
                jpegRequest.set(CaptureRequest.JPEG_ORIENTATION, correctOrientation(context, characteristics));

                if (previews == 0) {
                    saveImage(camera, session, jpegRequest.build());
                } else {
                    // Take previews to dummySurface to allow camera to warm up before saving jpeg:
                    final CaptureRequest.Builder captureBuilder = camera.createCaptureRequest(CameraDevice.TEMPLATE_PREVIEW);
                    // Render to our dummy preview surface:
                    captureBuilder.addTarget(outputSurfaces.get(1));
                    // Configure auto-focus (AF) and auto-exposure (AE) modes:
                    captureBuilder.set(CaptureRequest.CONTROL_AF_MODE, CameraMetadata.CONTROL_AF_MODE_CONTINUOUS_PICTURE);
                    captureBuilder.set(CaptureRequest.CONTROL_AE_MODE, autoExposureModeFinal);

                    session.setRepeatingRequest(captureBuilder.build(), new CameraCaptureSession.CaptureCallback() {
                        int mNumCaptures;

                        @Override
                        public void onCaptureCompleted(CameraCaptureSession completedSession, CaptureRequest request, TotalCaptureResult result) {
                            //Log.d("mNumCaptures", String.valueOf(mNumCaptures));
                            if (++mNumCaptures == previews) {
                                try {
                                    completedSession.stopRepeating();
                                    saveImage(camera, session, jpegRequest.build());
                                    //session.abortCaptures();
                                    closeCamera(camera, looper);
                                } catch (CameraAccessException e) {
                                    error("Error saving image", e);
                                    closeCamera(camera, looper);
                                }
                            }
                        }
                    }, null);

                }

我已经在Android 6的nexus 5x上测试了这个并且它可以工作。预览设置为20 - 您需要捕获更多图像,以便摄像机适应光线。

我用Galaxy s5测试了这段代码--Android 5并没有用。 我收到此错误:min undequeued buffer count exceeded

03-16 15:01:09.569: W/ArrayUtils(30646): Ignoring invalid value emboss
03-16 15:01:09.569: W/ArrayUtils(30646): Ignoring invalid value sketch
03-16 15:01:09.569: W/ArrayUtils(30646): Ignoring invalid value neon
03-16 15:01:09.599: I/CameraManager(30646): Using legacy camera HAL.
03-16 15:01:10.059: W/ArrayUtils(30646): Ignoring invalid value emboss
03-16 15:01:10.059: W/ArrayUtils(30646): Ignoring invalid value sketch
03-16 15:01:10.059: W/ArrayUtils(30646): Ignoring invalid value neon
03-16 15:01:10.089: W/ArrayUtils(30646): Ignoring invalid value emboss
03-16 15:01:10.089: W/ArrayUtils(30646): Ignoring invalid value sketch
03-16 15:01:10.089: W/ArrayUtils(30646): Ignoring invalid value neon
03-16 15:01:10.109: I/CameraDeviceState(30646): Legacy camera service transitioning to state CONFIGURING
03-16 15:01:10.109: I/RequestThread-0(30646): Configure outputs: 2 surfaces configured.
03-16 15:01:10.109: D/Camera(30646): app passed NULL surface
03-16 15:01:10.119: I/RequestThread-0(30646): configureOutputs - set take picture size to 800x480
03-16 15:01:10.209: I/CameraDeviceState(30646): Legacy camera service transitioning to state IDLE
03-16 15:01:10.219: D/info(30646): Not using a front facing camera.
03-16 15:01:10.229: D/info(30646): Sensor orientation: 90 degrees
03-16 15:01:10.229: D/info(30646): Device orientation: 0 degrees
03-16 15:01:10.229: D/info(30646): Returning JPEG orientation of 90 degrees
03-16 15:01:10.229: I/RequestQueue(30646): Repeating capture request set.
03-16 15:01:10.239: W/LegacyRequestMapper(30646): convertRequestMetadata - control.awbRegions setting is not supported, ignoring value
03-16 15:01:10.239: W/LegacyRequestMapper(30646): Only received metering rectangles with weight 0.
03-16 15:01:10.239: W/LegacyRequestMapper(30646): Only received metering rectangles with weight 0.
03-16 15:01:11.019: I/CameraDeviceState(30646): Legacy camera service transitioning to state CAPTURING
03-16 15:01:11.209: E/BufferQueueProducer(30646): [unnamed-30646-2] dequeueBuffer: min undequeued buffer count (2) exceeded (dequeued=5 undequeued=1)
03-16 15:01:14.039: I/RequestQueue(30646): Repeating capture request cancelled.
03-16 15:01:14.439: E/BufferQueueProducer(30646): [unnamed-30646-2] cancelBuffer: BufferQueue has been abandoned
03-16 15:01:14.439: E/BufferQueueProducer(30646): [unnamed-30646-2] cancelBuffer: BufferQueue has been abandoned
03-16 15:01:14.439: E/BufferQueueProducer(30646): [unnamed-30646-2] cancelBuffer: BufferQueue has been abandoned
03-16 15:01:14.439: E/BufferQueueProducer(30646): [unnamed-30646-2] cancelBuffer: BufferQueue has been abandoned

即使我将预览设置为0,也会出现相同的错误。

我找到了一些关于错误“min undequeued buffer count exceeded”的话题但是所有这些都与不推荐使用的相机类有关。 你知道我是否可以在Android 5上做些什么来解决这个问题?

由于

1 个答案:

答案 0 :(得分:0)

要尝试一下,看看是否将maxImages参数递增到JPEG ImageReader会对此有所帮助。