Android:JitsiMeetView 后不打开 CameraX

问题描述

我在我的应用上使用 CameraX,我也在使用 JistiMeetView。当我启动应用程序时,我可以打开包含 CameraX 的活动,并且相机可以启动。当我使用 JitsiMeetView 打开活动时,我正确加入了房间,但是当我退出 jitsi 活动并返回相机活动时,相机无法启动。所以我认为jitsi保留了相机资源,但我不知道如何关闭所有资源。

这是我销毁jitsi活动时的代码

@Override
protected void onDestroy() {
    jitsiMeetView.leave();
    jitsiMeetView.dispose();
    super.onDestroy();
}

用于启动相机的相机活动代码

 private fun startCamera(lensFacing: Int) {

        val cameraProviderFuture = ProcessCameraProvider.getInstance(this)

        cameraProviderFuture.addListener(Runnable {
            // Used to bind the lifecycle of cameras to the lifecycle owner
            val cameraProvider: ProcessCameraProvider = cameraProviderFuture.get()

            preview = Preview.Builder().build()
                    .also {
                it.setSurfaceProvider(findViewById<PreviewView>(R.id.phototake_camera_view).surfaceProvider)
            }

            imageCapture = ImageCapture.Builder().setCaptureMode(ImageCapture.CAPTURE_MODE_MINIMIZE_LATENCY)
                    .build()

            imageAnalyzer = ImageAnalysis.Builder()
                    .build()

            // Select back camera
            val cameraSelector = CameraSelector.Builder().requireLensFacing(lensFacing).build()

            try {
                // Unbind use cases before rebinding
                cameraProvider.unbindAll()

                // Bind use cases to camera
                cameraProvider.bindToLifecycle(this,cameraSelector,preview,imageCapture,imageAnalyzer)

            } catch (exc: Exception) {
                Log.e(TAG,"Use case binding Failed",exc)
            }

        },ContextCompat.getMainExecutor(this))
    }

当我停止 jitsi 视图时,我在日志中也有这个,它仍然存在:

W/unkNown:ReactNative: Attempt to set local data for view with unkNown tag: 247
I/Org.webrtc.Logging: CameraStatistics: Camera fps: 21.
D/NetworkManagementSocketTagger: tagSocket(71) with statsTag=0xffffffff,statsUid=-1
I/Org.webrtc.Logging: CameraStatistics: Camera fps: 20.
I/Org.webrtc.Logging: CameraStatistics: Camera fps: 20.
I/Org.webrtc.Logging: CameraStatistics: Camera fps: 20.
D/NetworkManagementSocketTagger: tagSocket(81) with statsTag=0xffffffff,statsUid=-1
I/Org.webrtc.Logging: CameraStatistics: Camera fps: 20.
I/Org.webrtc.Logging: CameraStatistics: Camera fps: 20.
D/NetworkManagementSocketTagger: tagSocket(81) with statsTag=0xffffffff,statsUid=-1
I/Org.webrtc.Logging: CameraStatistics: Camera fps: 21.

我使用 Kotlin 只是为了 CameraX 活动

解决方法

我找到了解决方案。

关注官网后:https://jitsi.github.io/handbook/docs/dev-guide/dev-guide-android-sdk

我忘记了关于 Jisti Activity 的 Activity 生命周期的所有 JitsiMeetActivityDelegate.onHost...(this);。我刚刚添加了它们,现在可以正常工作了。