#android #camera #android-camera2 #android-camerax #jitsi
#Android #камера #android-camera2 #android-camerax #jitsi
Вопрос:
Я использую CameraX в своем приложении, а также использую JistiMeetView. Когда я запускаю приложение, я могу открыть действие, содержащее CameraX, и камера может запуститься. Когда я открываю действие с помощью jitsmeetview, я правильно присоединяюсь к комнате, но когда я выхожу из действия 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:
Я нашел решение.
После перехода на официальный сайт: https://jitsi.github.io/handbook/docs/dev-guide/dev-guide-android-sdk
Я забыл все JitsiMeetActivityDelegate.onHost...(this);
о жизненном цикле активности Jisti Activity. Я только что добавил их, и теперь все работает нормально.