虽然确实调用了Camera.PreviewCallback#onPreviewFrame
,但相机未填充传递的byte[]
缓冲区:它始终充满零。
我之所以使用过时的API,是因为使用较新的API时帧率非常低。由于我的相机被认为是LEGACY
,因此建议您尝试不推荐使用的API。
我的代码,确实调用了回调,但是缓冲区为空:
camera = Camera.open();
camera.setParameters(configurator.getParameters());
Size size = configurator.getOutputSize();
camera.addCallbackBuffer(new byte[size.getWidth() * size.getHeight() * ImageFormat.getBitsPerPixel(ImageFormat.YV12) / 8]);
camera.setPreviewCallbackWithBuffer(this);
camera.startPreview();
我在日志中看到的一件奇怪的事情是:当我调用camera.setPreviewCallbackWithBuffer(this);
时,会出现以下调试消息:D/Camera-JNI: (tid:3466)[release camera] - X context=0x0
。
此外,所有对缓冲区的修改都将被清除:在每次调用回调之前,缓冲区实际上都填充了零。
答案 0 :(得分:1)
问题是与曝光时间相比,光线不足:我将预览FPS范围设置为最大,但与房间的灯光相比,这导致曝光时间太短。结果是黑色的图像,除非我直接将相机对准光源。将FPS范围更改为较低的值可以解决我的问题。