Ön plan hizmeti türleri

Android 14'ten (API düzeyi 34) itibaren her ön plan hizmeti için uygun bir hizmet türü tanımlamanız gerekir. Yani, uygulama manifestinizde hizmet türünü beyan etmeniz ve söz konusu tür için uygun ön plan hizmeti iznini istemeniz (FOREGROUND_SERVICE iznini istemeye ek olarak) gerekir. Ayrıca ön plan hizmet türüne bağlı olarak, hizmeti başlatmadan önce çalışma zamanı izinleri istemeniz gerekebilir.

Kamera

android:foregroundServiceType kapsamında manifestte bildirilecek ön plan hizmet türü
camera
Manifest'inizde beyan izni
FOREGROUND_SERVICE_CAMERA
startForeground() sabittir
FOREGROUND_SERVICE_TYPE_CAMERA
Çalışma zamanı ön koşulları

CAMERA çalışma zamanı iznini isteme ve alma

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

Açıklama

Çoklu görev yapılmasına olanak tanıyan görüntülü sohbet uygulamaları gibi arka plandan kameraya erişmeye devam edin.

Bağlı cihaz

Manifest'te bildirilecek ön plan hizmet türü
android:foregroundServiceType
connectedDevice
Manifest'inizde beyan izni
FOREGROUND_SERVICE_CONNECTED_DEVICE
startForeground() sabittir
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 etkileşimler.

Alternatifler

Uygulamanızın harici bir cihaza sürekli veri aktarımı gerçekleştirmesi gerekiyorsa bunun yerine tamamlayıcı cihaz yöneticisini kullanmayı düşünebilirsiniz. Tamamlayıcı cihaz kapsama alanındayken 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 kullanmayı düşünün.

Veri senkronizasyonu

Manifest'te bildirilecek ön plan hizmet türü
android:foregroundServiceType
dataSync
Manifest'inizde beyan izni
FOREGROUND_SERVICE_DATA_SYNC
startForeground() sabittir
FOREGROUND_SERVICE_TYPE_DATA_SYNC
Çalışma zamanı ön koşulları
Yok
Açıklama

Aşağıdakiler gibi veri aktarımı işlemleri:

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

Kullanıcıların uzun süreli veri yükleme işlemi başlatmasına veya görevleri indirmesine olanak tanımak için kullanıcı tarafından başlatılan veri aktarımı işleri oluşturun.

Bir URI'den veri indirmek için indirme yöneticisi API'sini kullanın.

Verileri yedeklemek veya geri yüklemek için BackupManager'i kullanın.

Diğer kullanım alanları için WorkManager'ı kullanmayı düşünün.

Sağlık

Manifestte bildirilecek ön plan hizmeti türü
android:foregroundServiceType
health
Manifest dosyanızda beyan etme izni
FOREGROUND_SERVICE_HEALTH
startForeground() için sabit geçiş
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 çalışma zamanı izni, kullanım sırasındaki kısıtlamalara tabidir. Bu nedenle, birkaç istisna dışında, uygulamanız arka plandayken vücut sensörlerini kullanan bir health ön plan hizmeti oluşturamazsınız. Daha fazla bilgi için Kullanım sırasında izin gerektiren ön plan hizmetlerinin başlatılmasıyla ilgili kısıtlamalar bölümüne bakın.

Açıklama

Fitness kategorisindeki uygulamaları destekleyen uzun süreli kullanım alanları (ör. egzersiz izleyiciler).

Konum

Manifest'te bildirilecek ön plan hizmet türü
android:foregroundServiceType
location
Manifest'inizde beyan izni
FOREGROUND_SERVICE_LOCATION
startForeground() sabittir
FOREGROUND_SERVICE_TYPE_LOCATION
Çalışma zamanı ön koşulları

Aşağıdaki çalışma zamanında istenen izinlerden en az birini isteyin ve alın:

Not: Konum çalışma zamanında istenen izinler, kullanım sırasındaki kısıtlamalara tabidir. Bu nedenle, birkaç istisna dışında uygulamanız arka plandayken location ön plan hizmeti oluşturamazsınız. Daha fazla bilgi için Kullanım sırasında izin gerektiren ön plan hizmetlerini başlatmayla ilgili kısıtlamalar bölümüne bakın.

Açıklama

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

Alternatifler

Uygulamanızın, kullanıcı belirli konumlara ulaştığında tetiklenmesi gerekiyorsa bunun yerine geofence API'yi kullanmayı düşünün.

Medya

Manifest'te bildirilecek ön plan hizmet türü
android:foregroundServiceType
mediaPlayback
Manifest'inizde beyan izni
FOREGROUND_SERVICE_MEDIA_PLAYBACK
startForeground() sabittir
FOREGROUND_SERVICE_TYPE_MEDIA_PLAYBACK
Çalışma zamanı ön koşulları
Yok
Açıklama
Arka planda ses veya video oynatmaya devam etme. Android TV'de Dijital Video Kayıt (DVR) işlevini destekler.
Alternatifler
Pencere içinde pencere modunda video gösteriyorsanız Pencere İçinde Pencere modunu kullanın.

Medya projeksiyonu

Manifest'te bildirilecek ön plan hizmet türü
android:foregroundServiceType
mediaProjection
Manifest'inizde beyan izni
FOREGROUND_SERVICE_MEDIA_PROJECTION
startForeground() sabittir
FOREGROUND_SERVICE_TYPE_MEDIA_PROJECTION
Çalışma zamanı ön koşulları

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

Ön plan hizmetini oluşturduktan sonra MediaProjectionManager.getMediaProjection() yöntemini ç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ğinden olması gerekmez.

Alternatifler

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

Mikrofon

Manifest'te bildirilecek ön plan hizmet türü
android:foregroundServiceType
microphone
Manifest'inizde beyan izni
FOREGROUND_SERVICE_MICROPHONE
startForeground() sabittir
FOREGROUND_SERVICE_TYPE_MICROPHONE
Çalışma zamanı ön koşulları

RECORD_AUDIO çalışma zamanı iznini isteyin ve 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ım sırasında izin gerektiren ön plan hizmetlerini başlatmayla ilgili kısıtlamalar bölümüne bakın.

Açıklama

Mikrofonu ses kaydediciler veya iletişim uygulamaları gibi arka planda kaydetmeye devam edin.

Sesli arama

Manifest'te bildirilecek ön plan hizmet türü
android:foregroundServiceType
phoneCall
Manifest'inizde beyan izni
FOREGROUND_SERVICE_PHONE_CALL
startForeground() sabittir
FOREGROUND_SERVICE_TYPE_PHONE_CALL
Çalışma zamanı ön koşulları

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

  • Uygulama, ROLE_DIALER rolü sayesinde varsayılan numara çevirici uygulamasıdır.
Açıklama

Devam eden bir çağrıya ConnectionService API'lerini kullanarak devam edin.

Alternatifler

Telefon, görüntülü veya VoIP aramaları yapmanız gerekiyorsa android.telecom kitaplığını kullanabilirsiniz.

Aramaları filtrelemek için CallScreeningService aracını kullanabilirsiniz.

Uzaktan mesajlaşma

Manifestte bildirilecek ön plan hizmeti türü
android:foregroundServiceType
remoteMessaging
Manifest dosyanızda beyan etme izni
FOREGROUND_SERVICE_REMOTE_MESSAGING
startForeground() için sabit geçiş
FOREGROUND_SERVICE_TYPE_REMOTE_MESSAGING
Çalışma zamanı ön koşulları
Hiçbiri
Açıklama
Kısa mesajları bir cihazdan diğerine aktarın. Cihaz değiştirdiğinde kullanıcıların mesajlaşma görevlerinin devam etmesine yardımcı olur.

Kısa servis

Manifestte bildirilecek ön plan hizmeti türü
android:foregroundServiceType
shortService
Manifest dosyanızda beyan etme izni
Hiçbiri
startForeground() için sabit geçiş
FOREGROUND_SERVICE_TYPE_SHORT_SERVICE
Çalışma zamanı ön koşulları
Hiçbiri
Açıklama

Kesilemeyen veya ertelenemeyen kritik işleri hızla bitirin.

Bu türün bazı benzersiz özellikleri vardır:

  • Yalnızca kısa bir süre (yaklaşık 3 dakika) için çalıştırılabilir.
  • Yapışkan ön plan hizmetleri için destek sunulmaz.
  • Diğer ön plan hizmetleri başlatılamaz.
  • Türe özel izin gerektirmez ancak yine de FOREGROUND_SERVICE iznini gerektirir.
  • shortService öğesinin başka bir hizmet türüne geçmesi, yalnızca uygulamanın şu anda yeni bir ön plan hizmeti başlatmaya uygun olması durumunda mümkündür.
  • Bir ön plan hizmeti, türünü istediği zaman shortService olarak değiştirebilir. Bu noktada zaman aşımı süresi başlar.

ShortService için zaman aşımı Service.startForeground() hizmetinin çağrıldığı anda başlar. Uygulamanın, zaman aşımı gerçekleşmeden önce Service.stopSelf() veya Service.stopForeground() yöntemini çağırması beklenir. Aksi takdirde, yeni Service.onTimeout() çağrılır; bu da uygulamalara, hizmetlerini durdurmaları için kısa bir süre içinde stopSelf() veya stopForeground() numarasını arama fırsatı verir.

Service.onTimeout() çağrıldıktan kısa bir süre sonra uygulama önbelleğe alınmış duruma girer ve kullanıcı etkin bir şekilde uygulamayla etkileşimde bulunmadığı sürece artık ön planda kabul edilmez. Uygulama önbelleğe alındıktan ve hizmet durdurulmadan kısa bir süre sonra uygulama bir ANR alır. ANR mesajında FOREGROUND_SERVICE_TYPE_SHORT_SERVICE bahsediliyor. Bu nedenlerle, Service.onTimeout() geri çağırmanın uygulanması en iyi uygulama olarak kabul edilir.

Service.onTimeout() geri çağırma özelliği Android 13 ve önceki sürümlerde mevcut değildir. Aynı hizmet bu tür cihazlarda çalışıyorsa zaman aşımı olmaz ve ANR de yaşanmaz. Hizmetinizin işleme görevini tamamlar tamamlamaz (Service.onTimeout() geri çağırma işlemini henüz almamış olsa bile) durduğundan emin olun.

shortService zaman aşımına uyulmadığı takdirde, başka geçerli ön plan hizmetleri veya çalışan başka uygulama yaşam döngüsü süreçleri olsa bile uygulamanın ANR oluşturacağını unutmayın.

Bir uygulama kullanıcı tarafından görülebiliyorsa veya ön plan hizmetlerinin arka plandan başlatılmasına izin veren muafiyetlerden birini karşılıyorsa FOREGROUND_SERVICE_TYPE_SHORT_SERVICE parametresiyle Service.StartForeground() öğesinin tekrar çağrılması zaman aşımını 3 dakika daha uzatır. Uygulama kullanıcı tarafından görülmüyorsa ve muafiyetlerden birini karşılamıyorsa türden bağımsız olarak başka bir ön plan hizmeti başlatma girişimi ForegroundServiceStartNotAllowedException hatasına neden olur.

Bir kullanıcı uygulamanız için pil optimizasyonunu devre dışı bıraksa bile, shortService ön plan hizmetlerini devre dışı bırakan uygulama, yine de kısa süreli bir çözüm olarak kullanılır.

shortService türünü ve başka bir ön plan hizmet türünü içeren bir ön plan hizmeti başlatırsanız sistem, shortService türü beyanını yoksayar. Ancak hizmetin yine de bildirilen diğer türlerin ön koşullarına uyması gerekir. Daha fazla bilgi için Ön plan hizmetleri belgelerine bakın.

Özel kullanım

Manifestte bildirilecek ön plan hizmeti türü
android:foregroundServiceType
specialUse
Manifest dosyanızda beyan etme izni
FOREGROUND_SERVICE_SPECIAL_USE
startForeground() için sabit geçiş
FOREGROUND_SERVICE_TYPE_SPECIAL_USE
Çalışma zamanı ön koşulları
Hiçbiri
Açıklama

Diğer ön plan hizmet türlerinin kapsamına girmeyen geçerli tüm ön plan hizmeti kullanım alanlarını kapsar.

Geliştiriciler, FOREGROUND_SERVICE_TYPE_SPECIAL_USE ön plan hizmet türünü belirtmenin yanı sıra kullanım alanlarını da manifest dosyasında beyan etmelidir. Bunu yapmak için <service> öğesi içinde <property> öğesini belirtirler. Bu değerler ve karşılık gelen kullanım alanları, uygulamanızı Google Play Console'a gönderdiğinizde incelenir. Sağladığınız kullanım alanları serbest biçimlidir ve incelemecinin specialUse türünü neden kullanmanız gerektiğini anlayabilmesi için yeterli bilgi sağladığınızdan emin olun.

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

Sistemden muaf

Manifestte bildirilecek ön plan hizmeti türü
android:foregroundServiceType
systemExempted
Manifest dosyanızda beyan etme izni
FOREGROUND_SERVICE_SYSTEM_EXEMPTED
startForeground() için sabit geçiş
FOREGROUND_SERVICE_TYPE_SYSTEM_EXEMPTED
Çalışma zamanı ön koşulları
Hiçbiri
Açıklama

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

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

Ön plan hizmeti türlerini kullanmayla ilgili Google Play politika yaptırımı

Uygulamanız Android 14 veya sonraki sürümleri hedefliyorsa Play Console'un uygulama içeriği sayfasında (Politika > Uygulama içeriği) uygulamanızın ön plan hizmet türlerini beyan etmeniz 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 bölümüne bakın.