Diensttypen im Vordergrund

Ab Android 14 (API-Ebene 34) müssen Sie für jeden Dienst im Vordergrund einen geeigneten Diensttyp deklarieren. Das bedeutet, dass Sie den Diensttyp in Ihrem App-Manifest deklarieren und die entsprechende Berechtigung für Dienste im Vordergrund für diesen Typ anfordern müssen (zusätzlich zur Anforderung der Berechtigung FOREGROUND_SERVICE). Außerdem müssen Sie je nach Diensttyp möglicherweise Laufzeitberechtigungen anfordern, bevor Sie den Dienst starten.

Kamera

Typ des Diensts im Vordergrund, der im Manifest unter android:foregroundServiceType deklariert werden muss
camera
Berechtigung, die im Manifest deklariert werden muss
FOREGROUND_SERVICE_CAMERA
Konstante, die an startForeground() übergeben werden soll
FOREGROUND_SERVICE_TYPE_CAMERA
Voraussetzungen für die Laufzeit

CAMERA-Laufzeitberechtigung anfordern und erhalten

Beschreibung

Zugriff auf die Kamera im Hintergrund ist weiterhin möglich, z. B. über Videoanruf-Apps, die Multitasking zulassen.

Verbundenes Gerät

要在清单中的以下位置声明的前台服务类型
android:foregroundServiceType
connectedDevice
在清单中声明的权限
FOREGROUND_SERVICE_CONNECTED_DEVICE
要传递给 startForeground() 的常量
FOREGROUND_SERVICE_TYPE_CONNECTED_DEVICE
运行时前提条件

必须至少满足以下其中一个条件:

说明

与需要蓝牙、NFC、IR、USB 或网络连接的外部设备进行互动。

替代方案

如果您的应用需要向外部设备持续传输数据,请考虑改用配套设备管理器。使用配套设备感知 API,可帮助您的应用在配套设备在范围内时保持运行。

如果您的应用需要扫描蓝牙设备,请考虑改用 Bluetooth Scan API

Datensynchronisierung

Typ des Diensts im Vordergrund, der im Manifest unter
android:foregroundServiceType
dataSync
Berechtigung, die im Manifest deklariert werden muss
FOREGROUND_SERVICE_DATA_SYNC
Konstante, die an startForeground() übergeben werden soll
FOREGROUND_SERVICE_TYPE_DATA_SYNC
Voraussetzungen für die Laufzeit
Keine
Beschreibung

Vorgänge zur Datenübertragung, z. B.:

  • Daten hoch- oder herunterladen
  • Sicherungs- und Wiederherstellungsvorgänge
  • Import- oder Exportvorgänge
  • Daten abrufen
  • Lokale Dateiverarbeitung
  • Daten über ein Netzwerk zwischen einem Gerät und der Cloud übertragen
Alternativen

Ausführliche Informationen finden Sie unter Alternativen zu Vordergrunddiensten für die Datensynchronisierung.

Zustand

要在清单中的以下位置声明的前台服务类型
android:foregroundServiceType
health
在清单中声明的权限
FOREGROUND_SERVICE_HEALTH
要传递给 startForeground() 的常量
FOREGROUND_SERVICE_TYPE_HEALTH
运行时前提条件

必须至少满足以下其中一个条件:

说明

为健身类别的应用(例如锻炼追踪器)提供支持的所有长时间运行的用例。

Standort

要在清单中的以下位置声明的前台服务类型
android:foregroundServiceType
location
在清单中声明的权限
FOREGROUND_SERVICE_LOCATION
要传递给 startForeground() 的常量
FOREGROUND_SERVICE_TYPE_LOCATION
运行时前提条件

用户必须已启用位置信息服务,并且应用必须至少获得以下一项运行时权限:

说明

需要位置信息使用权的长时间运行的用例,例如导航和位置信息分享。

替代方案

如果您的应用需要在用户到达特定位置时触发,请考虑改用 Geofence API

Medien

Typ des Diensts im Vordergrund, der im Manifest unter
android:foregroundServiceType
mediaPlayback
Berechtigung, die im Manifest deklariert werden muss
FOREGROUND_SERVICE_MEDIA_PLAYBACK
Konstante, die an startForeground() übergeben werden soll
FOREGROUND_SERVICE_TYPE_MEDIA_PLAYBACK
Voraussetzungen für die Laufzeit
Keine
Beschreibung

Fortsetzung der Audio‑ oder Videowiedergabe im Hintergrund. Unterstützung der DVR-Funktion (Digital Video Recording) auf Android TV.

Alternativen

Wenn Sie ein Bild-im-Bild-Video präsentieren, verwenden Sie den Bild-im-Bild-Modus.

Medien werden verarbeitet.

Typ des Dienstes im Vordergrund, der im Manifest unter
android:foregroundServiceType
mediaProcessing
Berechtigung, die in Ihrem Manifest deklariert werden muss
FOREGROUND_SERVICE_MEDIA_PROCESSING
Konstante, die an startForeground() übergeben werden soll
FOREGROUND_SERVICE_TYPE_MEDIA_PROCESSING
Laufzeitvoraussetzungen
Keine
Beschreibung

Dienst zum Ausführen zeitaufwendiger Vorgänge auf Medien-Assets, z. B. zum Konvertieren von Medien in verschiedene Formate. Das System erlaubt diesem Dienst eine begrenzte Laufzeit. Unter normalen Umständen beträgt diese Zeitbeschränkung 6 Stunden pro 24 Stunden. Dieses Limit gilt für alle mediaProcessing-Dienste im Vordergrund einer App.

Ihre App sollte den Medienverarbeitungsdienst in folgenden Fällen manuell beenden:

Wenn die Zeitüberschreitung erreicht ist, ruft das System die Methode Service.onTimeout(int, int) des Dienstes auf. In dieser Zeit hat der Dienst einige Sekunden Zeit, Service.stopSelf() aufzurufen. Wenn der Dienst Service.stopSelf() nicht aufruft, wird eine ANR mit der folgenden Fehlermeldung ausgegeben: „Ein Dienst im Vordergrund von <fgs_type> wurde nicht innerhalb des Zeitlimits beendet: <component_name>“.

Hinweis: Service.onTimeout(int, int) ist unter Android 14 oder niedriger nicht verfügbar. Wenn auf Geräten mit diesen Versionen ein Medienverarbeitungsdienst die Zeitüberschreitung erreicht, wird die App sofort vom System im Cache gespeichert. Aus diesem Grund sollte Ihre App nicht auf eine Benachrichtigung zur Zeitüberschreitung warten. Stattdessen sollte der Dienst im Vordergrund so bald wie möglich beendet oder in einen Dienst im Hintergrund geändert werden.

Medienprojektion

Typ des Diensts im Vordergrund, der im Manifest unter
android:foregroundServiceType
mediaProjection
Berechtigung, die im Manifest deklariert werden muss
FOREGROUND_SERVICE_MEDIA_PROJECTION
Konstante, die an startForeground() übergeben werden soll
FOREGROUND_SERVICE_TYPE_MEDIA_PROJECTION
Voraussetzungen für die Laufzeit

Rufen Sie die Methode createScreenCaptureIntent() auf, bevor Sie den Dienst im Vordergrund starten. Dadurch wird dem Nutzer eine Berechtigungsbenachrichtigung angezeigt. Der Nutzer muss die Berechtigung erteilen, bevor Sie den Dienst erstellen können.

Nachdem Sie den Vordergrunddienst erstellt haben, können Sie MediaProjectionManager.getMediaProjection() aufrufen.

Beschreibung

Übertragung von Inhalten mit den MediaProjection APIs auf nicht primäre Displays oder externe Geräte. Diese Inhalte müssen nicht ausschließlich Medieninhalte sein.

Alternativen

Wenn Sie Medien auf ein anderes Gerät streamen möchten, verwenden Sie das Google Cast SDK.

Mikrofon

Typ des Diensts im Vordergrund, der im Manifest unter
android:foregroundServiceType
microphone
Berechtigung, die im Manifest deklariert werden muss
FOREGROUND_SERVICE_MICROPHONE
Konstante, die an startForeground() übergeben werden soll
FOREGROUND_SERVICE_TYPE_MICROPHONE
Voraussetzungen für die Laufzeit

Fordern Sie die Laufzeitberechtigung RECORD_AUDIO an und erhalten Sie sie.

Beschreibung

Mikrofonaufnahmen im Hintergrund fortsetzen, z. B. bei Sprachrekordern oder Kommunikations-Apps.

Telefonanruf

Typ des Diensts im Vordergrund, der im Manifest unter
android:foregroundServiceType
phoneCall
Berechtigung, die im Manifest deklariert werden muss
FOREGROUND_SERVICE_PHONE_CALL
Konstante, die an startForeground() übergeben werden soll
FOREGROUND_SERVICE_TYPE_PHONE_CALL
Voraussetzungen für die Laufzeit

Mindestens eine dieser Bedingungen muss erfüllt sein:

  • Die App hat die Berechtigung MANAGE_OWN_CALLS in ihrer Manifestdatei deklariert.
  • Die App ist die Standard-App fürs Telefonieren über die Rolle ROLE_DIALER.
Beschreibung

Sie können einen laufenden Anruf mit den ConnectionService APIs fortsetzen.

Alternativen

Wenn Sie Telefon-, Video- oder VoIP-Anrufe starten möchten, sollten Sie die android.telecom-Bibliothek verwenden.

Verwenden Sie CallScreeningService, um Anrufe zu filtern.

Remote-Messaging

Typ des Dienstes im Vordergrund, der im Manifest unter
android:foregroundServiceType
remoteMessaging
Berechtigung, die in Ihrem Manifest deklariert werden muss
FOREGROUND_SERVICE_REMOTE_MESSAGING
Konstante, die an startForeground() übergeben werden soll
FOREGROUND_SERVICE_TYPE_REMOTE_MESSAGING
Laufzeitvoraussetzungen
Keine
Beschreibung
Sie können Nachrichten von einem Gerät auf ein anderes übertragen. Unterstützt Nutzer beim Wechseln des Geräts, ohne dass die Messaging-Aufgaben weiter ausgeführt werden.

Kurzer Service

要在清单中的以下位置声明的前台服务类型
android:foregroundServiceType
shortService
在清单中声明的权限
要传递给 startForeground() 的常量
FOREGROUND_SERVICE_TYPE_SHORT_SERVICE
运行时前提条件
说明

快速完成不可中断或推迟的关键工作。

这种类型有一些独特的特征:

  • 只能持续运行一小段时间(大约 3 分钟)。
  • 不支持粘性前台服务。
  • 无法启动其他前台服务。
  • 不需要类型专用权限,不过它仍需要 FOREGROUND_SERVICE 权限。
  • 只有当应用当前符合启动新前台服务的条件时,shortService 才能更改为其他服务类型。
  • 前台服务可以随时将其类型更改为 shortService,届时超时期限将开始。

shortService 的超时时间从调用 Service.startForeground() 开始算起。应用应在发生超时之前调用 Service.stopSelf()Service.stopForeground()。否则,系统会调用新的 Service.onTimeout(),让应用有机会调用 stopSelf()stopForeground() 来停止其服务。

调用 Service.onTimeout() 后的短时间内,应用会进入缓存状态,并且不再被视为处于前台,除非用户正在主动与应用互动。应用缓存一小段时间后,服务还未停止,该应用会收到 ANR 消息。ANR 消息提及 FOREGROUND_SERVICE_TYPE_SHORT_SERVICE。出于这些原因,实现 Service.onTimeout() 回调被视为一种最佳实践。

Android 13 及更低版本中不存在 Service.onTimeout() 回调。如果同一服务在此类设备上运行,则不会出现超时,也不会发生 ANR。确保您的服务在完成处理任务后立即停止,即使它尚未收到 Service.onTimeout() 回调也是如此。

请务必注意,如果未遵循 shortService 的超时设置,即使应用还有其他有效的前台服务或其他应用生命周期进程,应用也会遇到 ANR。

如果应用对用户可见,或满足允许从后台启动前台服务的某一豁免条件,则使用 FOREGROUND_SERVICE_TYPE_SHORT_SERVICE 参数再次调用 Service.StartForeground() 会将超时时间再延长 3 分钟。如果应用对用户不可见且不满足其中一个豁免条件,则尝试启动其他前台服务(无论其类型如何)都会导致 ForegroundServiceStartNotAllowedException

即使用户为您的应用停用电池优化功能,仍然会受到 shortService FGS 的影响。

如果您启动包含 shortService 类型和另一个前台服务类型的前台服务,系统会忽略 shortService 类型声明。不过,该服务仍必须遵守其他声明类型的先决条件。如需了解详情,请参阅前台服务文档

Spezielle Anwendungsfälle

要在清单中声明的前台服务类型
android:foregroundServiceType
specialUse
在清单中声明的权限
FOREGROUND_SERVICE_SPECIAL_USE
要传递给 startForeground() 的常量
FOREGROUND_SERVICE_TYPE_SPECIAL_USE
运行时前提条件
说明

涵盖其他前台服务类型未涵盖的所有有效前台服务用例。

除了声明 FOREGROUND_SERVICE_TYPE_SPECIAL_USE 前台服务类型之外,开发者还应在清单中声明用例。为此,他们会在 <service> 元素内指定 <property> 元素。这些值和相应的应用场景 。用途 您提供的案例均为自由形式,因此,您应确保提供足够的 相关信息,让审核人员了解您为何需要使用 specialUse 类型。

<service android:name="fooService" android:foregroundServiceType="specialUse">
  <property android:name="android.app.PROPERTY_SPECIAL_USE_FGS_SUBTYPE"
      android:value="explanation_for_special_use"/>
</service>

Vom System ausgenommen

Typ des Dienstes im Vordergrund, der im Manifest deklariert werden soll unter
android:foregroundServiceType
systemExempted
Deklarierungsberechtigung im Manifest
FOREGROUND_SERVICE_SYSTEM_EXEMPTED
Konstante zur Übergabe an startForeground()
FOREGROUND_SERVICE_TYPE_SYSTEM_EXEMPTED
Laufzeitvoraussetzungen
Keine
Beschreibung

Ist für Systemanwendungen und bestimmte Systemintegrationen vorgesehen, um weiterhin Dienste im Vordergrund zu verwenden.

Zur Verwendung dieses Typs muss eine App mindestens eines der folgenden Kriterien erfüllen:

Durchsetzung der Google Play-Richtlinien für die Verwendung von Diensttypen im Vordergrund

Wenn Ihre App auf Android 14 oder höher ausgerichtet ist, müssen Sie die Typen der Dienste im Vordergrund Ihrer App auf der Seite „App-Inhalte“ in der Play Console (Richtlinie > App-Inhalte) deklarieren. Weitere Informationen dazu, wie Sie die Typen Ihrer Dienste im Vordergrund in der Play Console deklarieren, finden Sie unter Anforderungen für Dienste im Vordergrund und Full-Screen Intents.