Si bien parece que hay algunas preguntas aquí con respecto a las restricciones de servicio de Android 12, todavía tengo que ver una específica para este caso de uso.
Fondo: estoy iniciando un servicio de primer plano para manejar un reproductor multimedia de fondo de ejecución muy larga (Exoplayer). Debido a la configuración de la aplicación, no puedo usar el administrador de notificaciones integrado de exoplayer. Sin embargo, veo un comportamiento extraño de Crashlytics. Recibo ForegroundServiceStartNotAllowedException
mientras que la aplicación está, sin duda, en primer plano. Según los registros, es fácil ver que el usuario está navegando por la aplicación dentro de un segundo de la llamada startForeground
.
yo tambien estoy escuchando
override fun onStateChanged(source: LifecycleOwner, event: Lifecycle.Event)
para asegurarse de que la aplicación esté en un estado de primer plano.
Estoy empezando a quedarme sin ideas sobre lo que podría causar esto. Como puede ver por las marcas de tiempo, había pasado menos de 1 segundo. La aplicación no tiene casos de uso en los que el servicio podría incluso iniciarse accidentalmente desde el fondo.
Gracias
Editar:
También estoy declarando mi tipo de servicio:
<service android:name=".service.SoundPlayerService" android:enabled="true" android:exported="false" android:foregroundServiceType="mediaPlayback" android:stopWithTask="false"> <intent-filter> <action android:name="android.media.browse.MediaBrowserService" /> </intent-filter> </service>
if (!audioFocusTakenBackground && Application.instance.isAppInForeground) { if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.Q) { startForeground( ONGOING_NOTIFICATION_ID, builder.build(), ServiceInfo.FOREGROUND_SERVICE_TYPE_MEDIA_PLAYBACK ) } else { startForeground( ONGOING_NOTIFICATION_ID, builder.build() ) } }
Nunca intente reproducir audio usando su propio Servicio. Utilice siempre la API MediaSession como se describe aquí: https://developer.android.com/guide/topics/media-apps/audio-app/building-an-audio-app
Application.instance.isAppInForeground
¿Esta variable tiene el valor correcto? Tal vez esta variable tenga un valor incorrecto. ¿Podrías comprobar?