Android 15 platformu, uygulamanızı etkileyebilecek davranış değişiklikleri içerir.
Aşağıdaki davranış değişiklikleri, targetSdkVersion değerinden bağımsız olarak Android 15'te çalıştırıldığında tüm uygulamalar için geçerlidir. Uygulamanızı test etmeli ve uygun durumlarda bunları düzgün şekilde desteklemek için gerektiği gibi değiştirmelisiniz.
Yalnızca Android 15'i hedefleyen uygulamaları etkileyen davranış değişiklikleri listesini de incelemeyi unutmayın.
Temel işlevler
Android 15, Android sisteminin çeşitli temel özelliklerini değiştirir veya genişletir.
Paketin durdurulmuş durumundaki değişiklikler
Paket FLAG_STOPPED durumunun amacı (kullanıcı AOSP derlemelerinde bir uygulama simgesine uzun basıp "Zorla Durdur"u seçerek bu işleme başlayabilir), kullanıcı uygulamayı doğrudan başlatarak veya dolaylı olarak uygulamayla etkileşime geçerek (paylaşım sayfası veya widget aracılığıyla, uygulamayı canlı duvar kağıdı olarak seçerek vb.) uygulamayı bu durumdan açıkça kaldırana kadar uygulamaları bu durumda tutmak olmuştur. Android 15'te, sistemin davranışını bu amaçlanan davranışla uyumlu olacak şekilde güncelledik. Uygulamalar yalnızca doğrudan veya dolaylı kullanıcı işlemiyle durdurulmuş durumundan kaldırılmalıdır.
Sistem, istenen davranışı desteklemek için Android 15 çalıştıran bir cihazda uygulama durdurulmuş duruma girdiğinde mevcut kısıtlamalara ek olarak tüm beklemedeki intent'leri de iptal eder. Kullanıcının işlemleri uygulamayı durdurulmuş durumdan çıkardığında ACTION_BOOT_COMPLETED yayını uygulamaya gönderilir. Bu yayın, bekleyen tüm intent'leri yeniden kaydetme fırsatı sunar.
Uygulamanın durdurulmuş duruma alınıp alınmadığını onaylamak için yeni ApplicationStartInfo.wasForceStopped() yöntemini çağırabilirsiniz.
16 KB sayfa boyutları için destek
Historically, Android has only supported 4 KB memory page sizes, which has optimized system memory performance for the average amount of total memory that Android devices have typically had. Beginning with Android 15, AOSP supports devices that are configured to use a page size of 16 KB (16 KB devices). If your app uses any NDK libraries, either directly or indirectly through an SDK, then you will need to rebuild your app for it to work on these 16 KB devices.
As device manufacturers continue to build devices with larger amounts of physical memory (RAM), many of these devices will adopt 16 KB (and eventually greater) page sizes to optimize the device's performance. Adding support for 16 KB page size devices enables your app to run on these devices and helps your app benefit from the associated performance improvements. Without recompiling, apps won't work on 16 KB devices in future Android releases.
To help you add support for your app, we've provided guidance on how to check if your app is impacted, how to rebuild your app (if applicable), and how to test your app in a 16 KB environment using emulators (including Android 15 system images for the Android Emulator).
Benefits and performance gains
16 KB sayfa boyutlarıyla yapılandırılan cihazlar, ortalama olarak biraz daha fazla bellek kullanır. Ancak, hem sistem hem de uygulamalar için çeşitli performans iyileştirmeleri sağlar:
- Sistem bellek baskısı altındayken daha düşük uygulama başlatma süreleri: Test ettiğimiz bazı uygulamalarda daha belirgin iyileştirmeler (%30'a varan) ile birlikte ortalama %3, 16 daha düşük
- Uygulama başlatma sırasında güç tüketimi azaltıldı: Ortalama% 4,56 oranında azalma
- Daha hızlı kamera başlatma: Ortalama% 4,48 daha hızlı çalışır durumda başlatma ve ortalama% 6,60 daha hızlı soğuk başlatma
- İyileştirilmiş sistem önyükleme süresi: Ortalama %8 (yaklaşık 950 milisaniye) iyileşme
Bu iyileştirmeler, ilk testlerimizi temel almaktadır ve gerçek cihazlardaki sonuçlar büyük olasılıkla farklılık gösterecektir. Testlerimizi sürdürürken uygulamaların olası kazanımlara ilişkin ek analizler sağlayacağız.
Check if your app is impacted
If your app uses any native code, then you should rebuild your app with support for 16 KB devices. If you are unsure if your app uses native code, you can use the APK Analyzer to identify whether any native code is present and then check the alignment of ELF segments for any shared libraries that you find. Android Studio also provides features that help you to automatically detect alignment issues.
If your app only uses code written in the Java programming language or in Kotlin, including all libraries or SDKs, then your app already supports 16 KB devices. Nevertheless, we recommend that you test your app in a 16 KB environment to verify that there are no unexpected regressions in app behavior.
Bazı uygulamaların özel alanı desteklemesi için gerekli değişiklikler
Özel alan, Android 15'teki yeni bir özelliktir. Kullanıcıların cihazlarında ayrı bir alan oluşturarak hassas uygulamaları, ek bir kimlik doğrulama katmanıyla meraklı gözlerden korumalarına olanak tanır. Özel alandaki uygulamaların görünürlüğü kısıtlandığından, bazı uygulama türlerinin kullanıcının özel alanındaki uygulamaları görüp bunlarla etkileşim kurabilmesi için ek adımlar atması gerekir.
Tüm uygulamalar
Gizli alandaki uygulamalar, iş profillerine benzer şekilde ayrı bir kullanıcı profilinde tutulduğundan, uygulamaların ana profilde olmayan yüklü kopyalarının iş profilinde olduğunu varsaymaması gerekir. Uygulamanızda, iş profili uygulamalarıyla ilgili bu varsayımı yapan bir mantık varsa bu mantığı düzenlemeniz gerekir.
Tıbbi uygulamalar
Kullanıcı özel alanı kilitlediğinde özel alandaki tüm uygulamalar durdurulur ve bu uygulamalar, bildirim göstermek de dahil olmak üzere ön planda veya arka planda etkinlik gerçekleştiremez. Bu davranış, özel alana yüklenen tıbbi uygulamaların kullanımını ve işlevini önemli ölçüde etkileyebilir.
Özel alan kurulum deneyimi, kullanıcıları özel alanın tıbbi uygulamalardan gelen bildirimleri gösterme gibi kritik ön plan veya arka plan etkinlikleri gerçekleştirmesi gereken uygulamalar için uygun olmadığı konusunda uyarır. Ancak uygulamalar, özel alanda kullanılıp kullanılmadıklarını belirleyemediğinden bu durumda kullanıcıya uyarı gösteremez.
Bu nedenle, tıbbi uygulama geliştiriyorsanız bu özelliğin uygulamanızı nasıl etkileyebileceğini inceleyin ve kritik uygulama özelliklerinin kesintiye uğramasını önlemek için uygun işlemleri yapın (ör. kullanıcılarınızı uygulamanızı özel alana yüklememeleri konusunda bilgilendirin).
Başlatıcı uygulamaları
Bir başlatıcı uygulaması geliştirirseniz özel alandaki uygulamaların görünmesi için aşağıdakileri yapmanız gerekir:
- Uygulamanız, cihaz için varsayılan başlatıcı uygulaması olarak atanmış olmalıdır. Yani
ROLE_HOMErolüne sahip olmalıdır. - Uygulamanız,
ACCESS_HIDDEN_PROFILESnormal iznini uygulamanızın manifest dosyasında beyan etmelidir.
ACCESS_HIDDEN_PROFILES iznini beyan eden başlatıcı uygulamaları aşağıdaki özel alan kullanım alanlarını ele almalıdır:
- Uygulamanızda, özel alana yüklenen uygulamalar için ayrı bir başlatıcı kapsayıcısı olmalıdır. Hangi tür kullanıcı profilinin işlendiğini belirlemek için
getLauncherUserInfo()yöntemini kullanın. - Kullanıcı, özel alan kapsayıcısını gizleyip gösterebilmelidir.
- Kullanıcı, özel alan kapsayıcısını kilitleyip kilidini açabilmelidir. Özel alanı kilitlemek (
trueile) veya kilidini açmak (falseile) içinrequestQuietModeEnabled()yöntemini kullanın. Kilitliyken özel alan kapsayıcısındaki hiçbir uygulama görünmemeli veya arama gibi mekanizmalar aracılığıyla bulunamamalıdır. Uygulamanız,
ACTION_PROFILE_AVAILABLEveACTION_PROFILE_UNAVAILABLEyayınları için bir alıcı kaydettirmeli ve özel alan kapsayıcısının kilitli veya kilidi açık durumu değiştiğinde uygulamanızdaki kullanıcı arayüzünü güncellemelidir. Bu yayınların her ikisi deEXTRA_USERiçerir. Uygulamanız, özel profil kullanıcısını belirtmek için bu kimliği kullanabilir.Özel alan profilinin kilitli olup olmadığını kontrol etmek için
isQuietModeEnabled()yöntemini de kullanabilirsiniz.
Uygulama mağazası uygulamaları
Özel alanda, kullanıcının özel alanına uygulama yüklemek için bir örtülü intent başlatan bir "Uygulama Yükle" düğmesi bulunur. Uygulamanızın bu dolaylı intent'i alabilmesi için uygulamanızın manifest dosyasında CATEGORY_APP_MARKET <category> içeren bir <intent-filter> beyan edin.
PNG tabanlı emoji yazı tipi kaldırıldı
Eski, PNG tabanlı emoji yazı tipi dosyası (NotoColorEmojiLegacy.ttf) kaldırıldı ve yalnızca vektör tabanlı dosya kaldı. Android 13'ten (API düzeyi 33) itibaren sistem emoji oluşturma aracı tarafından kullanılan emoji yazı tipi dosyası PNG tabanlı bir dosyadan vektör tabanlı bir dosyaya değiştirildi. Sistem, Android 13 ve 14'te uyumluluk nedeniyle eski yazı tipi dosyasını sakladı. Böylece, kendi yazı tipi oluşturma araçlarına sahip uygulamalar yeni sürüme geçene kadar eski yazı tipi dosyasını kullanmaya devam edebildi.
Uygulamanızın etkilenip etkilenmediğini kontrol etmek için uygulamanızın kodunda NotoColorEmojiLegacy.ttf dosyasına yapılan referansları arayın.
Uygulamanızı birkaç şekilde uyarlayabilirsiniz:
- Metin oluşturma için platform API'lerini kullanın. Metni bitmap destekli bir
Canvasolarak oluşturabilir ve gerekirse ham resim elde etmek için bunu kullanabilirsiniz. - Uygulamanıza COLRv1 yazı tipi desteği ekleyin. FreeType açık kaynak kitaplığı, 2.13.0 sürümü ve sonraki sürümlerde COLRv1'i destekler.
- Son çare olarak eski emoji yazı tipi dosyasını (
NotoColorEmoji.ttf) APK'nıza ekleyebilirsiniz. Ancak bu durumda uygulamanızda en son emoji güncellemeleri eksik olur. Daha fazla bilgi için Noto Emoji GitHub proje sayfasına göz atın.
Minimum hedef SDK sürümü 23'ten 24'e yükseltildi
Android 15
Android 14'te yapılan değişiklikler ve bu değişikliğin kapsamını genişleterek
daha fazla güvenlik. Android 15'te targetSdkVersion değeri 24'ten düşük olan uygulamalar yüklenemez.
Uygulamaların modern API seviyelerini karşılamasını zorunlu kılmak, güvenliğin ve
gizlilik.
Kötü amaçlı yazılımlar, güvenlik ve gizliliği atlamak için genellikle daha düşük API seviyelerini hedefler.
yüksek Android sürümlerinde sunulan koruma özellikleri. Örneğin,
bazı kötü amaçlı yazılım uygulamalarıtargetSdkVersion
Android 6.0 Marshmallow (API) tarafından 2015'te kullanıma sunulan çalışma zamanı izin modeli
23. düzey). Android 15'teki bu değişiklik, kötü amaçlı yazılımların güvenlikten kaçınmasını zorlaştırıyor
ve gizlilikle ilgili iyileştirmeler yapıldı. Daha düşük bir API'yi hedefleyen bir uygulama yüklenmeye çalışılıyor
düzeyinde bir yükleme işlemi hatasıyla sonuçlanır ve bu hataya aşağıdaki gibi bir mesaj gönderilir
Logcat'te görünüyor:
INSTALL_FAILED_DEPRECATED_SDK_VERSION: App package must target at least SDK version 24, but found 7
Android 15'e geçen cihazlarda, targetSdkVersion daha düşük
24'ten fazlası yüklü durumda.
Eski bir API düzeyini hedefleyen bir uygulamayı test etmeniz gerekirse aşağıdaki ADB'yi kullanın komut:
adb install --bypass-low-target-sdk-block FILENAME.apk
Güvenlik ve gizlilik
Android 15 introduces robust measures to combat one-time passcode (OTP) fraud and to protect the user's sensitive content, focusing on hardening the Notification Listener Service and screenshare protections. Key enhancements include redacting OTPs from notifications accessible to untrusted apps, hiding notifications during screenshare, and securing app activities when OTPs are posted. These changes aim to keep the user's sensitive content safe from unauthorized actors.
Developers need to be aware of the following to ensure their apps are compatible with the changes in Android 15:
OTP Redaction
Android will stop untrusted apps that implement a
NotificationListenerService from reading unredacted content
from notifications where an OTP has been detected. Trusted apps such as
companion device manager associations are exempt from these restrictions.
Screenshare Protection
- Notification content is hidden during screen sharing sessions to preserve
the user's privacy. If the app implements
setPublicVersion(), Android shows the public version of the notification which serves as a replacement notification in insecure contexts. Otherwise, the notification content is redacted without any further context. - Sensitive content like password input is hidden from remote viewers to prevent revealing the user's sensitive information.
- Activities from apps that post notifications during screenshare where an OTP has been detected will be hidden. App content is hidden from the remote viewer when launched.
- Beyond Android's automatic identification of sensitive fields, developers
can manually mark parts of their app as sensitive using
setContentSensitivity, which is hidden from remote viewers during screenshare. - Developers can choose to toggle the Disable screen share protections option under Developer Options to be exempted from the screenshare protections for demo or testing purposes. The default system screen recorder is exempted from these changes, since the recordings remain on-device.
Kamera ve medya içerikleri
Android 15, tüm uygulamalarda kamera ve medya davranışıyla ilgili aşağıdaki değişiklikleri yapar.
Doğrudan ve dışa aktarılan ses oynatma, kaynak sınırlarına ulaşıldığında daha önce açılmış doğrudan veya dışa aktarılmış ses parçalarını geçersiz kılar.
Android 15'ten önce, başka bir uygulama ses çalarken bir uygulama doğrudan veya aktarma yoluyla ses çalmayı talep ederse ve kaynak sınırlarına ulaşılırsa uygulama yeni bir AudioTrack açamazdı.
Android 15'ten itibaren, bir uygulama doğrudan oynatma veya aktarma oynatma istediğinde ve kaynak sınırlarına ulaşıldığında sistem, yeni parça isteğinin yerine getirilmesini engelleyen, şu anda açık olan tüm AudioTrack nesnelerini geçersiz kılar.
(Doğrudan ve aktarılan ses parçaları genellikle sıkıştırılmış ses biçimlerinin oynatılması için açılır. Doğrudan ses oynatmanın yaygın kullanım alanları arasında, kodlanmış sesi HDMI üzerinden TV'ye aktarma yer alır. İndirilen parçalar genellikle donanım DSP hızlandırması olan bir mobil cihazda sıkıştırılmış ses oynatmak için kullanılır.)
Kullanıcı deneyimi ve sistem arayüzü
Android 15, daha tutarlı ve sezgisel bir kullanıcı deneyimi oluşturmayı amaçlayan bazı değişiklikler içerir.
Katılan uygulamalar için tahmine dayalı geri hareketi animasyonları etkinleştirildi
Android 15'ten itibaren tahmine dayalı geri animasyonlar için geliştirici seçeneği kaldırıldı. Ana sayfaya geri gitme, görevler arasında geçiş yapma ve etkinlikler arasında geçiş yapma gibi sistem animasyonları artık tahmini geri hareketini etkinleştiren uygulamalarda tamamen veya etkinlik düzeyinde gösteriliyor. Uygulamanız etkilendiyse aşağıdaki işlemleri yapın:
- Uygulamanızın, tahmini geri hareketi kullanacak şekilde düzgün bir şekilde taşındığından emin olun.
- Parça geçişlerinizin tahmini geri gezinme ile çalıştığından emin olun.
- Animasyon ve çerçeve geçişlerinden uzaklaşın ve bunun yerine animatör ve androidx geçişlerini kullanın.
FragmentManager'nin bilmediği arka yığınlardan taşının. Bunun yerineFragmentManagerveya Gezinme bileşeni tarafından yönetilen geri yığınları kullanın.
Kullanıcı bir uygulamayı durdurmaya zorladığında widget'lar devre dışı bırakılıyor
If a user force-stops an app on a device running Android 15, the system temporarily disables all the app's widgets. The widgets are grayed out, and the user cannot interact with them. This is because beginning with Android 15, the system cancels all an app's pending intents when the app is force-stopped.
The system re-enables those widgets the next time the user launches the app.
For more information, see Changes to package stopped state.
Medya yansıtma durum çubuğu çipi, kullanıcıları ekran paylaşımı, yayınlama ve kayıt konusunda uyarır.
Ekran yansıtma istismarlarında, kullanıcılar cihaz ekranlarının paylaşıldığını fark etmediğinden finansal bilgiler gibi gizli kullanıcı verileri açığa çıkar.
Android 15 QPR1 veya sonraki sürümleri çalıştıran cihazlarda, büyük ve belirgin bir durum çubuğu çipi, devam eden ekran yansıtma işlemleri hakkında kullanıcıları uyarır. Kullanıcılar, ekranlarının paylaşılmasını, yayınlamasını veya kaydedilmesini durdurmak için çipe dokunabilir. Ayrıca, cihaz ekranı kilitlendiğinde ekran yansıtma otomatik olarak durur.
Uygulamanızın etkilenip etkilenmediğini kontrol edin
Uygulamanız varsayılan olarak durum çubuğu çipini içerir ve kilit ekranı etkinleştirildiğinde ekran yansıtmayı otomatik olarak askıya alır.
Uygulamanızı bu kullanım alanları için nasıl test edeceğiniz hakkında daha fazla bilgi edinmek için Durum çubuğu çipi ve otomatik durdurma başlıklı makaleyi inceleyin.
Arka plan ağ erişimi kısıtlamaları
Android 15'te, geçerli bir işlem yaşam döngüsü dışında ağ isteği başlatan uygulamalar istisna alır. Genellikle bir UnknownHostException veya soketle ilgili başka bir IOException olur. Geçerli yaşam döngüsü dışında gerçekleşen ağ istekleri genellikle uygulamaların artık etkin olmasa bile ağ isteklerini bilmeden devam ettirmesinden kaynaklanır.
Bu istisnayı azaltmak için yaşam döngüsü bilincine sahip bileşenler kullanarak ağ isteklerinizin yaşam döngüsü bilincine sahip olduğundan ve geçerli bir işlem yaşam döngüsünden çıktığında iptal edildiğinden emin olun. Ağ isteğinin, kullanıcı uygulamadan ayrılsa bile yapılması önemliyse WorkManager'ı kullanarak ağ isteğini planlayabilir veya ön plan hizmetini kullanarak kullanıcı tarafından görülebilen bir göreve devam edebilirsiniz.
Kullanımdan Kaldırmalar
Her sürümde belirli Android API'leri eski hale gelebilir veya daha iyi bir geliştirici deneyimi sunmak ya da yeni platform özelliklerini desteklemek için yeniden düzenlenmesi gerekebilir. Bu tür durumlarda, eski API'lerin desteğini resmi olarak sonlandırırız ve geliştiricileri bunun yerine kullanabilecekleri alternatif API'lere yönlendiririz.
Desteğin sonlandırılması, API'ler için resmi desteğin sona erdirildiği ancak geliştiricilerin bu API'leri kullanmaya devam edebileceği anlamına gelir. Android'in bu sürümündeki önemli desteği sonlandırılan özellikler hakkında daha fazla bilgi edinmek için desteği sonlandırılan özellikler sayfasını inceleyin.