Android: CameraX не открывается после JitsiMeetView

Я использую 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

1
0
232
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Я нашел решение.

После перехода на официальный сайт: https://jitsi.github.io/handbook/docs/dev-guide/dev-guide-android-sdk

Я забыл все JitsiMeetActivityDelegate.onHost...(this); о жизненном цикле активности Jisti Activity. Я только что добавил их, и теперь все работает нормально.

Другие вопросы по теме