Ön plan hizmeti türleri zorunludur

Android 10, geliştiricilerin kullanıcılara yönelik ön plan hizmetlerini daha bilinçli bir şekilde tanımlamasına yardımcı olmak için <service> öğesinde android:foregroundServiceType özelliğini kullanıma sundu.

Android 14'ü hedefleyen uygulamalar, uygun ön plan hizmeti türlerini belirtmelidir. Android'in önceki sürümlerinde de olduğu gibi birden fazla tür birlikte kullanılabilir. Aşağıdaki listede, aralarından seçim yapabileceğiniz ön plan hizmeti türleri gösterilmektedir:

Uygulamanızdaki kullanım alanı bu türlerden hiçbiriyle ilişkilendirilmemişse mantığınızı WorkManager veya kullanıcı tarafından başlatılan veri aktarımı işlerini kullanacak şekilde taşımanızı öneririz.

health, remoteMessaging, shortService, specialUse ve systemExempted türleri, Android 14'te yenidir.

Aşağıdaki kod snippet'inde, manifest dosyasında ön plan hizmeti türü beyanı örneği verilmiştir:

<manifest ...>
  <uses-permission android:name="android.permission.FOREGROUND_SERVICE" />
  <uses-permission android:name="android.permission.FOREGROUND_SERVICE_MEDIA_PLAYBACK" />
    <application ...>
      <service
          android:name=".MyMediaPlaybackService"
          android:foregroundServiceType="mediaPlayback"
          android:exported="false">
      </service>
    </application>
</manifest>

Android 14'ü hedefleyen bir uygulama, manifest dosyasında belirli bir hizmet için türleri tanımlamazsa sistem, söz konusu hizmet için startForeground() çağrıldıktan sonra MissingForegroundServiceTypeException hatası oluşturur.

Ön plan hizmeti türlerini kullanmak için yeni izin bildir

Android 14'ü hedefleyen uygulamalarda bir ön plan hizmeti kullanılacaksa Android 14'te kullanıma sunulan, ön plan hizmet türüne bağlı belirli bir izni belirtmeleri gerekir. Bu izinler, bu sayfadaki her ön plan hizmeti türü için amaçlanan kullanım alanları ve yaptırım bölümündeki "manifest dosyanızda beyan etmeniz gereken izin" etiketli bölümlerde görünür.

Tüm izinler normal izinler olarak tanımlanır ve varsayılan olarak verilir. Kullanıcılar bu izinleri iptal edemez.

Çalışma zamanında ön plan hizmet türünü ekleme

Ön plan hizmetlerini başlatan uygulamalar için en iyi uygulama, ön plan hizmet türlerinin bitsel bir tam sayı değerini ilettiğiniz startForeground() işlevinin ServiceCompat sürümünü (androidx-core 1.12 ve sonraki sürümlerde kullanılabilir) kullanmaktır. Bir veya daha fazla tür değeri iletmeyi seçebilirsiniz.

Genellikle yalnızca belirli bir kullanım alanı için gereken türleri tanımlamanız gerekir. Bu sayede sistemin her ön plan hizmet türüne dair beklentilerini karşılayabilirsiniz. Bir ön plan hizmetinin birden fazla türle başlatıldığı durumlarda, ön plan hizmeti tüm türlerin platform yaptırım koşullarına uymalıdır.

ServiceCompat.startForeground(0, notification, FOREGROUND_SERVICE_TYPE_LOCATION)

Ön plan hizmet türü çağrıda belirtilmezse tür varsayılan olarak manifest'te tanımlanan değerlere ayarlanır. Manifest'te hizmet türünü belirtmediyseniz sistem MissingForegroundServiceTypeException hatası verir.

Ön plan hizmetini başlattıktan sonra yeni izinlere ihtiyacı olursa startForeground() işlevini tekrar çağırıp yeni hizmet türlerini eklemeniz gerekir. Örneğin, bir fitness uygulamasının her zaman location bilgisine ihtiyaç duyan ancak media izinlerine ihtiyaç duyabilecek ya da gerekmeyebilecek bir koşu takip aracı hizmeti çalıştırdığını varsayalım. Manifestte hem location hem de mediaPlayback öğelerini belirtmeniz gerekir. Bir kullanıcı koşuya başlar ve yalnızca konumunun izlenmesini isterse uygulamanız startForeground() işlevini çağırmalı ve yalnızca location hizmet türünü iletmelidir. Ardından, kullanıcı ses oynatmaya başlamak isterse startForeground() işlevini tekrar çağırın ve location|mediaPlayback parametresini iletin.

Sistem çalışma zamanı kontrolleri

Sistem, ön plan hizmeti türlerinin uygun şekilde kullanılıp kullanılmadığını kontrol eder ve uygulamanın, çalışma zamanında doğru izinleri istediğini veya gerekli API'leri kullandığını onaylar. Örneğin, sistem, FOREGROUND_SERVICE_TYPE_LOCATION ön plan hizmet türünü kullanan uygulamaların ACCESS_COARSE_LOCATION veya ACCESS_FINE_LOCATION iznini istemesini bekler.

Bu, uygulamaların kullanıcıdan izin isterken ve ön plan hizmetlerini başlatırken çok özel bir işlem sırasını izlemesi gerektiği anlamına gelir. İzinler, uygulama startForeground() çağrısına başlamadan önce istenmeli ve verilmelidir. Ön plan hizmeti başlatıldıktan sonra uygun izinleri isteyen uygulamalar bu işlem sırasını değiştirmeli ve ön plan hizmetini başlatmadan önce izin istemelidir.

Platform yaptırımıyla ilgili ayrıntılar, bu sayfadaki her ön plan hizmeti türü için amaçlanan kullanım alanları ve yaptırım bölümündeki "çalışma zamanı gereksinimleri" etiketli bölümlerde yer alır.

Her ön plan hizmet türü için amaçlanan kullanım alanları ve yaptırım

Belirli bir ön plan hizmet türünü kullanmak için manifest dosyanızda belirli bir izni beyan etmeniz, belirli çalışma zamanı koşullarını karşılamanız ve uygulamanızın, söz konusu tür için amaçlanan kullanım alanı gruplarından birini karşılaması gerekir. Aşağıdaki bölümlerde, beyan etmeniz gereken izin, çalışma zamanı ön koşulları ve her türün amaçlanan kullanım alanları açıklanmaktadır.

Kamera

Foreground service type to declare in manifest under android:foregroundServiceType
camera
Permission to declare in your manifest
FOREGROUND_SERVICE_CAMERA
Constant to pass to startForeground()
FOREGROUND_SERVICE_TYPE_CAMERA
Runtime prerequisites

Request and be granted the CAMERA runtime permission

Note: The CAMERA runtime permission is subject to while-in-use restrictions. For this reason, you cannot create a camera foreground service while your app is in the background, with a few exceptions. For more information, see Restrictions on starting foreground services that need while-in-use permissions.

Description

Continue to access the camera from the background, such as video chat apps that allow for multitasking.

Bağlı cihaz

Manifest dosyasında aşağıdaki altında beyan edilecek ön plan hizmet türü
android:foregroundServiceType
connectedDevice
Manifest dosyanızda beyan etme izni
FOREGROUND_SERVICE_CONNECTED_DEVICE
startForeground() işlevine iletilecek sabit değer
FOREGROUND_SERVICE_TYPE_CONNECTED_DEVICE
Çalışma zamanı ön koşulları

Aşağıdaki koşullardan en az biri doğru olmalıdır:

Açıklama

Bluetooth, NFC, IR, USB veya ağ bağlantısı gerektiren harici cihazlarla olan etkileşimler.

Alternatifler

Uygulamanızın harici bir cihaza sürekli veri aktarması gerekiyorsa bunun yerine companion device manager'ı kullanabilirsiniz. Tamamlayıcı cihaz kapsam içindeyken uygulamanızın çalışmaya devam etmesine yardımcı olmak için tamamlayıcı cihaz varlığı API'sini kullanın.

Uygulamanızın Bluetooth cihazları taraması gerekiyorsa bunun yerine Bluetooth tarama API'sini kullanabilirsiniz.

Veri senkronizasyonu

Manifest dosyasında aşağıdaki altında beyan edilecek ön plan hizmet türü
android:foregroundServiceType
dataSync
Manifest dosyanızda beyan etme izni
FOREGROUND_SERVICE_DATA_SYNC
startForeground() işlevine iletilecek sabit değer
FOREGROUND_SERVICE_TYPE_DATA_SYNC
Çalışma zamanı ön koşulları
Yok
Açıklama

Aşağıdakiler gibi veri aktarma işlemleri:

  • Veri yükleme veya indirme
  • Yedekleme ve geri yükleme işlemleri
  • İçe veya dışa aktarma işlemleri
  • Veri getirme
  • Yerel dosya işleme
  • Ağ üzerinden bir cihaz ile bulut arasında veri aktarma
Alternatifler

Ayrıntılı bilgi için Veri senkronizasyonu ön plan hizmetlerine alternatifler başlıklı makaleyi inceleyin.

Sağlık

Manifest dosyasında aşağıdaki altında beyan edilecek ön plan hizmet türü
android:foregroundServiceType
health
Manifest dosyanızda beyan etme izni
FOREGROUND_SERVICE_HEALTH
startForeground() işlevine iletilen sabit değer
FOREGROUND_SERVICE_TYPE_HEALTH
Çalışma zamanı ön koşulları

Aşağıdaki koşullardan en az biri doğru olmalıdır:

Not: BODY_SENSORS ve sensör tabanlı OKU çalışma zamanında istenen izinleri, kullanım sırasındaki kısıtlamalara tabidir. Bu nedenle, BODY_SENSORS_BACKGROUND (API düzeyi 33 ila 35) veya READ_HEALTH_DATA_IN_BACKGROUND (API düzeyi 36 ve üzeri) izinleri verilmedikçe uygulamanız arka plandayken vücut sensörlerini kullanan bir health ön plan hizmeti oluşturamazsınız. Daha fazla bilgi için Kullanımdayken izin gerektiren ön plan hizmetlerini başlatmayla ilgili kısıtlamalar başlıklı makaleyi inceleyin.

Açıklama

Fitness kategorisindeki uygulamaları (ör. egzersiz takipçileri) desteklemek için uzun süredir kullanılan tüm kullanım alanları.

Konum

Manifest dosyasında aşağıdaki altında beyan edilecek ön plan hizmet türü
android:foregroundServiceType
location
Manifest dosyanızda beyan etme izni
FOREGROUND_SERVICE_LOCATION
startForeground() işlevine iletilecek sabit değer
FOREGROUND_SERVICE_TYPE_LOCATION
Çalışma zamanı ön koşulları

Kullanıcının konum hizmetlerini etkinleştirmiş olması ve uygulamaya aşağıdaki çalışma zamanında istenen izinlerden en az biri verilmiş olmalıdır:

Not: Kullanıcının konum hizmetlerini etkinleştirip etkinleştirmediğini ve çalışma zamanında izinlere erişim izni verip vermediğini kontrol etmek için PermissionChecker#checkSelfPermission()

Not: Çalışma zamanı konum izinleri, kullanım sırasındaki kısıtlamalara tabidir. Bu nedenle, ACCESS_BACKGROUND_LOCATION çalışma zamanında izin verilmedikçe uygulamanız arka plandayken location ön plan hizmeti oluşturamazsınız. Daha fazla bilgi için Kullanımdayken izin gerektiren ön plan hizmetlerini başlatmayla ilgili kısıtlamalar başlıklı makaleyi inceleyin.

Açıklama

Navigasyon ve konum paylaşımı gibi konum erişimi gerektiren uzun süreli kullanım alanları.

Alternatifler

Kullanıcı belirli konumlara ulaştığında uygulamanızın tetiklenmesi gerekiyorsa bunun yerine coğrafi çit API'sini kullanabilirsiniz.

Medya

Foreground service type to declare in manifest under
android:foregroundServiceType
mediaPlayback
Permission to declare in your manifest
FOREGROUND_SERVICE_MEDIA_PLAYBACK
Constant to pass to startForeground()
FOREGROUND_SERVICE_TYPE_MEDIA_PLAYBACK
Runtime prerequisites
None
Description
Continue audio or video playback from the background. Support Digital Video Recording (DVR) functionality on Android TV.
Alternatives
If you're showing picture-in-picture video, use Picture-in-Picture mode.

Medya projeksiyonu

Manifest dosyasında aşağıdaki altında beyan edilecek ön plan hizmet türü
android:foregroundServiceType
mediaProjection
Manifest dosyanızda beyan etme izni
FOREGROUND_SERVICE_MEDIA_PROJECTION
startForeground() işlevine iletilecek sabit değer
FOREGROUND_SERVICE_TYPE_MEDIA_PROJECTION
Çalışma zamanı ön koşulları

Ön plan hizmetini başlatmadan önce createScreenCaptureIntent() yöntemini çağırın. Bu işlem, kullanıcıya bir izin bildirimi gösterir. Hizmeti oluşturabilmeniz için kullanıcının izin vermesi gerekir.

Ön plan hizmetini oluşturduktan sonra MediaProjectionManager.getMediaProjection() işlevini çağırabilirsiniz.

Açıklama

MediaProjection API'lerini kullanarak içeriği birincil olmayan ekrana veya harici cihaza yansıtın. Bu içeriğin yalnızca medya içeriği olması gerekmez.

Alternatifler

Medyayı başka bir cihaza aktarmak için Google Cast SDK'sını kullanın.

Mikrofon

Manifest dosyasında aşağıdaki altında beyan edilecek ön plan hizmet türü
android:foregroundServiceType
microphone
Manifest dosyanızda beyan etme izni
FOREGROUND_SERVICE_MICROPHONE
startForeground() işlevine iletilecek sabit değer
FOREGROUND_SERVICE_TYPE_MICROPHONE
Çalışma zamanı ön koşulları

RECORD_AUDIO çalışma zamanı iznini isteyin ve izni alın.

Not: RECORD_AUDIO çalışma zamanı izni, kullanım sırasındaki kısıtlamalara tabidir. Bu nedenle, birkaç istisna dışında uygulamanız arka plandayken microphone ön plan hizmeti oluşturamazsınız. Daha fazla bilgi için Kullanımdayken izin gerektiren ön plan hizmetlerini başlatmayla ilgili kısıtlamalar başlıklı makaleyi inceleyin.

Açıklama

Ses kaydediciler veya iletişim uygulamaları gibi mikrofon kayıtlarına arka planda devam edin.

Sesli arama

Foreground service type to declare in manifest under
android:foregroundServiceType
phoneCall
Permission to declare in your manifest
FOREGROUND_SERVICE_PHONE_CALL
Constant to pass to startForeground()
FOREGROUND_SERVICE_TYPE_PHONE_CALL
Runtime prerequisites

At least one of these conditions must be true:

  • App is the default dialer app through the ROLE_DIALER role.
Description

Continue an ongoing call using the ConnectionService APIs.

Alternatives

If you need to make phone, video, or VoIP calls, consider using the android.telecom library.

Consider using CallScreeningService to screen calls.

Uzaktan mesajlaşma

Foreground service type to declare in manifest under
android:foregroundServiceType
remoteMessaging
Permission to declare in your manifest
FOREGROUND_SERVICE_REMOTE_MESSAGING
Constant to pass to startForeground()
FOREGROUND_SERVICE_TYPE_REMOTE_MESSAGING
Runtime prerequisites
None
Description
Transfer text messages from one device to another. Assists with continuity of a user's messaging tasks when they switch devices.

Kısa servis

Foreground service type to declare in manifest under
android:foregroundServiceType
shortService
Permission to declare in your manifest
None
Constant to pass to startForeground()
FOREGROUND_SERVICE_TYPE_SHORT_SERVICE
Runtime prerequisites
None
Description

Quickly finish critical work that cannot be interrupted or postponed.

This type has some unique characteristics:

  • Can only run for a short period of time (about 3 minutes).
  • No support for sticky foreground services.
  • Cannot start other foreground services.
  • Doesn't require a type-specific permission, though it still requires the FOREGROUND_SERVICE permission.
  • A shortService can only change to another service type if the app is currently eligible to start a new foreground service.
  • A foreground service can change its type to shortService at any time, at which point the timeout period begins.

The timeout for shortService begins from the moment that Service.startForeground() is called. The app is expected to call Service.stopSelf() or Service.stopForeground() before the timeout occurs. Otherwise, the new Service.onTimeout() is called, giving apps a brief opportunity to call stopSelf() or stopForeground() to stop their service.

A short time after Service.onTimeout() is called, the app enters a cached state and is no longer considered to be in the foreground, unless the user is actively interacting with the app. A short time after the app is cached and the service has not stopped, the app receives an ANR. The ANR message mentions FOREGROUND_SERVICE_TYPE_SHORT_SERVICE. For these reasons, it's considered best practice to implement the Service.onTimeout() callback.

The Service.onTimeout() callback doesn't exist on Android 13 and lower. If the same service runs on such devices, it doesn't receive a timeout, nor does it ANR. Make sure that your service stops as soon as it finishes the processing task, even if it hasn't received the Service.onTimeout() callback yet.

It's important to note that if the timeout of the shortService is not respected, the app will ANR even if it has other valid foreground services or other app lifecycle processes running.

If an app is visible to the user or satisfies one of the exemptions that allow foreground services to be started from the background, calling Service.StartForeground() again with the FOREGROUND_SERVICE_TYPE_SHORT_SERVICE parameter extends the timeout by another 3 minutes. If the app isn't visible to the user and doesn't satisfy one of the exemptions, any attempt to start another foreground service, regardless of type, causes a ForegroundServiceStartNotAllowedException.

If a user disables battery optimization for your app, it's still affected by the timeout of shortService FGS.

If you start a foreground service that includes the shortService type and another foreground service type, the system ignores the shortService type declaration. However, the service must still adhere to the prerequisites of the other declared types. For more information, see the Foreground services documentation.

Özel kullanım

Manifest dosyasında tanımlanacak ön plan hizmet türü
android:foregroundServiceType
specialUse
Manifest'inizde beyan etme izni
FOREGROUND_SERVICE_SPECIAL_USE
startForeground() noktasına ulaşılmasına kalan süre
FOREGROUND_SERVICE_TYPE_SPECIAL_USE
Çalışma zamanı ön koşulları
Yok
Açıklama

Diğer ön plan hizmeti kapsamı dışındaki geçerli ön plan hizmeti kullanım alanlarını kapsar. ön plan hizmet türleri için kullanılır.

FOREGROUND_SERVICE_TYPE_SPECIAL_USE beyana ek olarak, ön plan hizmet türüyle birlikte, geliştiricilerin kullanım alanlarını manifest'ini kullanabilirsiniz. Bunu yapmak için<property> <service> öğesi. Bu değerler ve karşılık gelen kullanım alanları şunlardır: incelenir. Kullanım sağladığınız örnekler serbest biçimli olmalıdır ve bunun için yeterli miktarda incelemecinin specialUse öğesini neden kullanmanız gerektiğini bilmesi için gerekli bilgileri türü.

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

Sistem muaf

Manifest dosyasında aşağıdaki altında beyan edilecek ön plan hizmet türü
android:foregroundServiceType
systemExempted
Manifest dosyanızda beyan etme izni
FOREGROUND_SERVICE_SYSTEM_EXEMPTED
startForeground() işlevine iletilecek sabit değer
FOREGROUND_SERVICE_TYPE_SYSTEM_EXEMPTED
Çalışma zamanı ön koşulları
Yok
Açıklama

Ön plan hizmetlerini kullanmaya devam etmek için sistem uygulamaları ve belirli sistem entegrasyonları için ayrılmıştır.

Bu türü kullanmak isteyen uygulamaların aşağıdaki ölçütlerden en az birini karşılaması gerekir:

  • Cihaz demo modunda
  • Uygulama, cihaz sahibidir.
  • Uygulama, Profil Oluşturucu Sahibi
  • ROLE_EMERGENCY rolüne sahip güvenlik uygulamaları
  • Cihaz Yöneticisi uygulamaları
  • SCHEDULE_EXACT_ALARM veya USE_EXACT_ALARM iznine sahip olan ve yalnızca dokunma alarmları da dahil olmak üzere alarmları arka planda devam ettirmek için ön plan hizmetini kullanan uygulamalar.
  • VPN uygulamaları (Ayarlar > Ağ ve İnternet > VPN kullanılarak yapılandırılır)

    Aksi takdirde, bu türün tanımlanması sistemin ForegroundServiceTypeNotAllowedException hatası vermesine neden olur.

Ön plan hizmet türlerinin kullanımıyla ilgili Google Play politika yaptırımı

Uygulamanız Android 14 veya sonraki sürümleri hedefliyorsa uygulamanızın ön plan hizmet türlerini Play Console'un uygulama içeriği sayfasında (Politika > Uygulama içeriği) belirtmeniz gerekir. Play Console'da ön plan hizmet türlerinizi nasıl beyan edeceğiniz hakkında daha fazla bilgi için Ön plan hizmetini ve tam ekran intent şartlarını anlama başlıklı makaleyi inceleyin.