和先前版本一樣,Android 15 也包含可能會影響應用程式的行為變更。以下行為變更僅適用於指定 Android 15 以上版本的應用程式。如果您的應用程式指定 Android 15 以上版本,建議您視情況修改應用程式,以支援這些行為。
此外,無論應用程式的 targetSdkVersion 為何,請務必查看對所有 Android 15 應用程式有影響的行為變更清單。
核心功能
Android 15 會修改或擴充 Android 系統的各種核心功能。
前景服務異動
我們將對 Android 15 的前景服務進行下列異動。
資料同步處理前景服務逾時行為
Android 15 introduces a new timeout behavior to dataSync for apps targeting
Android 15 (API level 35) or higher. This behavior also applies to the new
mediaProcessing foreground service type.
The system permits an app's dataSync services to run for a total of 6 hours
in a 24-hour period, after which the system calls the running service's
Service.onTimeout(int, int) method (introduced in Android
15). At this time, the service has a few seconds to call
Service.stopSelf(). When Service.onTimeout() is called, the
service is no longer considered a foreground service. If the service does not
call Service.stopSelf(), the system throws an internal exception. The
exception is logged in Logcat with the following message:
Fatal Exception: android.app.RemoteServiceException: "A foreground service of
type dataSync did not stop within its timeout: [component name]"
To avoid problems with this behavior change, you can do one or more of the following:
- Have your service implement the new
Service.onTimeout(int, int)method. When your app receives the callback, make sure to callstopSelf()within a few seconds. (If you don't stop the app right away, the system generates a failure.) - Make sure your app's
dataSyncservices don't run for more than a total of 6 hours in any 24-hour period (unless the user interacts with the app, resetting the timer). - Only start
dataSyncforeground services as a result of direct user interaction; since your app is in the foreground when the service starts, your service has the full six hours after the app goes to the background. - Instead of using a
dataSyncforeground service, use an alternative API.
If your app's dataSync foreground services have run for 6 hours in the last
24, you cannot start another dataSync foreground service unless the user
has brought your app to the foreground (which resets the timer). If you try to
start another dataSync foreground service, the system throws
ForegroundServiceStartNotAllowedException
with an error message like "Time limit already exhausted for foreground service
type dataSync".
Testing
To test your app's behavior, you can enable data sync timeouts even if your app
is not targeting Android 15 (as long as the app is running on an Android 15
device). To enable timeouts, run the following adb command:
adb shell am compat enable FGS_INTRODUCE_TIME_LIMITS your-package-name
You can also adjust the timeout period, to make it easier to test how your
app behaves when the limit is reached. To set a new timeout period, run the
following adb command:
adb shell device_config put activity_manager data_sync_fgs_timeout_duration duration-in-milliseconds
新的媒體處理前景服務類型
Android 15 introduces a new foreground service type, mediaProcessing. This
service type is appropriate for operations like transcoding media files. For
example, a media app might download an audio file and need to convert it to a
different format before playing it. You can use a mediaProcessing foreground
service to make sure the conversion continues even while the app is in the
background.
The system permits an app's mediaProcessing services to run for a total of 6
hours in a 24-hour period, after which the system calls the running service's
Service.onTimeout(int, int) method (introduced in Android
15). At this time, the service has a few seconds to call
Service.stopSelf(). If the service does not
call Service.stopSelf(), the system throws an internal exception. The
exception is logged in Logcat with the following message:
Fatal Exception: android.app.RemoteServiceException: "A foreground service of
type mediaProcessing did not stop within its timeout: [component name]"
To avoid having the exception, you can do one of the following:
- Have your service implement the new
Service.onTimeout(int, int)method. When your app receives the callback, make sure to callstopSelf()within a few seconds. (If you don't stop the app right away, the system generates a failure.) - Make sure your app's
mediaProcessingservices don't run for more than a total of 6 hours in any 24-hour period (unless the user interacts with the app, resetting the timer). - Only start
mediaProcessingforeground services as a result of direct user interaction; since your app is in the foreground when the service starts, your service has the full six hours after the app goes to the background. - Instead of using a
mediaProcessingforeground service, use an alternative API, like WorkManager.
If your app's mediaProcessing foreground services have run for 6 hours in the
last 24, you cannot start another mediaProcessing foreground service unless
the user has brought your app to the foreground (which resets the timer). If you
try to start another mediaProcessing foreground service, the system throws
ForegroundServiceStartNotAllowedException
with an error message like "Time limit already exhausted for foreground service
type mediaProcessing".
For more information about the mediaProcessing service type, see Changes to
foreground service types for Android 15: Media processing.
Testing
To test your app's behavior, you can enable media processing timeouts even if
your app is not targeting Android 15 (as long as the app is running on an
Android 15 device). To enable timeouts, run the following adb command:
adb shell am compat enable FGS_INTRODUCE_TIME_LIMITS your-package-name
You can also adjust the timeout period, to make it easier to test how your
app behaves when the limit is reached. To set a new timeout period, run the
following adb command:
adb shell device_config put activity_manager media_processing_fgs_timeout_duration duration-in-milliseconds
BOOT_COMPLETED 廣播接收器啟動前景服務的限制
BOOT_COMPLETED 廣播接收器啟動有一些新限制
前景服務BOOT_COMPLETED 接收器無法啟動
下列類型的前景服務:
dataSynccameramediaPlaybackphoneCallmediaProjectionmicrophone(我們已對microphone設下這項限制,自 Android 14)
如果 BOOT_COMPLETED 接收器嘗試啟動任何這些類型的前景
服務就會擲回 ForegroundServiceStartNotAllowedException。
測試
如要測試應用程式的行為,即使應用程式並非以 Android 15 為目標版本 (只要應用程式是在 Android 15 裝置上執行),您也可以啟用這些新限制。執行下列 adb 指令:
adb shell am compat enable FGS_BOOT_COMPLETED_RESTRICTIONS your-package-name
如要在不重新啟動裝置的情況下傳送「BOOT_COMPLETED」廣播訊息,請按照下列步驟操作:
執行下列 adb 指令:
adb shell am broadcast -a android.intent.action.BOOT_COMPLETED your-package-name
應用程式擁有 SYSTEM_ALERT_WINDOW 權限時,啟動前景服務的限制
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
應用程式可修改勿擾模式全域狀態的時間異動
指定 Android 15 (API 級別 35) 以上版本的應用程式,將無法再變更裝置上的勿擾模式 (DND) 全域狀態或政策 (透過修改使用者設定或關閉勿擾模式)。相反地,應用程式必須提供 AutomaticZenRule,系統會將其與現有的最嚴格政策優先方案結合為全域政策。呼叫先前影響全域狀態的現有 API (setInterruptionFilter、setNotificationPolicy) 會導致建立或更新隱含的 AutomaticZenRule,而 AutomaticZenRule 的開啟和關閉狀態會根據這些 API 呼叫的呼叫週期而定。
請注意,只有在應用程式呼叫 setInterruptionFilter(INTERRUPTION_FILTER_ALL) 且預期該呼叫會停用先前由其擁有者啟用的 AutomaticZenRule 時,這項變更才會影響可觀察的行為。
OpenJDK API 變更
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(); }
安全性
Android 15 包含多項變更,可提升系統安全性,協助保護應用程式和使用者免受惡意應用程式侵害。
受限的 TLS 版本
Android 15 會限制 TLS 1.0 和 1.1 版本的使用。這些版本先前已在 Android 中淘汰,但現在已禁止用於指定 Android 15 為目標版本的應用程式。
安全啟動背景活動
Android 15 protects users from malicious apps and gives them more control over their devices by adding changes that prevent malicious background apps from bringing other apps to the foreground, elevating their privileges, and abusing user interaction. Background activity launches have been restricted since Android 10 (API level 29).
Other changes
- Change
PendingIntentcreators to block background activity launches by default. This helps prevent apps from accidentally creating aPendingIntentthat could be abused by malicious actors. - Don't bring an app to the foreground unless the
PendingIntentsender allows it. This change aims to prevent malicious apps from abusing the ability to start activities in the background. By default, apps are not allowed to bring the task stack to the foreground unless the creator allows background activity launch privileges or the sender has background activity launch privileges. - Control how the top activity of a task stack can finish its task. If the top activity finishes a task, Android will go back to whichever task was last active. Moreover, if a non-top activity finishes its task, Android will go back to the home screen; it won't block the finish of this non-top activity.
- Prevent launching arbitrary activities from other apps into your own task. This change prevents malicious apps from phishing users by creating activities that appear to be from other apps.
- Block non-visible windows from being considered for background activity launches. This helps prevent malicious apps from abusing background activity launches to display unwanted or malicious content to users.
更安全的意圖
Android 15 推出意圖的 StrictMode。
如要查看 Intent 用量違規的詳細記錄,請使用下列方法:
Kotlin
fun onCreate() { StrictMode.setVmPolicy(VmPolicy.Builder() .detectUnsafeIntentLaunch() .build() ) }
Java
public void onCreate() { StrictMode.setVmPolicy(new VmPolicy.Builder() .detectUnsafeIntentLaunch() .build()); }
使用者體驗和系統 UI
Android 15 包含一些變更,旨在打造更一致、直覺的使用者體驗。
視窗插邊變更
Android 15 有兩項與視窗內嵌相關的變更:預設會強制執行邊到邊,且有設定變更,例如系統列的預設設定。
邊緣到邊緣強制執行
如果應用程式以 Android 15 (API 級別 35) 為目標版本,在搭載 Android 15 的裝置上預設會顯示無邊框模式。
這項重大變更可能會對應用程式的 UI 造成負面影響。這項異動會影響下列 UI 區域:
- 手勢控點導覽列
- 預設為透明。
- 底部位移已停用,因此除非套用插邊,否則內容會在系統導覽列後方繪製。
setNavigationBarColor和R.attr#navigationBarColor已淘汰,不會影響手勢操作模式。setNavigationBarContrastEnforced和R.attr#navigationBarContrastEnforced仍不會影響手勢操作模式。
- 三按鈕操作
- 預設不透明度為 80%,顏色可能與視窗背景相符。
- 底部位移已停用,因此內容會在系統導覽列後方繪製,除非套用插邊。
setNavigationBarColor和R.attr#navigationBarColor預設會設為與視窗背景相符。如要套用此預設值,視窗背景必須是顏色可繪項目。這個 API 已淘汰,但仍會影響三按鈕操作模式。setNavigationBarContrastEnforced和R.attr#navigationBarContrastEnforced預設為 true,這會在三按鈕操作列中加入 80% 不透明的背景。
- 狀態列
- 預設為透明。
- 頂端位移已停用,因此內容會在狀態列後方繪製,除非套用插邊。
setStatusBarColor和R.attr#statusBarColor已淘汰,對 Android 15 沒有影響。setStatusBarContrastEnforced和R.attr#statusBarContrastEnforced已淘汰,但仍會影響 Android 15。
- 螢幕凹口
- 非浮動視窗的
layoutInDisplayCutoutMode必須為LAYOUT_IN_DISPLAY_CUTOUT_MODE_ALWAYS。SHORT_EDGES、NEVER和DEFAULT會解讀為ALWAYS,因此使用者不會看到因螢幕凹口而產生的黑邊,且畫面會顯示到邊框。
- 非浮動視窗的
以下範例顯示應用程式在指定 Android 15 (API 級別 35) 前後,以及套用插邊前後的樣貌。這個範例並不完整,Android Auto 上的顯示方式可能有所不同。
如果應用程式已採用無邊框設計,請檢查以下項目
如果您的應用程式已無邊框並套用插邊,則大多不會受到影響,但下列情況除外。不過,即使您認為不受影響,我們仍建議測試應用程式。
- 您有非浮動視窗,例如使用
SHORT_EDGES、NEVER或DEFAULT而不是LAYOUT_IN_DISPLAY_CUTOUT_MODE_ALWAYS的Activity。如果應用程式在啟動時當機,可能是因為啟動畫面。您可以將核心啟動畫面依附元件升級至 1.2.0-alpha01 以上版本,或設定window.attributes.layoutInDisplayCutoutMode = WindowManager.LayoutInDisplayCutoutMode.always。 - 可能會有流量較低的畫面,且使用者介面遭到遮蔽。確認這些較少造訪的畫面沒有遭到遮蔽的 UI。流量較低的螢幕包括:
- 新手上路或登入畫面
- 設定頁面
如果應用程式尚未採用無邊框設計,請檢查下列項目
如果您的應用程式尚未採用無邊框設計,很可能就會受到影響。除了已採用無邊框設計的應用程式情境,您也應考量下列事項:
- 如果應用程式在 Compose 中使用 Material 3 元件 (
androidx.compose.material3),例如TopAppBar、BottomAppBar和NavigationBar,這些元件可能會不受影響,因為它們會自動處理插邊。 - 如果應用程式使用 Compose 的 Material 2 元件 (
androidx.compose.material),這類元件本身不會自動處理插邊。不過,您可以存取插邊,然後手動套用。在 androidx.compose.material 1.6.0 以上版本,請使用windowInsets參數,為BottomAppBar、TopAppBar、BottomNavigation和NavigationRail手動套用插邊。同樣地,對Scaffold也是使用contentWindowInsets參數。 - 如果應用程式使用 Views 和 Material 元件 (
com.google.android.material),您可能不需採取額外行動,因為大多數以 Views 為基礎的 Material 元件 (例如BottomNavigationView、BottomAppBar、NavigationRailView或NavigationView) 都會處理插邊。不過,如果您使用AppBarLayout,就需要新增android:fitsSystemWindows="true"。 - 如果是自訂可組合函式,請手動將插邊套用為邊框間距。如果內容位於
Scaffold內,您可以使用Scaffold邊框間距值取用插邊。否則,請使用其中一個WindowInsets套用邊框間距。 - 如果應用程式使用 Views 和
BottomSheet、SideSheet或自訂容器,請使用ViewCompat.setOnApplyWindowInsetsListener套用邊框間距。對於RecyclerView,也請使用這個事件監聽器套用邊框間距,同時新增clipToPadding="false"。
如果應用程式必須提供自訂背景保護功能,請檢查下列事項
如果應用程式必須為三按鈕操作模式或狀態列提供自訂背景保護措施,應用程式應使用 WindowInsets.Type#tappableElement() 取得三按鈕操作模式的導覽列高度或 WindowInsets.Type#statusBars,在系統列後方放置可組合函式或檢視區塊。
其他無邊框資源
如要進一步瞭解如何套用插邊,請參閱「無邊框檢視區塊」和「無邊框 Compose」指南。
已淘汰的 API
下列 API 已淘汰,但尚未停用:
R.attr#enforceStatusBarContrastR.attr#navigationBarColor(適用於三按鈕操作模式,且 alpha 值為 80%)Window#isStatusBarContrastEnforcedWindow#setNavigationBarColor(適用於三按鈕操作模式,透明度為 80%)Window#setStatusBarContrastEnforced
下列 API 已淘汰並停用:
R.attr#navigationBarColor(手勢操作模式)R.attr#navigationBarDividerColorR.attr#statusBarColorWindow#setDecorFitsSystemWindowsWindow#getNavigationBarColorWindow#getNavigationBarDividerColorWindow#getStatusBarColorWindow#setNavigationBarColor(手勢操作模式)Window#setNavigationBarDividerColorWindow#setStatusBarColor
穩定設定
如果應用程式指定 Android 15 (API 級別 35) 以上版本,Configuration系統不會再排除系統資訊列。如果您在 Configuration 類別中使用螢幕大小進行版面配置計算,請視需求改用適當的 ViewGroup、WindowInsets 或 WindowMetricsCalculator 等更合適的替代方案。
Configuration 自 API 1 開始提供,這項資訊通常來自 Activity.onConfigurationChanged。並提供視窗密度、方向和大小等資訊。從 Configuration 傳回的視窗大小有一項重要特徵,就是先前會排除系統資訊列。
設定大小通常用於資源選取 (例如 /res/layout-h500dp),這仍是有效的用途。不過,我們一直不建議使用這項屬性計算版面配置。如果正在使用,請立即移開。視用途而定,您應將 Configuration 替換為更合適的項目。
如果使用它來計算版面配置,請使用適當的 ViewGroup,例如 CoordinatorLayout 或 ConstraintLayout。如要使用這個方法判斷系統導覽列的高度,請使用 WindowInsets。如要瞭解應用程式視窗的目前大小,請使用 computeCurrentWindowMetrics。
下列清單說明受這項異動影響的欄位:
Configuration.screenWidthDp和screenHeightDp大小不再排除系統資訊列。Configuration.smallestScreenWidthDp會間接受到screenWidthDp和screenHeightDp變更的影響。Configuration.orientation會間接受到接近正方形裝置上screenWidthDp和screenHeightDp變更的影響。Display.getSize(Point)會間接受到Configuration變更的影響。這項屬性已在 API 級別 30 中淘汰。- 自 API 級別 33 起,
Display.getMetrics()就已採用這種運作方式。
elegantTextHeight 屬性預設為 true
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 寬度變化
In previous versions of Android, some cursive fonts or languages that have
complex shaping might draw the letters in the previous or next character's area.
In some cases, such letters were clipped at the beginning or ending position.
Starting in Android 15, a TextView allocates width for drawing enough space
for such letters and allows apps to request extra paddings to the left to
prevent clipping.
Because this change affects how a TextView decides the width, TextView
allocates more width by default if the app targets Android 15 (API level 35) or
higher. You can enable or disable this behavior by calling the
setUseBoundsForWidth API on TextView.
Because adding left padding might cause a misalignment for existing layouts, the
padding is not added by default even for apps that target Android 15 or higher.
However, you can add extra padding to preventing clipping by calling
setShiftDrawingOffsetForStartOverhang.
The following examples show how these changes can improve text layout for some fonts and languages.
<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" />
EditText 的預設行高會因語言代碼而異
在 Android 先前版本中,文字版面配置會拉伸文字高度,以符合與目前語言代碼相符的字型行高。舉例來說,如果內容是日文,由於日文字型的行高略大於拉丁字型,因此文字高度會稍微變高。不過,儘管行高有這些差異,EditText 元素的大小仍保持一致,不受使用語言代碼影響,如下圖所示:
EditText 元素,可包含英文 (en)、日文 (ja) 和緬甸文 (my) 的文字。EditText 的高度相同,即使這些語言的行高不同。針對指定 Android 15 (API 級別 35) 的應用程式,現在會為 EditText 保留最小行高,以便與指定語言代碼的參考字型相符,如以下圖片所示:
EditText 元素,可包含英文 (en)、日文 (ja) 和緬甸文 (my) 的文字。EditText 的高度現在包含空格,可容納這些語言字型預設的行高。如有需要,應用程式可以將 useLocalePreferredLineHeightForMinimum 屬性指定為 false,藉此還原先前的行為,並使用 Kotlin 和 Java 中的 setMinimumFontMetrics API 設定自訂的垂直最小指標。
相機和媒體
Android 15 對指定 Android 15 以上版本的應用程式,進行了下列攝影機和媒體行為變更。
要求音訊焦點的限制
指定 Android 15 (API 級別 35) 為目標版本的應用程式必須是頂層應用程式,或執行前景服務,才能要求音訊焦點。如果應用程式在未符合上述任一規定的情況下嘗試要求焦點,則呼叫會傳回 AUDIOFOCUS_REQUEST_FAILED。
如要進一步瞭解音訊焦點,請參閱「管理音訊焦點」。
更新非 SDK 限制
基於與 Android 開發人員合作及最新的內部測試,Android 15 包含更新後的受限制非 SDK 介面清單。在限制非 SDK 介面之前,我們盡可能確保公開替代方案的可得性。
如果您的應用程式並不是以 Android 15 為目標版本,則此處所述的某些變更可能不會立即對您造成影響。不過,應用程式視目標 API 級別而定,可能可以存取某些非 SDK 介面,但使用任何非 SDK 方法或欄位時,應用程式停止運作的風險極高。
如果不確定應用程式是否使用非 SDK 介面,可測試應用程式以便確認。如果應用程式仰賴非 SDK 介面,則應開始規劃遷移至 SDK 替代方案。我們瞭解有些應用程式可使用非 SDK 介面運作。如果您除了為應用程式中的某個功能使用非 SDK 介面外,已別無他法,則應要求新的公用 API。
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.