【问题标题】:Android camera2 api openCamera errorAndroid camera2 api openCamera 错误
【发布时间】:2016-11-10 13:40:10
【问题描述】:

我想使用 camera2 api 制作一个简单的 flashlite 应用程序。 我正在使用以下代码:

public class FlashLightUtilForL {
private CameraCaptureSession mSession;
private CaptureRequest.Builder mBuilder;
private CameraDevice mCameraDevice;
private CameraManager mCameraManager;

public FlashLightUtilForL(Context context) {
    try {
        mCameraManager = (CameraManager) context.getSystemService(Context.CAMERA_SERVICE);
        //here to judge if flash is available
        CameraCharacteristics cameraCharacteristics = mCameraManager.getCameraCharacteristics("0");
        boolean flashAvailable = cameraCharacteristics.get(CameraCharacteristics.FLASH_INFO_AVAILABLE);
        if (flashAvailable) {
            mCameraManager.openCamera("0", new MyCameraDeviceStateCallback(), null);
        } else {
            //todo: throw Exception
        }
        //mCameraManager.openCamera("0", new MyCameraDeviceStateCallback(), null);
    } catch (Exception e) {
        e.printStackTrace();
    }
}

class MyCameraDeviceStateCallback extends CameraDevice.StateCallback {

    @Override
    public void onOpened(CameraDevice camera) {
        mCameraDevice = camera;
        //get builder
        try {
            mBuilder = camera.createCaptureRequest(CameraDevice.TEMPLATE_MANUAL);
            //flash on, default is on
            mBuilder.set(CaptureRequest.CONTROL_AE_MODE, CameraMetadata.CONTROL_AF_MODE_AUTO);
            mBuilder.set(CaptureRequest.FLASH_MODE, CameraMetadata.FLASH_MODE_TORCH);
            List<Surface> list = new ArrayList<Surface>();
            SurfaceTexture mSurfaceTexture = new SurfaceTexture(1);
            Size size = getSmallestSize(mCameraDevice.getId());
            mSurfaceTexture.setDefaultBufferSize(size.getWidth(), size.getHeight());
            Surface mSurface = new Surface(mSurfaceTexture);
            list.add(mSurface);
            mBuilder.addTarget(mSurface);
            camera.createCaptureSession(list, new MyCameraCaptureSessionStateCallback(), null);
        } catch (CameraAccessException e) {
            e.printStackTrace();
        }
    }

    @Override
    public void onDisconnected(CameraDevice camera) {

    }

    @Override
    public void onError(CameraDevice camera, int error) {

    }
}

private Size getSmallestSize(String cameraId) throws CameraAccessException {
    Size[] outputSizes = mCameraManager.getCameraCharacteristics(cameraId)
            .get(CameraCharacteristics.SCALER_STREAM_CONFIGURATION_MAP)
            .getOutputSizes(SurfaceTexture.class);
    if (outputSizes == null || outputSizes.length == 0) {
        throw new IllegalStateException(
                "Camera " + cameraId + "doesn't support any outputSize.");
    }
    Size chosen = outputSizes[0];
    for (Size s : outputSizes) {
        if (chosen.getWidth() >= s.getWidth() && chosen.getHeight() >= s.getHeight()) {
            chosen = s;
        }
    }
    return chosen;
}

/**
 * session callback
 */
class MyCameraCaptureSessionStateCallback extends CameraCaptureSession.StateCallback {

    @Override
    public void onConfigured(CameraCaptureSession session) {
        mSession = session;
        try {
            mSession.setRepeatingRequest(mBuilder.build(), null, null);
        } catch (CameraAccessException e) {
            e.printStackTrace();
        }
    }

    @Override
    public void onConfigureFailed(CameraCaptureSession session) {

    }
}

public void turnOnFlashLight() {
    try {
        mBuilder.set(CaptureRequest.FLASH_MODE, CameraMetadata.FLASH_MODE_TORCH);
        mSession.setRepeatingRequest(mBuilder.build(), null, null);
    } catch (Exception e) {
        e.printStackTrace();
    }
}

public void turnOffFlashLight() {
    try {
        mBuilder.set(CaptureRequest.FLASH_MODE, CameraMetadata.FLASH_MODE_OFF);
        mSession.setRepeatingRequest(mBuilder.build(), null, null);
    } catch (Exception e) {
        e.printStackTrace();
    }
}

private void close() {
    if (mCameraDevice == null || mSession == null) {
        return;
    }
    mSession.close();
    mCameraDevice.close();
    mCameraDevice = null;
    mSession = null;
}
}

以下是我在主要活动中使用此类的方式:

FlashLightUtilForL util = new FlashLightUtilForL(getApplicationContext());
util.turnOnFlashLight();

但它什么也没做。我发现打开相机时出错,但没有提示这个错误是由什么引起的。这是日志:

这是连续打印三次:

11-10 15:27:32.881 11801-11801/com.flashlight W/ArrayUtils: Ignoring invalid value manual
11-10 15:27:32.881 11801-11801/com.flashlight W/ArrayUtils: Ignoring invalid value fullscan
11-10 15:27:32.881 11801-11801/com.flashlight W/ArrayUtils: Ignoring invalid value nashville
11-10 15:27:32.882 11801-11801/com.flashlight W/ArrayUtils: Ignoring invalid value hefe
11-10 15:27:32.882 11801-11801/com.flashlight W/ArrayUtils: Ignoring invalid value valencia
11-10 15:27:32.882 11801-11801/com.flashlight W/ArrayUtils: Ignoring invalid value xproll
11-10 15:27:32.882 11801-11801/com.flashlight W/ArrayUtils: Ignoring invalid value lofi
11-10 15:27:32.882 11801-11801/com.flashlight W/ArrayUtils: Ignoring invalid value sierra
11-10 15:27:32.882 11801-11801/com.flashlight W/ArrayUtils: Ignoring invalid value walden
11-10 15:27:32.882 11801-11801/com.flashlight W/ArrayUtils: Ignoring invalid value normal

然后一次:

11-10 15:27:32.909 11801-11801/com.flashlight I/CameraManager: Using legacy camera HAL.
11-10 15:27:32.911 11801-12695/com.flashlight W/Camera: An error occurred while connecting to camera: 0

我什至在 camera2 中找不到与此特定错误相关的任何内容。什么可能导致问题? 设备是红米note 2 5.0.2,摄像头有手电筒,我在manifest中添加了摄像头权限。

【问题讨论】:

    标签: android flashlight android-camera2


    【解决方案1】:

    我怀疑您的问题来自CameraDevice.TEMPLATE_MANUAL。并非所有设备都支持这一点。此外,当设备使用旧版支持时,我认为这效果不佳。尝试切换到CameraDevice.TEMPLATE_PREVIEW

    另外,不要忘记释放SufaceTexture

    【讨论】:

    • 永远不会调用 onOpened 方法,它不能是 'CameraDevice.TEMPLATE_MANUAL' 或 'SufaceTexture'。
    猜你喜欢
    • 2015-12-26
    • 2023-03-14
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2017-05-03
    • 1970-01-01
    • 2016-12-28
    • 1970-01-01
    相关资源
    最近更新 更多