android-components/components/feature/media/README.md

68 lines
2.3 KiB
Markdown
Raw Permalink Normal View History

2023-11-28 09:10:03 +01:00
# [Android Components](../../../README.md) > Feature > Media
Feature component for website media related features.
## Usage
Add the push service for controlling the media session:
```kotlin
class MediaSessionService(
override val store: BrowserStore,
override val crashReporter: CrashReporting
) : AbstractMediaSessionService()
```
Expose the service in the `AndroidManifest.xml`:
```xml
<service android:name=".media.MediaSessionService"
android:foregroundServiceType="mediaPlayback"
android:exported="false" />
```
2024-02-18 09:20:44 +01:00
The `AbstractMediaSessionService` also requires extra permissions needed to post notification updates on media changes:
- `android.permission.POST_NOTIFICATIONS`
- `android.permission.FOREGROUND_SERVICE`
- `android.permission.FOREGROUND_SERVICE_MEDIA_PLAYBACK`
2023-11-28 09:10:03 +01:00
### Setting up the dependency
Use Gradle to download the library from [maven.mozilla.org](https://maven.mozilla.org/) ([Setup repository](../../../README.md#maven-repository)):
```Groovy
implementation "org.mozilla.components:feature-media:{latest-version}"
```
### Notification: Recording devices
2024-02-18 09:20:44 +01:00
`RecordingDevicesMiddleware` can be used to show an ongoing notification when a recording device (camera,
2023-11-28 09:10:03 +01:00
microphone) is used by web content. Notifications will be shown in the "Media" notification channel.
This feature should only be initialized once globally:
```kotlin
2024-02-18 09:20:44 +01:00
BrowserStore(
middleware = listOf(
RecordingDevicesMiddleware(applicationContext, notificationsDelegate)
)
)
2023-11-28 09:10:03 +01:00
```
## Facts
This component emits the following [Facts](../../support/base/README.md#Facts):
| Action | Item | Description |
|--------|-----------------|-------------------------------------------|
| PLAY | state | Media started playing. |
| PAUSE | state | Media playback was paused. |
| STOP | state | Media playback has ended. |
| PLAY | notification | Play action of notification was invoked |
| PAUSE | notification | Pause action of notification was invoked |
## License
This Source Code Form is subject to the terms of the Mozilla Public
License, v. 2.0. If a copy of the MPL was not distributed with this
file, You can obtain one at http://mozilla.org/MPL/2.0/