Wie bei früheren Versionen enthält Android 15 Verhaltensänderungen, die sich auf Ihre App auswirken können. Die folgenden Verhaltensänderungen gelten ausschließlich für Apps, die auf Android 15 oder höher ausgerichtet sind. Wenn Ihre App auf Android 15 oder höher ausgerichtet ist, sollten Sie sie gegebenenfalls so anpassen, dass sie diese Verhaltensweisen richtig unterstützt.
Sehen Sie sich auch die Liste der Verhaltensänderungen an, die sich auf alle Apps auswirken, die unter Android 15 ausgeführt werden, unabhängig vom targetSdkVersion Ihrer App.
Hauptfunktion
In Android 15 werden verschiedene Kernfunktionen des Android-Systems geändert oder erweitert.
Änderungen an Vordergrunddiensten
Mit Android 15 nehmen wir die folgenden Änderungen an Diensten im Vordergrund vor.
- Verhalten bei Zeitüberschreitung des Diensts „Datensynchronisierung im Vordergrund“
- Neuer Typ für Dienste im Vordergrund zur Medienverarbeitung
- Einschränkungen für
BOOT_COMPLETED-Übertragungsempfänger, die Dienste im Vordergrund starten - Einschränkungen beim Starten von Diensten im Vordergrund, während eine App die Berechtigung
SYSTEM_ALERT_WINDOWhat
Zeitüberschreitung des Diensts „Datensynchronisierung im Vordergrund“
Unter Android 15 wird für dataSync ein neues Zeitlimit für Apps eingeführt, die auf Android 15 (API-Level 35) oder höher ausgerichtet sind. Dies gilt auch für den neuen Diensttyp mediaProcessing im Vordergrund.
Das System erlaubt es den dataSync-Diensten einer App, innerhalb eines Zeitraums von 24 Stunden insgesamt 6 Stunden lang ausgeführt zu werden. Danach ruft das System die Methode Service.onTimeout(int, int) des laufenden Dienstes auf (in Android 15 eingeführt). Derzeit hat der Dienst einige Sekunden Zeit, um Service.stopSelf() aufzurufen. Wenn Service.onTimeout() aufgerufen wird, gilt der Dienst nicht mehr als Dienst im Vordergrund. Wenn der Dienst Service.stopSelf() nicht aufruft, löst das System eine interne Ausnahme aus. Die Ausnahme wird mit der folgenden Meldung in Logcat protokolliert:
Fatal Exception: android.app.RemoteServiceException: "A foreground service of
type dataSync did not stop within its timeout: [component name]"
So vermeiden Sie Probleme mit dieser Verhaltensänderung:
- Lassen Sie Ihren Dienst die neue
Service.onTimeout(int, int)-Methode implementieren. Wenn Ihre App den Callback empfängt, müssen Sie innerhalb weniger SekundenstopSelf()anrufen. Wenn Sie die App nicht sofort beenden, generiert das System einen Fehler. - Die
dataSync-Dienste deiner App dürfen innerhalb von 24 Stunden nicht länger als sechs Stunden ausgeführt werden, es sei denn, der Nutzer interagiert mit der App und setzt den Timer zurück. - Starten Sie
dataSyncDienste im Vordergrund nur als Folge einer direkten Nutzerinteraktion. Da sich Ihre App beim Start des Dienstes im Vordergrund befindet, hat Ihr Dienst die vollen sechs Stunden Zeit, nachdem die App in den Hintergrund gewechselt ist. - Verwenden Sie stattdessen eine alternative API.
dataSync
Wenn die dataSync-Dienste im Vordergrund Ihrer App in den letzten 24 Stunden sechs Stunden lang ausgeführt wurden, können Sie keinen weiteren dataSync-Dienst im Vordergrund starten, es sei denn, der Nutzer hat Ihre App in den Vordergrund gebracht (wodurch der Timer zurückgesetzt wird). Wenn Sie versuchen, einen weiteren dataSync-Vordergrunddienst zu starten, gibt das System ForegroundServiceStartNotAllowedException mit einer Fehlermeldung zurück, z. B. „Zeitlimit für den Typ ‚dataSync‘ des Vordergrunddienstes bereits überschritten“.
Testen
Sie können Zeitüberschreitungen für die Datensynchronisierung aktivieren, um das Verhalten Ihrer App zu testen, auch wenn Ihre App nicht auf Android 15 ausgerichtet ist, solange die App auf einem Android 15-Gerät ausgeführt wird. Führen Sie den folgenden Befehl adb aus, um Zeitüberschreitungen zu aktivieren:
adb shell am compat enable FGS_INTRODUCE_TIME_LIMITS your-package-name
Sie können auch die Zeitüberschreitung anpassen, um das Verhalten Ihrer App nach Erreichen des Limits leichter zu testen. Führen Sie den folgenden adb-Befehl aus, um ein neues Zeitlimit festzulegen:
adb shell device_config put activity_manager data_sync_fgs_timeout_duration duration-in-milliseconds
Neuer Typ für Dienste im Vordergrund zur Medienverarbeitung
In Android 15 wird der neue Diensttyp mediaProcessing eingeführt. Dieser Diensttyp eignet sich für Vorgänge wie das Transcodieren von Mediendateien. Eine Medien-App könnte beispielsweise eine Audiodatei herunterladen und sie vor der Wiedergabe in ein anderes Format konvertieren. Sie können einen mediaProcessing-Dienst im Vordergrund verwenden, damit die Conversion auch dann fortgesetzt wird, wenn die App im Hintergrund ausgeführt wird.
Das System lässt zu, dass die mediaProcessing-Dienste einer App insgesamt 6 Stunden innerhalb von 24 Stunden ausgeführt werden. Anschließend ruft das System die Service.onTimeout(int, int)-Methode des laufenden Dienstes auf (in Android 15 eingeführt). Derzeit hat der Dienst einige Sekunden Zeit, um Service.stopSelf() aufzurufen. Wenn der Dienst Service.stopSelf() nicht aufruft, löst das System eine interne Ausnahme aus. Die Ausnahme wird in Logcat mit der folgenden Meldung protokolliert:
Fatal Exception: android.app.RemoteServiceException: "A foreground service of
type mediaProcessing did not stop within its timeout: [component name]"
Sie können eine Ausnahme vermeiden, indem Sie einen der folgenden Schritte ausführen:
- Implementieren Sie in Ihrem Dienst die neue
Service.onTimeout(int, int)-Methode. Wenn Ihre App den Callback empfängt, müssen Sie innerhalb weniger SekundenstopSelf()anrufen. Wenn Sie die App nicht sofort beenden, generiert das System einen Fehler. - Die
mediaProcessing-Dienste Ihrer App dürfen innerhalb eines 24-Stunden-Zeitraums insgesamt nicht länger als 6 Stunden ausgeführt werden, es sei denn, der Nutzer interagiert mit der App und setzt den Timer zurück. - Starten Sie
mediaProcessingDienste im Vordergrund nur als Folge einer direkten Nutzerinteraktion. Da sich Ihre App beim Start des Dienstes im Vordergrund befindet, hat Ihr Dienst die vollen sechs Stunden Zeit, nachdem die App in den Hintergrund gewechselt ist. - Verwende anstelle eines
mediaProcessing-Dienstes im Vordergrund eine alternative API wie WorkManager.
Wenn die mediaProcessing-Dienste im Vordergrund Ihrer App in den letzten 24 Stunden sechs Stunden lang ausgeführt wurden, können Sie keinen weiteren mediaProcessing-Dienst im Vordergrund starten, es sei denn, der Nutzer hat Ihre App in den Vordergrund gebracht (wodurch der Timer zurückgesetzt wird). Wenn Sie versuchen, einen weiteren mediaProcessing-Vordergrunddienst zu starten, löst das System ForegroundServiceStartNotAllowedException mit einer Fehlermeldung wie „Zeitlimit für den Typ „mediaProcessing“ des Dienstes im Vordergrund bereits überschritten“ aus.
Weitere Informationen zum Diensttyp mediaProcessing finden Sie unter Änderungen an Diensttypen im Vordergrund für Android 15: Medienverarbeitung.
Testen
Wenn du das Verhalten deiner App testen möchtest, kannst du Zeitüberschreitungen bei der Medienverarbeitung aktivieren, auch wenn deine App nicht auf Android 15 ausgerichtet ist, solange sie auf einem Android 15-Gerät ausgeführt wird. Führen Sie den folgenden Befehl adb aus, um Zeitüberschreitungen zu aktivieren:
adb shell am compat enable FGS_INTRODUCE_TIME_LIMITS your-package-name
Sie können auch das Zeitlimit anpassen, um zu testen, wie sich Ihre Anwendung verhält, wenn das Limit erreicht ist. Führen Sie den folgenden adb-Befehl aus, um ein neues Zeitlimit festzulegen:
adb shell device_config put activity_manager media_processing_fgs_timeout_duration duration-in-milliseconds
Einschränkungen für BOOT_COMPLETED-Übertragungsempfänger, die Dienste im Vordergrund starten
Es gelten neue Einschränkungen für die Einführung von BOOT_COMPLETED Übertragungsempfängern
Dienste im Vordergrund. BOOT_COMPLETED Empfänger dürfen nicht Folgendes starten:
folgende Arten von Diensten im Vordergrund:
dataSynccameramediaPlaybackphoneCallmediaProjectionmicrophone(Diese Einschränkung gilt seit demmicrophonefürmicrophoneAndroid 14)
Wenn ein BOOT_COMPLETED-Empfänger versucht, einen dieser Dienste im Vordergrund zu starten, löst das System ForegroundServiceStartNotAllowedException aus.
Testen
Um das Verhalten Ihrer App zu testen, können Sie diese neuen Einschränkungen auch dann aktivieren, wenn Ihre
Die App ist nicht auf Android 15 ausgerichtet (solange die App auf einem Android 15 ausgeführt wird)
Gerät). Führen Sie den folgenden adb-Befehl aus:
adb shell am compat enable FGS_BOOT_COMPLETED_RESTRICTIONS your-package-name
Wenn Sie eine BOOT_COMPLETED-Broadcastnachricht senden möchten, ohne das Gerät neu zu starten, führen Sie den folgenden Befehl adb aus:
adb shell am broadcast -a android.intent.action.BOOT_COMPLETED your-package-name
Einschränkungen beim Starten von Diensten im Vordergrund, während eine App die Berechtigung SYSTEM_ALERT_WINDOW hat
Previously, if an app held the SYSTEM_ALERT_WINDOW permission, it could launch
a foreground service even if the app was currently in the background (as
discussed in exemptions from background start restrictions).
If an app targets Android 15, this exemption is now narrower. The app now needs
to have the SYSTEM_ALERT_WINDOW permission and also have a visible overlay
window. That is, the app needs to first launch a
TYPE_APPLICATION_OVERLAY window and the window
needs to be visible before you start a foreground service.
If your app attempts to start a foreground service from the background without
meeting these new requirements (and it does not have some other exemption), the
system throws ForegroundServiceStartNotAllowedException.
If your app declares the SYSTEM_ALERT_WINDOW permission
and launches foreground services from the background, it may be affected by this
change. If your app gets a ForegroundServiceStartNotAllowedException, check
your app's order of operations and make sure your app already has an active
overlay window before it attempts to start a foreground service from the
background. You can check if your overlay window is currently visible
by calling View.getWindowVisibility(), or you
can override View.onWindowVisibilityChanged()
to get notified whenever the visibility changes.
Testing
To test your app's behavior, you can enable these new restrictions even if your
app is not targeting Android 15 (as long as the app is running on an Android 15
device). To enable these new restrictions on starting foreground services
from the background, run the following adb command:
adb shell am compat enable FGS_SAW_RESTRICTIONS your-package-name
Änderungen daran, wann Apps den globalen Status des Modus „Bitte nicht stören“ ändern können
Apps that target Android 15 (API level 35) and higher can no longer change the
global state or policy of Do Not Disturb (DND) on a device (either by modifying
user settings, or turning off DND mode). Instead, apps must contribute an
AutomaticZenRule, which the system combines into a global policy with the
existing most-restrictive-policy-wins scheme. Calls to existing APIs that
previously affected global state (setInterruptionFilter,
setNotificationPolicy) result in the creation or update of an implicit
AutomaticZenRule, which is toggled on and off depending on the call-cycle of
those API calls.
Note that this change only affects observable behavior if the app is calling
setInterruptionFilter(INTERRUPTION_FILTER_ALL) and expects that call to
deactivate an AutomaticZenRule that was previously activated by their owners.
OpenJDK-API-Änderungen
Android 15 continues the work of refreshing Android's core libraries to align with the features in the latest OpenJDK LTS releases.
Some of these changes can affect app compatibility for apps targeting Android 15 (API level 35):
Changes to string formatting APIs: Validation of argument index, flags, width, and precision are now more strict when using the following
String.format()andFormatter.format()APIs:String.format(String, Object[])String.format(Locale, String, Object[])Formatter.format(String, Object[])Formatter.format(Locale, String, Object[])
For example, the following exception is thrown when an argument index of 0 is used (
%0in the format string):IllegalFormatArgumentIndexException: Illegal format argument index = 0In this case, the issue can be fixed by using an argument index of 1 (
%1in the format string).Changes to component type of
Arrays.asList(...).toArray(): When usingArrays.asList(...).toArray(), the component type of the resulting array is now anObject—not the type of the underlying array's elements. So the following code throws aClassCastException:String[] elements = (String[]) Arrays.asList("one", "two").toArray();For this case, to preserve
Stringas the component type in the resulting array, you could useCollection.toArray(Object[])instead:String[] elements = Arrays.asList("two", "one").toArray(new String[0]);Changes to language code handling: When using the
LocaleAPI, language codes for Hebrew, Yiddish, and Indonesian are no longer converted to their obsolete forms (Hebrew:iw, Yiddish:ji, and Indonesian:in). When specifying the language code for one of these locales, use the codes from ISO 639-1 instead (Hebrew:he, Yiddish:yi, and Indonesian:id).Changes to random int sequences: Following the changes made in https://bugs.openjdk.org/browse/JDK-8301574, the following
Random.ints()methods now return a different sequence of numbers than theRandom.nextInt()methods do:Generally, this change shouldn't result in app-breaking behavior, but your code shouldn't expect the sequence generated from
Random.ints()methods to matchRandom.nextInt().
The new SequencedCollection API can affect your app's compatibility
after you update compileSdk in your app's build configuration to use
Android 15 (API level 35):
Collision with
MutableList.removeFirst()andMutableList.removeLast()extension functions inkotlin-stdlibThe
Listtype in Java is mapped to theMutableListtype in Kotlin. Because theList.removeFirst()andList.removeLast()APIs have been introduced in Android 15 (API level 35), the Kotlin compiler resolves function calls, for examplelist.removeFirst(), statically to the newListAPIs instead of to the extension functions inkotlin-stdlib.If an app is re-compiled with
compileSdkset to35andminSdkset to34or lower, and then the app is run on Android 14 and lower, a runtime error is thrown:java.lang.NoSuchMethodError: No virtual method removeFirst()Ljava/lang/Object; in class Ljava/util/ArrayList;The existing
NewApilint option in Android Gradle Plugin can catch these new API usages../gradlew lintMainActivity.kt:41: Error: Call requires API level 35 (current min is 34): java.util.List#removeFirst [NewApi] list.removeFirst()To fix the runtime exception and lint errors, the
removeFirst()andremoveLast()function calls can be replaced withremoveAt(0)andremoveAt(list.lastIndex)respectively in Kotlin. If you're using Android Studio Ladybug | 2024.1.3 or higher, it also provides a quick fix option for these errors.Consider removing
@SuppressLint("NewApi")andlintOptions { disable 'NewApi' }if the lint option has been disabled.Collision with other methods in Java
New methods have been added into the existing types, for example,
ListandDeque. These new methods might not be compatible with the methods with the same name and argument types in other interfaces and classes. In the case of a method signature collision with incompatibility, thejavaccompiler outputs a build-time error. For example:Example error 1:
javac MyList.javaMyList.java:135: error: removeLast() in MyList cannot implement removeLast() in List public void removeLast() { ^ return type void is not compatible with Object where E is a type-variable: E extends Object declared in interface ListExample error 2:
javac MyList.javaMyList.java:7: error: types Deque<Object> and List<Object> are incompatible; public class MyList implements List<Object>, Deque<Object> { both define reversed(), but with unrelated return types 1 errorExample error 3:
javac MyList.javaMyList.java:43: error: types List<E#1> and MyInterface<E#2> are incompatible; public static class MyList implements List<Object>, MyInterface<Object> { class MyList inherits unrelated defaults for getFirst() from types List and MyInterface where E#1,E#2 are type-variables: E#1 extends Object declared in interface List E#2 extends Object declared in interface MyInterface 1 errorTo fix these build errors, the class implementing these interfaces should override the method with a compatible return type. For example:
@Override public Object getFirst() { return List.super.getFirst(); }
Sicherheit
Android 15 enthält Änderungen, die die Systemsicherheit fördern und dazu beitragen, Apps und Nutzer vor schädlichen Apps zu schützen.
Eingeschränkte TLS-Versionen
Android 15 restricts the usage of TLS versions 1.0 and 1.1. These versions had previously been deprecated in Android, but are now disallowed for apps targeting Android 15.
Sichere Starts von Hintergrundaktivitäten
Android 15 schützt Nutzer vor schädlichen Apps und gibt ihnen mehr Kontrolle über ihre Geräte. Dazu werden Änderungen eingeführt, die verhindern, dass schädliche Hintergrund-Apps andere Apps in den Vordergrund holen, ihre Berechtigungen erweitern und Nutzerinteraktionen missbrauchen. Das Starten von Hintergrundaktivitäten ist seit Android 10 (API-Level 29) eingeschränkt.
Sonstige Änderungen
PendingIntent-Ersteller standardmäßig so ändern, dass Starts von Hintergrundaktivitäten blockiert werden: So wird verhindert, dass Apps versehentlich einePendingIntenterstellen, die von böswilligen Akteuren missbraucht werden könnte.- Eine App darf nur dann in den Vordergrund gebracht werden, wenn der
PendingIntent-Absender dies zulässt. Mit dieser Änderung soll verhindert werden, dass schädliche Apps die Möglichkeit zum Starten von Aktivitäten im Hintergrund missbrauchen. Standardmäßig dürfen Apps den Task-Stack nicht in den Vordergrund holen, es sei denn, der Ersteller erlaubt das Starten von Hintergrundaktivitäten oder der Absender hat die Berechtigung zum Starten von Hintergrundaktivitäten. - Steuern, wie die oberste Aktivität eines Aufgabenstapels ihre Aufgabe beenden kann Wenn die oberste Aktivität eine Aufgabe beendet, kehrt Android zur zuletzt aktiven Aufgabe zurück. Wenn eine Aktivität, die nicht im Vordergrund ausgeführt wird, ihre Aufgabe beendet, kehrt Android zum Startbildschirm zurück. Das Beenden dieser Aktivität wird nicht blockiert.
- Verhindern, dass beliebige Aktivitäten aus anderen Apps in Ihrem eigenen Task gestartet werden. Diese Änderung verhindert, dass schädliche Apps Nutzer durch das Erstellen von Aktivitäten, die von anderen Apps zu stammen scheinen, zum Phishing verleiten.
- Blockieren, dass nicht sichtbare Fenster für Starts von Hintergrundaktivitäten berücksichtigt werden: So wird verhindert, dass schädliche Apps Hintergrundaktivitäten starten, um Nutzern unerwünschte oder schädliche Inhalte zu präsentieren.
Sicherere Intents
In Android 15 wird StrictMode für Intents eingeführt.
So rufen Sie detaillierte Logs zu Verstößen gegen die Nutzungsbedingungen von Intent auf:
Kotlin
fun onCreate() { StrictMode.setVmPolicy(VmPolicy.Builder() .detectUnsafeIntentLaunch() .build() ) }
Java
public void onCreate() { StrictMode.setVmPolicy(new VmPolicy.Builder() .detectUnsafeIntentLaunch() .build()); }
Nutzererfahrung und System-UI
Android 15 enthält einige Änderungen, die für eine einheitlichere und intuitivere User Experience sorgen sollen.
Änderungen am Fenstereinsatz
In Android 15 gibt es zwei Änderungen im Zusammenhang mit Fenstereinblendungen: Vollbild wird standardmäßig erzwungen. Außerdem gibt es Konfigurationsänderungen, z. B. an der Standardkonfiguration der Systemleisten.
Edge-to-Edge-Erzwingung
Apps werden auf Geräten mit Android 15 standardmäßig randlos angezeigt, wenn die App auf Android 15 (API‑Level 35) ausgerichtet ist.
Dies ist eine schwerwiegende Änderung, die sich negativ auf die Benutzeroberfläche Ihrer App auswirken kann. Die Änderungen betreffen die folgenden Bereiche der Benutzeroberfläche:
- Navigationsleiste mit Geste
- Standardmäßig transparent.
- Der untere Offset ist deaktiviert. Inhalte werden also hinter der Systemnavigationsleiste gerendert, sofern keine Insets angewendet werden.
setNavigationBarColorundR.attr#navigationBarColorsind veraltet und wirken sich nicht auf die Bedienung über Gesten aus.setNavigationBarContrastEnforcedundR.attr#navigationBarContrastEnforcedhaben weiterhin keine Auswirkungen auf die Gestennavigation.
- Bedienung über 3 Schaltflächen
- Die Deckkraft ist standardmäßig auf 80% eingestellt. Die Farbe kann mit dem Fensterhintergrund übereinstimmen.
- Der untere Offset ist deaktiviert, sodass Inhalte hinter der Systemnavigationsleiste gerendert werden, sofern keine Insets angewendet werden.
setNavigationBarColorundR.attr#navigationBarColorsind standardmäßig so eingestellt, dass sie dem Fensterhintergrund entsprechen. Der Fensterhintergrund muss ein Farb-Drawable sein, damit diese Standardeinstellung angewendet wird. Diese API ist zwar eingestellt, wirkt sich aber weiterhin auf die 3-Tasten-Navigation aus.setNavigationBarContrastEnforcedundR.attr#navigationBarContrastEnforcedsind standardmäßig auf „true“ gesetzt. Dadurch wird bei der Bedienung über 3 Schaltflächen ein zu 80% undurchsichtiger Hintergrund hinzugefügt.
- Statusleiste
- Standardmäßig transparent.
- Der obere Offset ist deaktiviert. Inhalte werden also hinter der Statusleiste gerendert, sofern keine Insets angewendet werden.
setStatusBarColorundR.attr#statusBarColorsind veraltet und haben keine Auswirkungen auf Android 15.setStatusBarContrastEnforcedundR.attr#statusBarContrastEnforcedsind veraltet, haben aber weiterhin Auswirkungen auf Android 15.
- Displayausschnitt
layoutInDisplayCutoutModevon nicht schwebenden Fenstern mussLAYOUT_IN_DISPLAY_CUTOUT_MODE_ALWAYSsein.SHORT_EDGES,NEVERundDEFAULTwerden alsALWAYSinterpretiert, damit Nutzer keinen schwarzen Balken sehen, der durch den Displayausschnitt verursacht wird, und das Bild von Kante zu Kante angezeigt wird.
Im folgenden Beispiel wird eine App vor und nach der Ausrichtung auf Android 15 (API‑Level 35) sowie vor und nach dem Anwenden von Einsätzen gezeigt. Dieses Beispiel ist nicht vollständig. Die Darstellung kann in Android Auto anders aussehen.
Was Sie prüfen sollten, wenn Ihre App bereits Edge-to-Edge-Darstellung unterstützt
Wenn Ihre App bereits randlos ist und Insets verwendet, sind Sie größtenteils nicht betroffen, außer in den folgenden Fällen. Auch wenn Sie nicht davon ausgehen, dass Ihre App betroffen ist, empfehlen wir Ihnen, sie zu testen.
- Sie haben ein nicht schwebendes Fenster, z. B. ein
Activity, dasSHORT_EDGES,NEVERoderDEFAULTanstelle vonLAYOUT_IN_DISPLAY_CUTOUT_MODE_ALWAYSverwendet. Wenn Ihre App beim Starten abstürzt, liegt das möglicherweise an Ihrem Splashscreen. Sie können entweder die Abhängigkeit core splashscreen auf 1.2.0-alpha01 oder höher aktualisieren oderwindow.attributes.layoutInDisplayCutoutMode = WindowManager.LayoutInDisplayCutoutMode.alwaysfestlegen. - Es kann sein, dass es Bildschirme mit geringerem Traffic gibt, auf denen die Benutzeroberfläche verdeckt ist. Prüfen Sie, ob die Benutzeroberfläche auf diesen weniger besuchten Bildschirmen verdeckt ist. Zu den Bildschirmen mit geringerem Traffic gehören:
- Einrichtungs- oder Anmeldebildschirme
- Einstellungsseiten
Was Sie prüfen sollten, wenn Ihre App noch nicht randlos ist
Wenn Ihre App noch nicht randlos ist, sind Sie höchstwahrscheinlich betroffen. Zusätzlich zu den Szenarien für Apps, die bereits randlos sind, sollten Sie Folgendes berücksichtigen:
- Wenn in Ihrer App Material 3-Komponenten (
androidx.compose.material3) in Compose verwendet werden, z. B.TopAppBar,BottomAppBarundNavigationBar, sind diese Komponenten wahrscheinlich nicht betroffen, da sie Insets automatisch verarbeiten. - Wenn in Ihrer App Material 2-Komponenten (
androidx.compose.material) in Compose verwendet werden, werden Insets nicht automatisch von diesen Komponenten verarbeitet. Sie können jedoch auf die Insets zugreifen und sie manuell anwenden. In androidx.compose.material 1.6.0 und höher können Sie den ParameterwindowInsetsverwenden, um die Insets manuell fürBottomAppBar,TopAppBar,BottomNavigationundNavigationRailanzuwenden. Verwenden Sie den ParametercontentWindowInsetsauch fürScaffold. - Wenn in Ihrer App Ansichten und Material-Komponenten (
com.google.android.material) verwendet werden, werden die meisten ansichtsbasierte Material-Komponenten wieBottomNavigationView,BottomAppBar,NavigationRailViewoderNavigationViewmit Insets gerendert. Es sind keine zusätzlichen Maßnahmen erforderlich. Wenn SieAppBarLayoutverwenden, müssen Sie jedochandroid:fitsSystemWindows="true"hinzufügen. - Bei benutzerdefinierten Composables müssen Sie die Insets manuell als Padding anwenden. Wenn sich Ihre Inhalte in einem
Scaffoldbefinden, können Sie Insets mit denScaffold-Abstandswerten verwenden. Andernfalls wenden Sie den Innenabstand mit einem derWindowInsetsan. - Wenn Ihre App Ansichten und
BottomSheet-,SideSheet- oder benutzerdefinierte Container verwendet, wenden Sie den Innenabstand mitViewCompat.setOnApplyWindowInsetsListeneran. Wenden Sie fürRecyclerViewmit diesem Listener einen Innenabstand an und fügen Sie auchclipToPadding="false"hinzu.
Prüfen, ob Ihre App einen benutzerdefinierten Schutz im Hintergrund bieten muss
Wenn Ihre App einen benutzerdefinierten Hintergrundschutz für die 3‑Tasten-Navigation oder die Statusleiste bieten muss, sollte sie mithilfe von WindowInsets.Type#tappableElement() für die Höhe der 3‑Tasten-Navigationsleiste oder WindowInsets.Type#statusBars eine Komposition oder Ansicht hinter der Systemleiste platzieren.
Weitere Ressourcen für Edge-to-Edge-Anzeigen
Weitere Informationen zum Anwenden von Insets finden Sie in den Leitfäden Edge-to-Edge-Ansichten und Edge-to-Edge-Compose.
Eingestellte APIs
Die folgenden APIs sind veraltet, aber nicht deaktiviert:
R.attr#enforceStatusBarContrastR.attr#navigationBarColor(für die Bedienung über 3 Schaltflächen, mit 80 % Alpha)Window#isStatusBarContrastEnforcedWindow#setNavigationBarColor(für die Bedienung über 3 Schaltflächen, mit 80% Alpha)Window#setStatusBarContrastEnforced
Die folgenden APIs sind eingestellt und deaktiviert:
R.attr#navigationBarColor(für die Bedienung über Gesten)R.attr#navigationBarDividerColorR.attr#statusBarColorWindow#setDecorFitsSystemWindowsWindow#getNavigationBarColorWindow#getNavigationBarDividerColorWindow#getStatusBarColorWindow#setNavigationBarColor(für die Bedienung über Gesten)Window#setNavigationBarDividerColorWindow#setStatusBarColor
Stabile Konfiguration
Wenn Ihre App auf Android 15 (API‑Level 35) oder höher ausgerichtet ist, werden die Systemleisten nicht mehr aus Configuration ausgeschlossen. Wenn Sie die Bildschirmgröße in der Klasse Configuration für die Layoutberechnung verwenden, sollten Sie sie je nach Bedarf durch bessere Alternativen wie ein geeignetes ViewGroup, WindowInsets oder WindowMetricsCalculator ersetzen.
Configuration ist seit API 1 verfügbar. Sie wird in der Regel aus Activity.onConfigurationChanged abgerufen. Sie enthält Informationen wie Fensterdichte, Ausrichtung und Größen. Ein wichtiges Merkmal der Fenstergrößen, die von Configuration zurückgegeben werden, ist, dass die Systemleisten zuvor ausgeschlossen wurden.
Die Konfigurationsgröße wird in der Regel für die Ressourcenauswahl verwendet, z. B. /res/layout-h500dp. Dies ist weiterhin ein gültiger Anwendungsfall. Die Verwendung für die Layoutberechnung wurde jedoch immer abgeraten. Wenn das der Fall ist, sollten Sie jetzt davon Abstand nehmen. Sie sollten die Verwendung von Configuration durch etwas ersetzen, das je nach Anwendungsfall besser geeignet ist.
Wenn Sie sie zum Berechnen des Layouts verwenden, nutzen Sie eine geeignete ViewGroup, z. B. CoordinatorLayout oder ConstraintLayout. Wenn Sie damit die Höhe der Systemnavigationsleiste ermitteln möchten, verwenden Sie WindowInsets. Wenn Sie die aktuelle Größe Ihres App-Fensters wissen möchten, verwenden Sie computeCurrentWindowMetrics.
In der folgenden Liste werden die Felder beschrieben, die von dieser Änderung betroffen sind:
- Bei den Größen
Configuration.screenWidthDpundscreenHeightDpwerden die Systemleisten nicht mehr ausgeschlossen. Configuration.smallestScreenWidthDpist indirekt von Änderungen anscreenWidthDpundscreenHeightDpbetroffen.Configuration.orientationist indirekt von Änderungen anscreenWidthDpundscreenHeightDpauf Geräten mit einem quadratähnlichen Display betroffen.Display.getSize(Point)ist indirekt von den Änderungen inConfigurationbetroffen. Diese Funktion wurde ab API-Level 30 verworfen.Display.getMetrics()funktioniert seit API-Level 33 bereits so.
Das Attribut „elegantTextHeight“ ist standardmäßig auf „true“ gesetzt.
For apps targeting Android 15 (API level 35), the
elegantTextHeight TextView attribute
becomes true by default, replacing the compact font used by default with some
scripts that have large vertical metrics with one that is much more readable.
The compact font was introduced to prevent breaking layouts; Android 13 (API
level 33) prevents many of these breakages by allowing the text layout to
stretch the vertical height utilizing the fallbackLineSpacing
attribute.
In Android 15, the compact font still remains in the system, so your app can set
elegantTextHeight to false to get the same behavior as before, but it is
unlikely to be supported in upcoming releases. So, if your app supports the
following scripts: Arabic, Lao, Myanmar, Tamil, Gujarati, Kannada, Malayalam,
Odia, Telugu or Thai, test your app by setting elegantTextHeight to true.
elegantTextHeight behavior for apps targeting Android 14 (API level 34) and lower.
elegantTextHeight behavior for apps targeting Android 15.TextView-Breite ändert sich bei komplexen Buchstabenformen
In früheren Android-Versionen wurden bei einigen Schriftarten mit Kurrentschrift oder Sprachen mit komplexer Schriftbildgestaltung die Buchstaben möglicherweise im Bereich des vorherigen oder nächsten Zeichens gezeichnet.
In einigen Fällen wurden solche Buchstaben am Anfang oder Ende abgeschnitten.
Ab Android 15 weist eine TextView eine Breite zu, um genügend Platz für solche Buchstaben zu erhalten. Außerdem können Apps auf der linken Seite zusätzliche Abstände anfordern, um das Abschneiden zu verhindern.
Da sich diese Änderung darauf auswirkt, wie TextView die Breite festlegt, weist TextView standardmäßig mehr Breite zu, wenn die App auf Android 15 (API-Level 35) oder höher ausgerichtet ist. Sie können dieses Verhalten aktivieren oder deaktivieren, indem Sie die setUseBoundsForWidth API auf TextView aufrufen.
Da das Hinzufügen eines linken Abstands zu einer Fehlausrichtung bestehender Layouts führen kann, wird der Abstand auch bei Apps, die auf Android 15 oder höher ausgerichtet sind, nicht standardmäßig hinzugefügt.
Sie können jedoch zusätzliche Abstände hinzufügen, um ein Abschneiden zu verhindern. Rufen Sie dazu setShiftDrawingOffsetForStartOverhang auf.
Die folgenden Beispiele zeigen, wie sich diese Änderungen auf das Textlayout für bestimmte Schriftarten und Sprachen auswirken können.
<TextView android:fontFamily="cursive" android:text="java" />
<TextView android:fontFamily="cursive" android:text="java" android:useBoundsForWidth="true" android:shiftDrawingOffsetForStartOverhang="true" />
<TextView android:text="คอมพิวเตอร์" />
<TextView android:text="คอมพิวเตอร์" android:useBoundsForWidth="true" android:shiftDrawingOffsetForStartOverhang="true" />
Gebietsschemaabhängige Standardzeilenhöhe für EditText
In früheren Android-Versionen wurde die Texthöhe im Textlayout so gedehnt, dass sie der Zeilenhöhe der Schrift entspricht, die dem aktuellen Gebietsschema entspricht. Wenn der Inhalt beispielsweise auf Japanisch war, war die Texthöhe etwas größer, da die Zeilenhöhe der japanischen Schrift etwas größer ist als die einer lateinischen Schrift. Trotz dieser Unterschiede bei den Zeilenhöhen wurde das Element EditText unabhängig von der verwendeten Sprache einheitlich dimensioniert, wie in der folgenden Abbildung dargestellt:
EditText-Elemente darstellen, die Text auf Englisch (en), Japanisch (ja) und Burmese (my) enthalten können. Die Höhe der EditText ist gleich, obwohl diese Sprachen unterschiedliche Zeilenhöhen haben.Für Apps, die auf Android 15 (API-Level 35) ausgerichtet sind, ist jetzt eine Mindestzeilenhöhe für EditText reserviert, die der Referenzschriftart für die angegebene Sprache entspricht, wie in der folgenden Abbildung dargestellt:
EditText-Elemente darstellen, die Text auf Englisch (en), Japanisch (ja) und Burmese (my) enthalten können. Die Höhe des EditText enthält jetzt Platz für die Standardzeilenhöhe der Schriftarten dieser Sprachen.Bei Bedarf können Sie das vorherige Verhalten Ihrer App wiederherstellen, indem Sie das Attribut useLocalePreferredLineHeightForMinimum auf false festlegen. Außerdem können Sie mit der setMinimumFontMetrics API in Kotlin und Java benutzerdefinierte Mindestmesswerte für vertikale Ausrichtungen festlegen.
Kamera und Medien
Unter Android 15 werden die folgenden Änderungen am Kamera- und Medienverhalten für Apps eingeführt, die auf Android 15 oder höher ausgerichtet sind.
Einschränkungen beim Anfordern des Audiofokus
Apps, die auf Android 15 (API-Level 35) ausgerichtet sind, müssen die oberste App sein oder einen Dienst im Vordergrund ausführen, um den Audiofokus anfordern zu können. Wenn eine App versucht, den Fokus anzufordern, ohne eine dieser Anforderungen zu erfüllen, gibt der Aufruf AUDIOFOCUS_REQUEST_FAILED zurück.
Weitere Informationen zum Audiofokus finden Sie unter Audiofokus verwalten.
Aktualisierte Einschränkungen für Nicht-SDKs
Android 15 enthält aktualisierte Listen eingeschränkter Nicht-SDK-Schnittstellen, die auf der Zusammenarbeit mit Android-Entwicklern und den neuesten internen Tests basieren. Wir sorgen nach Möglichkeit dafür, dass öffentliche Alternativen verfügbar sind, bevor wir Nicht-SDK-Schnittstellen einschränken.
Wenn Ihre App nicht auf Android 15 ausgerichtet ist, wirken sich einige dieser Änderungen möglicherweise nicht sofort auf Sie aus. Zwar kann Ihre App je nach Ziel-API-Level Ihrer App auf einige Nicht-SDK-Schnittstellen zugreifen, die Verwendung einer Nicht-SDK-Methode oder eines Nicht-SDK-Felds birgt jedoch immer ein hohes Risiko, dass Ihre App nicht mehr funktioniert.
Wenn Sie sich nicht sicher sind, ob Ihre App Nicht-SDK-Schnittstellen verwendet, können Sie Ihre App testen, um das herauszufinden. Wenn Ihre App auf Nicht-SDK-Schnittstellen basiert, sollten Sie mit der Planung einer Migration zu SDK-Alternativen beginnen. Wir wissen jedoch, dass es für einige Apps gültige Anwendungsfälle für die Verwendung von Nicht-SDK-Schnittstellen gibt. Wenn Sie für eine Funktion in Ihrer App keine Alternative zur Verwendung einer Nicht-SDK-Schnittstelle finden, sollten Sie eine neue öffentliche API anfordern.
To learn more about the changes in this release of Android, see Updates to non-SDK interface restrictions in Android 15. To learn more about non-SDK interfaces generally, see Restrictions on non-SDK interfaces.