Android 14 introduce fantastiche funzionalità e API per gli sviluppatori. Di seguito puoi trovare informazioni sulle funzionalità per le tue app e iniziare a utilizzare le API correlate.
Per un elenco dettagliato delle API aggiunte, modificate e rimosse, leggi il report sulle differenze delle API. Per informazioni dettagliate sulle API aggiunte, consulta il riferimento all'API Android. Per Android 14, cerca le API aggiunte nel livello API 34. Per scoprire le aree in cui le modifiche alla piattaforma potrebbero influire sulle tue app, consulta le modifiche al comportamento di Android 14 per le app che hanno come target Android 14 e per tutte le app.
Internazionalizzazione
Lingua preferita nelle app
Android 14 espande le funzionalità per lingua per app introdotte in Android 13 (livello API 33) con le seguenti funzionalità aggiuntive:
Genera automaticamente il
localeConfig
di un'app: a partire da Android Studio Giraffe Canary 7 e AGP 8.1.0-alpha07, puoi configurare l'app in modo che supporti automaticamente le preferenze per le lingue per app. In base alle risorse del progetto, il plug-in Android per Gradle genera il fileLocaleConfig
e aggiunge un riferimento al file manifest finale, quindi non devi più creare o aggiornare il file manualmente. AGP utilizza le risorse nelle cartelleres
dei moduli dell'app e eventuali dipendenze dei moduli della libreria per determinare le lingue da includere nel fileLocaleConfig
.Aggiornamenti dinamici per il
localeConfig
di un'app: utilizza i metodisetOverrideLocaleConfig()
egetOverrideLocaleConfig()
inLocaleManager
per aggiornare dinamicamente l'elenco delle lingue supportate della tua app nelle impostazioni di sistema del dispositivo. Utilizza questa flessibilità per personalizzare l'elenco delle lingue supportate per regione, eseguire esperimenti A/B o fornire un elenco aggiornato delle impostazioni internazionali se la tua app utilizza i push lato server per la localizzazione.Visibilità della lingua dell'app per gli editor di metodi di immissione (IME): gli IME possono utilizzare il metodo
getApplicationLocales()
per controllare la lingua dell'app corrente e associare la lingua dell'IME a quella lingua.
API Grammatical Inflection
Tre miliardi di persone parlano lingue con genere: lingue in cui le categorie grammaticali, come nomi, verbi, aggettivi e preposizioni, si declinano in base al genere delle persone e degli oggetti di cui parli o a cui ti riferisci. Tradizionalmente, molte lingue con genere grammaticale utilizzano il genere grammaticale maschile come genere predefinito o generico.
Rivolgersi agli utenti con il genere grammaticale sbagliato, ad esempio alle donne con il genere grammaticale maschile, può influire negativamente sul loro rendimento e sul loro atteggiamento. Al contrario, un'interfaccia utente con un linguaggio che riflette correttamente il genere grammaticale dell'utente può migliorare il coinvolgimento dell'utente e offrire un'esperienza utente più personalizzata e dal suono naturale.
为帮助您针对区分性别的语言构建以用户为中心的界面,Android 14 引入了 Grammatical Inflection API,让您无需重构应用便能添加对语法性别的支持。
Preferenze regionali
用户可通过地区偏好设置对温度单位、一周的第一天和编号系统进行个性化设置。居住在美国的欧洲用户可能更希望使用摄氏度,而不是华氏度,并且希望应用将星期一视为一周的开始,而不是像美国那样默认从星期日开始。
新 Android 设置菜单包含这些偏好设置,使用户能够在一个位置集中发现这些应用更改偏好设置。这些偏好设置在备份和恢复设备后也会保持不变。多个 API 和 intent(例如 getTemperatureUnit
和 getFirstDayOfWeek
)会为您的应用授予读取权限来访问用户偏好设置,因此您的应用可以调整其显示信息的方式。您还可以在 ACTION_LOCALE_CHANGED
上注册 BroadcastReceiver
,以便在地区偏好设置发生更改时处理语言区域配置更改。
如需找到这些设置,请打开“设置”应用,然后依次前往系统 > 语言和输入法 > 地区偏好设置。


Accessibilità
Ridimensionamento non lineare dei caratteri al 200%
从 Android 14 开始,系统支持字体放大高达 200%,为弱视用户提供了符合网络内容无障碍指南 (WCAG) 的其他无障碍选项。
为防止屏幕上的大文本元素放大过大,系统会采用非线性放大曲线。这种放大策略意味着大号文本的放大比例不会与较小的文本相同。非线性字体缩放有助于保持不同大小元素之间的比例层次结构,同时缓解高级别线性文本缩放的问题(例如文本被截断或文本因超大显示大小而难以阅读)。
使用非线性字体放大测试应用

如果您已经使用放大像素 (sp) 单位来定义文本大小,那么这些额外的选项和缩放改进会自动应用于应用中的文本。但是,您仍然应该在启用最大字体大小 (200%) 的情况下执行界面测试,以确保应用正确应用字体大小,并且可以适应更大的字体大小,而不影响易用性。
要启用 200% 字号,请按以下步骤操作:
- 打开“设置”应用,然后依次前往无障碍 > 显示大小和文字。
- 在字号选项中,点按加号 (+) 图标,直到启用最大字号设置,如本部分随附的图片所示。
针对文本大小使用放大像素 (sp) 单位
请务必始终以 sp 为单位指定文本大小。当应用使用 sp 单位时,Android 可以应用用户的首选文本大小并相应地缩放。
不要为内边距使用 sp 单位,也不假设隐式内边距定义视图高度:使用非线性字体缩放 sp 尺寸可能不成比例,因此 4sp + 20sp 可能不等于 24sp。
转换放大像素 (sp) 单位
使用 TypedValue.applyDimension()
从 sp 单位转换为像素,并使用 TypedValue.deriveDimension()
将像素转换为 sp。这些方法会自动应用适当的非线性缩放曲线。
避免使用 Configuration.fontScale
或 DisplayMetrics.scaledDensity
对方程进行硬编码。由于字体缩放是非线性的,因此 scaledDensity
字段不再准确。fontScale
字段应仅用于提供信息,因为字体不再使用单个标量值进行缩放。
对 lineHeight 使用 sp 单位
始终使用 sp 单位(而非 dp)定义 android:lineHeight
,以便行高随文本一起缩放。否则,如果您的文本为 sp,而 lineHeight
以 dp 或 px 为单位,则文本无法缩放且看起来狭窄。TextView 会自动更正 lineHeight
以保留您预期的比例,但前提是以 sp 为单位同时定义 textSize
和 lineHeight
。
Fotocamera e contenuti multimediali
Ultra HDR per le immagini

Android 14 aggiunge il supporto per le immagini HDR (High Dynamic Range) che mantengono più informazioni del sensore quando scatti una foto, il che consente di ottenere colori vivaci e un maggiore contrasto. Android utilizza il formato Ultra HDR, che è completamente compatibile con le immagini JPEG, consentendo alle app di dialogare senza problemi con le immagini HDR, visualizzandole in Standard Dynamic Range (SDR) se necessario.
Il rendering di queste immagini nell'interfaccia utente in HDR viene eseguito automaticamente dal framework quando l'app attiva l'utilizzo dell'interfaccia utente HDR per la finestra di attività tramite una voce del manifest o in fase di esecuzione tramite chiamata di Window.setColorMode()
. Puoi anche acquisire immagini statiche Ultra HDR compresse sui dispositivi supportati. Con un maggior numero di colori recuperati
dal sensore, la modifica in post può essere più flessibile. Il valore Gainmap
associato alle immagini Ultra HDR può essere utilizzato per eseguire il rendering utilizzando OpenGL o Vulkan.
Zoom, messa a fuoco, Postview e altro ancora nelle estensioni della fotocamera
Android 14 esegue l'upgrade e migliora le estensioni della fotocamera, consentendo alle app di gestire tempi di elaborazione più lunghi, il che consente di migliorare le immagini utilizzando algoritmi ad alta intensità di calcolo come la fotografia in condizioni di scarsa illuminazione su supportati dispositivi. Queste funzionalità offrono agli utenti un'esperienza ancora più solida quando utilizzano le funzionalità di estensione della videocamera. Ecco alcuni esempi di questi miglioramenti:
- La stima della latenza di elaborazione delle foto dinamiche fornisce stime della latenza di acquisizione delle foto molto più accurate in base alle condizioni ambientali e della scena attuali. Chiama
CameraExtensionSession.getRealtimeStillCaptureLatency()
per ottenere un oggettoStillCaptureLatency
con due metodi di stima della latenza. Il metodogetCaptureLatency()
restituisce la latenza stimata traonCaptureStarted
eonCaptureProcessStarted()
, mentre il metodogetProcessingLatency()
restituisce la latenza stimata traonCaptureProcessStarted()
e il frame elaborato finale disponibile. - Supporto per i callback relativi all'avanzamento dell'acquisizione in modo che le app possano mostrare l'avanzamento corrente delle operazioni di elaborazione di acquisizioni di foto ancora in corso. Puoi verificare se questa funzionalità è disponibile con
CameraExtensionCharacteristics.isCaptureProcessProgressAvailable
e, in questo caso, implementare il callbackonCaptureProcessProgressed()
, a cui viene passato come parametro il progresso (da 0 a 100). Metadati specifici per le estensioni, ad esempio
CaptureRequest.EXTENSION_STRENGTH
per regolare l'intensità di un effetto dell'estensione, ad esempio la quantità di sfocatura dello sfondo conEXTENSION_BOKEH
.Funzionalità Postview per l'acquisizione di foto nelle estensioni della fotocamera, che fornisce un'immagine meno elaborata più rapidamente rispetto all'immagine finale. Se un'estensione ha aumentato la latenza di elaborazione, è possibile fornire un'immagine post-visualizzazione come segnaposto per migliorare l'esperienza utente e sostituirla in un secondo momento con l'immagine finale. Puoi verificare se questa funzionalità è disponibile con
CameraExtensionCharacteristics.isPostviewAvailable
. Dopodiché puoi passare unOutputConfiguration
aExtensionSessionConfiguration.setPostviewOutputConfiguration
.Supporto di
SurfaceView
che consente un percorso di rendering dell'anteprima più ottimizzato e a basso consumo energetico.Supporto per il tocco per mettere a fuoco e lo zoom durante l'utilizzo dell'estensione.
Zoom in-sensor
当 CameraCharacteristics
中的 REQUEST_AVAILABLE_CAPABILITIES_STREAM_USE_CASE
包含 SCALER_AVAILABLE_STREAM_USE_CASES_CROPPED_RAW
时,您的应用可以使用高级传感器功能,将剪裁后的 RAW 数据流的像素与全视野范围相同,方法是将 CaptureRequest
与将数据流用例设置为 CameraMetadata.SCALER_AVAILABLE_STREAM_USE_CASES_CROPPED_RAW
的 RAW 目标搭配使用。通过实现请求替换控件,更新后的相机可让用户在其他相机控件准备就绪之前使用缩放控件。
Audio USB senza perdita di dati
Android 14 支持无损音频格式,可通过 USB 有线耳机提供发烧友级体验。您可以查询 USB 设备的首选混音器属性,注册监听器以监听首选混音器属性的更改,以及使用 AudioMixerAttributes
类配置混音器属性。此类表示音频混音器的格式,例如声道掩码、采样率和行为。该类允许直接发送音频,而无需混音、调节音量或处理效果。
Produttività e strumenti per sviluppatori
Gestore delle credenziali
Android 14 将 Credential Manager 添加为平台 API,并通过使用 Google Play 服务的 Jetpack 库,向后额外支持 Android 4.4(API 级别 19)设备。Credential Manager 旨在通过 API 使用用户配置的凭据提供程序检索和存储凭据,让用户更轻松地登录。Credential Manager 在单个 API 中支持多种登录方法,包括用户名和密码、通行密钥和联合登录解决方案(如“使用 Google 账号登录”)。
通行密钥具有许多优势。例如,通行密钥是基于业界标准构建的,可在各种不同的操作系统和浏览器生态系统中使用,并且可用于网站和应用。
如需了解详情,请参阅 Credential Manager 和通行密钥文档以及介绍 Credential Manager 和通行密钥的博文。
Connessione Salute
Health Connect 是用户健康与健身数据的设备端仓库。借助该功能,用户可以在一个位置控制要与这些应用共享哪些数据,并在自己喜爱的应用之间共享数据。
在搭载 Android 14 之前的 Android 版本的设备上,Health Connect 可作为应用从 Google Play 商店下载。从 Android 14 开始,Health Connect 将成为 Android 平台的一部分,并通过 Google Play 系统更新接收更新,而无需单独下载。这样一来,Health Connect 就可以频繁更新,您的应用可以依赖于搭载 Android 14 或更高版本的设备上提供的 Health Connect。用户可以通过设备的“设置”访问 Health Connect,隐私控制功能集成到系统设置中。


Health Connect 在 Android 14 中包含多项新功能,例如锻炼路线,可让用户分享可在地图上直观呈现的锻炼路线。路线定义为在一定时间范围内保存的位置列表,您的应用可以将路线插入锻炼时段,将它们关联起来。为确保用户能够完全控制此类敏感数据,用户必须允许与其他应用共享单个路线。
如需了解详情,请参阅 Health Connect 文档以及有关 Android Health 中的新功能的博文。
Aggiornamenti di OpenJDK 17
Android 14 continua l'opera di aggiornamento delle librerie di base di Android per allinearsi alle funzionalità delle ultime release OpenJDK LTS, inclusi gli aggiornamenti delle librerie e il supporto del linguaggio Java 17 per gli sviluppatori di app e piattaforme.
Sono incluse le seguenti funzionalità e i seguenti miglioramenti:
- Sono stati aggiornati circa 300 corsi
java.base
per il supporto di Java 17. - Blocchi di testo, che introducono stringhe letterali su più righe nel linguaggio di programmazione Java.
- Corrispondenza pattern per instanceof, che consente di trattare un oggetto come se avesse un tipo specifico in un
instanceof
senza variabili aggiuntive. - Classi sigillate, che ti consentono di limitare le classi e le interfacce che possono estenderle o implementarle.
Grazie agli aggiornamenti di sistema Google Play (Project Mainline), oltre 600 milioni di dispositivi sono abilitati a ricevere gli aggiornamenti più recenti di Android Runtime (ART) che includono queste modifiche. Ciò fa parte del nostro impegno a offrire alle app un ambiente più coerente e sicuro su tutti i dispositivi e a fornire nuove funzionalità e capacità agli utenti indipendentemente dalle release della piattaforma.
Java e OpenJDK sono marchi o marchi registrati di Oracle e/o delle sue società consociate.
Miglioramenti per gli store di app
Android 14 introduce diverse API PackageInstaller
che consentono agli store di app di migliorare l'esperienza utente.
Richiedere l'approvazione dell'installazione prima del download
L'installazione o l'aggiornamento di un'app potrebbe richiedere l'approvazione dell'utente.
Ad esempio, quando un programma di installazione che utilizza l'autorizzazione REQUEST_INSTALL_PACKAGES
tenta di installare una nuova app. Nelle versioni precedenti di Android, gli store possono richiedere l'approvazione dell'utente solo dopo che gli APK sono stati scritti nella sessione di installazione e la sessione è stata committata.
A partire da Android 14, il metodo requestUserPreapproval()
consente agli installatori di richiedere l'approvazione dell'utente prima di confermare la sessione di installazione. Questo miglioramento consente a un negozio di app di posticipare il download di eventuali APK fino a quando l'installazione non è stata approvata dall'utente. Inoltre, una volta che un utente ha approvato l'installazione, l'app store può scaricare e installare l'app in background senza interrompere l'utente.
Richiedere la responsabilità per gli aggiornamenti futuri
Il metodo setRequestUpdateOwnership()
consente a un installatore di indicare al sistema che intende essere responsabile degli aggiornamenti futuri di un'app che sta installando. Questa funzionalità consente l'applicazione della proprietà degli aggiornamenti, il che significa che solo il proprietario dell'aggiornamento è autorizzato a installare aggiornamenti automatici dell'app. L'applicazione della proprietà degli aggiornamenti contribuisce a garantire che gli utenti ricevano gli aggiornamenti solo dall'app store previsto.
Qualsiasi altro programma di installazione, inclusi quelli che utilizzano l'autorizzazione INSTALL_PACKAGES
, deve ricevere l'approvazione esplicita dell'utente per installare un aggiornamento. Se un utente decide di procedere con un
aggiornamento da un'altra origine, la proprietà dell'aggiornamento viene persa.
Aggiornare le app in orari meno critici
In genere, gli store per app vogliono evitare di aggiornare un'app in uso attivo perché questo comporta l'interruzione dei processi in esecuzione dell'app, il che potrebbe interrompere l'attività dell'utente.
A partire da Android 14, l'API InstallConstraints
offre ai programmatori di installazioni un modo per assicurarsi che gli aggiornamenti delle app vengano eseguiti al momento opportuno. Ad esempio, un app store può chiamare il metodo
commitSessionAfterInstallConstraintsAreMet()
per
assicurarsi che un aggiornamento venga eseguito solo quando l'utente non interagisce più con l'app in questione.
Installare facilmente le suddivisioni facoltative
Con gli APK divisi, le funzionalità di un'app possono essere pubblicate in file APK separati,
invece che come APK monolitico. Gli APK suddivisi consentono agli store di app di ottimizzare la distribuzione di diversi componenti dell'app. Ad esempio, gli store di app potrebbero eseguire l'ottimizzazione in base alle proprietà del dispositivo di destinazione. L'API
PackageInstaller
supporta le suddivisioni dalla sua
introduzione nel livello API 22.
In Android 14, il metodo setDontKillApp()
consente a un installatore di indicare che i processi in esecuzione dell'app non devono essere interrotti quando vengono installati nuovi split. Gli store possono utilizzare questa funzionalità per installare senza problemi nuove funzionalità di un'app mentre l'utente la utilizza.
Bundle di metadati delle app
Starting in Android 14, the Android package installer lets you specify app metadata, such as data safety practices, to include on app store pages such as Google Play.
Rilevare quando gli utenti acquisiscono screenshot del dispositivo
Per creare un'esperienza più standardizzata per il rilevamento degli screenshot, Android 14 introduce un'API di rilevamento degli screenshot che tutela la privacy. Questa API consente alle app di registrare i callback in base all'attività. Questi callback vengono richiamati e l'utente riceve una notifica quando acquisisce uno screenshot mentre l'attività è visibile.
Esperienza utente
Azioni personalizzate della scheda di condivisione e ranking migliorato
Android 14 aggiorna la scheda di condivisione di sistema per supportare azioni di app personalizzate e risultati di anteprima più informativi per gli utenti.
Aggiungere azioni personalizzate
Con Android 14, la tua app può aggiungere azioni personalizzate alla scheda di condivisione di sistema che richiama.

Migliorare il ranking dei target di condivisione diretta
Android 14 utilizza più indicatori delle app per determinare il ranking dei target di condivisione diretta al fine di fornire risultati più utili all'utente. Per fornire l'indicatore più utile per il ranking, segui le indicazioni per migliorare i ranking dei target di condivisione diretta. Le app di comunicazione possono anche segnalare l'utilizzo delle scorciatoie per i messaggi in uscita e in entrata.

Supporto di animazioni integrate e personalizzate per il gesto Indietro predittivo
Android 13 ha introdotto l'animazione di ritorno alla schermata Home predittiva come opzione per gli sviluppatori. Se viene utilizzato in un'app supportata con l'opzione per gli sviluppatori attivata, lo scorrimento indietro mostra un'animazione che indica che il gesto di ritorno all'indietro fa uscire dall'app e torna alla schermata Home.
Android 14 include diversi miglioramenti e nuove indicazioni per il pulsante Indietro predittivo:
- Puoi impostare
android:enableOnBackInvokedCallback=true
per attivare le animazioni di sistema Indietro predittive per ogni attività anziché per l'intera app. - Abbiamo aggiunto nuove animazioni di sistema per accompagnare l'animazione di ritorno alla home page di Android 13. Le nuove animazioni di sistema sono interattive e inter-attività e vengono visualizzate automaticamente dopo la migrazione a Indietro predittivo.
- Abbiamo aggiunto nuove animazioni dei componenti Material per schede inferiori, schede laterali e Ricerca.
- Abbiamo creato linee guida per il design per la creazione di animazioni e transizioni in-app personalizzate.
- Abbiamo aggiunto nuove API per supportare le animazioni di transizione in-app personalizzate:
handleOnBackStarted
,handleOnBackProgressed
,handleOnBackCancelled
in
OnBackPressedCallback
onBackStarted
,onBackProgressed
,onBackCancelled
in
OnBackAnimationCallback
- Utilizza
overrideActivityTransition
anzichéoverridePendingTransition
per le transizioni che rispondono quando l'utente scorri indietro.
Con questa release di anteprima di Android 14, tutte le funzionalità di Indietro predittivo rimangono nascoste dietro un'opzione per sviluppatori. Consulta la guida per gli sviluppatori per eseguire la migrazione della tua app al flusso di ritorno predittivo, nonché la guida per gli sviluppatori per creare transizioni in-app personalizzate.
Sostituzioni per app dei produttori di dispositivi con schermo grande
借助按应用替换项,设备制造商可以更改应用在大屏设备上的行为。例如,FORCE_RESIZE_APP
替换项会指示系统调整应用大小以适应显示屏尺寸(避免进入尺寸兼容模式),即使在应用清单中设置了 resizeableActivity="false"
也是如此。
替换项旨在改善大屏设备上的用户体验。
借助新的清单属性,您可以为应用停用某些设备制造商替换项。
Sostituzioni per app per utente con schermo grande
Le sostituzioni per app modificano il comportamento delle app sui dispositivi con schermi grandi. Ad esempio, l'override del produttore del dispositivo OVERRIDE_MIN_ASPECT_RATIO_LARGE
imposta le proporzioni dell'app su 16:9 indipendentemente dalla configurazione dell'app.
Android 14 QPR1 consente agli utenti di applicare sostituzioni per app tramite un nuovo menu delle impostazioni sui dispositivi con schermi di grandi dimensioni.
Condivisione della schermata dell'app
借助应用界面共享功能,用户可以在录制屏幕内容时共享应用窗口,而不是整个设备屏幕。
在应用屏幕共享模式下,状态栏、导航栏、通知和其他系统界面元素会从共享显示屏中排除。系统只会分享所选应用的内容。
应用屏幕共享功能可让用户运行多个应用,但将内容共享限制为单个应用,从而提高工作效率并保护隐私。
Risposta rapida basata su LLM in Gboard su Pixel 8 Pro
在搭载 12 月功能分块的 Pixel 8 Pro 设备上,开发者可以在 Gboard 中试用质量更高的智能回复,这些回复由在 Google Tensor 上运行的设备端大语言模型 (LLM) 提供支持。
此功能目前仅在 WhatsApp、Line 和 KakaoTalk 中以美式英语的形式提供给用户进行小范围测试。此功能需要使用 Pixel 8 Pro 设备,并将 Gboard 用作键盘。
如需试用此功能,请先依次前往设置 > 开发者选项 > AiCore 设置 > 启用 Aicore 持久性,启用该功能。
接下来,在受支持的应用中打开对话,即可在 Gboard 的建议栏中看到依托 LLM 的智能回复,以便回复收到的消息。
Grafica
I percorsi sono interrogabili e interpolabili
Android 的 Path
API 是一种强大且灵活的机制,可用于创建和渲染矢量图形,能够描边或填充路径、根据线段或二次曲线或立方曲线构建路径、执行布尔运算以获取更复杂的形状,或同时执行所有这些操作。但有一个限制是,您无法了解 Path 对象中实际包含的内容;该对象的内部信息在创建后对调用方是不透明的。
如需创建 Path
,您可以调用 moveTo()
、lineTo()
和 cubicTo()
等方法来添加路径段。但是,无法询问该路径有哪些片段,因此您必须在创建时保留该信息。
从 Android 14 开始,您可以查询路径以了解其内部内容。首先,您需要使用 Path.getPathIterator
API 获取 PathIterator
对象:
Kotlin
val path = Path().apply { moveTo(1.0f, 1.0f) lineTo(2.0f, 2.0f) close() } val pathIterator = path.pathIterator
Java
Path path = new Path(); path.moveTo(1.0F, 1.0F); path.lineTo(2.0F, 2.0F); path.close(); PathIterator pathIterator = path.getPathIterator();
接下来,您可以调用 PathIterator
逐个遍历片段,并检索每个片段的所有必要数据。以下示例使用了 PathIterator.Segment
对象,它会为您打包数据:
Kotlin
for (segment in pathIterator) { println("segment: ${segment.verb}, ${segment.points}") }
Java
while (pathIterator.hasNext()) { PathIterator.Segment segment = pathIterator.next(); Log.i(LOG_TAG, "segment: " + segment.getVerb() + ", " + segment.getPoints()); }
PathIterator
还有一个非分配版 next()
,您可以在其中传入缓冲区来保存点数据。
查询 Path
数据的一个重要用例是插值。例如,您可能想在两个不同的路径之间添加动画(或变形)。为了进一步简化该用例,Android 14 针对 Path
还包含 interpolate()
方法。假设两个路径具有相同的内部结构,interpolate()
方法会使用该插值结果创建一个新的 Path
。以下示例返回了一个形状介于 path
和 otherPath
之间的一半(线性插值为 0.5)的路径:
Kotlin
val interpolatedResult = Path() if (path.isInterpolatable(otherPath)) { path.interpolate(otherPath, .5f, interpolatedResult) }
Java
Path interpolatedResult = new Path(); if (path.isInterpolatable(otherPath)) { path.interpolate(otherPath, 0.5F, interpolatedResult); }
Jetpack graphics-path 库也为早期版本的 Android 启用了类似的 API。
Mesh personalizzati con shader di vertici e frammenti
Android 长期以来一直支持使用自定义着色绘制三角网格,但输入网格格式仅限于一些预定义的属性组合。Android 14 增加了对自定义网格的支持,可将其定义为三角形或三角形条,并且可以选择是否编入索引。这些网格是使用自定义属性、顶点步长、可变以及使用 AGSL 编写的顶点着色器和片段着色器指定的。
顶点着色器定义了位置和颜色等变量,而片段着色器可以选择为像素定义颜色,通常是使用顶点着色器创建的变量。如果片段着色器提供颜色,则系统会使用绘制网格时选择的混合模式将其与当前 Paint
颜色混合。Uniform 可以传递到片段着色器和顶点着色器,以提高灵活性。
Renderer del buffer hardware per Canvas
协助使用 Android 的 Canvas
API 通过
硬件加速至 HardwareBuffer
、Android 14
引入了 HardwareBufferRenderer
。如果您的用例涉及通过 SurfaceControl
与系统合成器通信以实现低延迟绘制,此 API 特别有用。