Android 14 introduce fantastiche funzionalità e API per gli sviluppatori. Le seguenti risorse ti aiutano a scoprire le funzionalità delle tue app e a iniziare a utilizzare le API correlate.
Per un elenco dettagliato delle API aggiunte, modificate e rimosse, leggi il report diff API. Per informazioni dettagliate sulle API aggiunte, visita la documentazione di riferimento delle 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, assicurati di consultare 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
localeConfigdi 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 fileLocaleConfige aggiunge un riferimento al file manifest finale, quindi non devi più creare o aggiornare il file manualmente. AGP utilizza le risorse nelle cartelleresdei moduli dell'app e eventuali dipendenze dei moduli della libreria per determinare le lingue da includere nel fileLocaleConfig.Aggiornamenti dinamici per il
localeConfigdi un'app: utilizza i metodisetOverrideLocaleConfig()egetOverrideLocaleConfig()inLocaleManagerper 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.
To help you build a user-centric UI for gendered languages, Android 14 introduces the Grammatical Inflection API, which lets you add support for grammatical gender without refactoring your app.
Preferenze regionali
Regional preferences enable users to personalize temperature units, the first day of the week, and numbering systems. A European living in the United States might prefer temperature units to be in Celsius rather than Fahrenheit and for apps to treat Monday as the beginning of the week instead of the US default of Sunday.
New Android Settings menus for these preferences provide users with a
discoverable and centralized location to change app preferences. These
preferences also persist through backup and restore. Several APIs and
intents—such as
getTemperatureUnit
and
getFirstDayOfWeek—
grant your app read access to user preferences, so your app can adjust how it
displays information. You can also register a
BroadcastReceiver on
ACTION_LOCALE_CHANGED
to handle locale configuration changes when regional preferences change.
To find these settings, open the Settings app and navigate to System > Languages & input > Regional preferences.
Accessibilità
Ridimensionamento non lineare dei caratteri fino al 200%
A partire da Android 14, il sistema supporta il ridimensionamento dei caratteri fino al 200%, offrendo agli utenti opzioni di accessibilità aggiuntive.
Per evitare che gli elementi di testo di grandi dimensioni sullo schermo vengano ridimensionati in modo eccessivo, il sistema applica una curva di ridimensionamento non lineare. Questa strategia di ridimensionamento fa sì che il testo grande non venga ridimensionato alla stessa velocità del testo più piccolo. Il ridimensionamento non lineare dei caratteri consente di preservare la gerarchia proporzionale tra elementi di dimensioni diverse, riducendo i problemi di ridimensionamento lineare del testo a livelli elevati (ad esempio testo troncato o testo che diventa più difficile da leggere a causa di dimensioni del display estremamente grandi).
Testare l'app con il ridimensionamento non lineare dei caratteri
Se utilizzi già le unità di pixel scalabili (sp) per definire le dimensioni del testo, queste opzioni aggiuntive e i miglioramenti del ridimensionamento vengono applicati automaticamente al testo della tua app. Tuttavia, devi comunque eseguire test dell'interfaccia utente con le dimensioni del carattere massime abilitate (200%) per assicurarti che la tua app applichi correttamente le dimensioni del carattere e possa ospitare dimensioni del carattere più grandi senza influire sull'usabilità.
Per attivare le dimensioni del carattere al 200%:
- Apri l'app Impostazioni e vai a Accessibilità > Dimensioni visualizzazione e testo.
- Per l'opzione Dimensioni carattere, tocca l'icona Più (+) finché non viene attivata l'impostazione delle dimensioni massime del carattere, come mostrato nell'immagine che accompagna questa sezione.
Utilizzare unità di pixel scalati (sp) per le dimensioni del testo
Ricorda di specificare sempre le dimensioni del testo in unità sp. Quando la tua app utilizza le unità sp, Android può applicare la dimensione del testo preferita dall'utente e ridimensionarla in modo appropriato.
Non utilizzare unità sp per la spaziatura interna o definire le altezze delle visualizzazioni presupponendo una spaziatura interna implicita: con il ridimensionamento non lineare dei caratteri, le dimensioni sp potrebbero non essere proporzionali, quindi 4 sp + 20 sp potrebbero non essere uguali a 24 sp.
Convertire le unità di pixel scalabili (sp)
Utilizza TypedValue.applyDimension() per convertire le unità sp in pixel e TypedValue.deriveDimension() per convertire i pixel in sp. Questi metodi applicano automaticamente la curva di scalabilità non lineare appropriata.
Evita di codificare le equazioni utilizzando
Configuration.fontScale o
DisplayMetrics.scaledDensity. Poiché il ridimensionamento dei caratteri non è lineare, il campo scaledDensity non è più preciso. Il campo fontScale
deve essere utilizzato solo a scopo informativo perché i caratteri non vengono più
scalati con un singolo valore scalare.
Utilizza le unità sp per lineHeight
Definisci sempre android:lineHeight utilizzando le unità sp anziché dp, in modo che l'altezza della riga venga scalata insieme al testo. In caso contrario, se il testo
è in sp, ma il lineHeight è in dp o px, non viene scalato e appare compresso.
TextView corregge automaticamente lineHeight in modo che le proporzioni che intendi utilizzare vengano mantenute, ma solo se sia textSize sia lineHeight sono definiti in unità sp.
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, post-visualizzazione e altro ancora nelle estensioni della fotocamera
Android 14 upgrades and improves camera extensions, allowing apps to handle longer processing times, which enables improved images using compute-intensive algorithms like low-light photography on supported devices. These features give users an even more robust experience when using camera extension capabilities. Examples of these improvements include:
- Dynamic still capture processing latency estimation provides much more
accurate still capture latency estimates based on the current scene and
environment conditions. Call
CameraExtensionSession.getRealtimeStillCaptureLatency()to get aStillCaptureLatencyobject that has two latency estimation methods. ThegetCaptureLatency()method returns the estimated latency betweenonCaptureStartedandonCaptureProcessStarted(), and thegetProcessingLatency()method returns the estimated latency betweenonCaptureProcessStarted()and the final processed frame being available. - Support for capture progress callbacks so that apps can display the current
progress of long-running, still-capture processing operations. You can check
if this feature is available with
CameraExtensionCharacteristics.isCaptureProcessProgressAvailable, and if it is, you implement theonCaptureProcessProgressed()callback, which has the progress (from 0 to 100) passed in as a parameter. Extension specific metadata, such as
CaptureRequest.EXTENSION_STRENGTHfor dialing in the amount of an extension effect, such as the amount of background blur withEXTENSION_BOKEH.Postview Feature for Still Capture in camera extensions, which provides a less-processed image more quickly than the final image. If an extension has increased processing latency, a postview image could be provided as a placeholder to improve UX and switched out later for the final image. You can check if this feature is available with
CameraExtensionCharacteristics.isPostviewAvailable. Then you can pass anOutputConfigurationtoExtensionSessionConfiguration.setPostviewOutputConfiguration.Support for
SurfaceViewallowing for a more optimized and power-efficient preview render path.Support for tap to focus and zoom during extension usage.
Zoom nel sensore
When REQUEST_AVAILABLE_CAPABILITIES_STREAM_USE_CASE in
CameraCharacteristics contains
SCALER_AVAILABLE_STREAM_USE_CASES_CROPPED_RAW, your app
can use advanced sensor capabilities to give a cropped RAW stream the same
pixels as the full field of view by using a CaptureRequest
with a RAW target that has stream use case set to
CameraMetadata.SCALER_AVAILABLE_STREAM_USE_CASES_CROPPED_RAW.
By implementing the request override controls, the updated camera gives users
zoom control even before other camera controls are ready.
Audio USB lossless
Android 14 gains support for lossless audio formats for audiophile-level
experiences over USB wired headsets. You can query a USB device for its
preferred mixer attributes, register a listener for changes in preferred mixer
attributes, and configure mixer attributes using the
AudioMixerAttributes class. This class represents the
format, such as channel mask, sample rate, and behavior of the audio mixer. The
class allows for audio to be sent directly, without mixing,
volume adjustment, or processing effects.
Produttività e strumenti per gli sviluppatori
Gestore delle credenziali
Android 14 adds Credential Manager as a platform API, with additional support back to Android 4.4 (API level 19) devices through a Jetpack Library using Google Play services. Credential Manager aims to make sign-in easier for users with APIs that retrieve and store credentials with user-configured credential providers. Credential Manager supports multiple sign-in methods, including username and password, passkeys, and federated sign-in solutions (such as Sign-in with Google) in a single API.
Passkeys provide many advantages. For example, passkeys are built on industry standards, can work across different operating systems and browser ecosystems, and can be used with both websites and apps.
For more information, see the Credential Manager and passkeys documentation and the blogpost about Credential Manager and passkeys.
Connessione Salute
Health Connect is an on-device repository for user health and fitness data. It allows users to share data between their favorite apps, with a single place to control what data they want to share with these apps.
On devices running Android versions prior to Android 14, Health Connect is available to download as an app on the Google Play store. Starting with Android 14, Health Connect is part of the platform and receives updates through Google Play system updates without requiring a separate download. With this, Health Connect can be updated frequently, and your apps can rely on Health Connect being available on devices running Android 14 or higher. Users can access Health Connect from the Settings in their device, with privacy controls integrated into the system settings.
Health Connect includes several new features in Android 14, such as exercise routes, allowing users to share a route of their workout which can be visualized on a map. A route is defined as a list of locations saved within a window of time, and your app can insert routes into exercise sessions, tying them together. To ensure that users have complete control over this sensitive data, users must allow sharing individual routes with other apps.
For more information, see the Health Connection documentation and the blogpost on What's new in Android Health.
Aggiornamenti di OpenJDK 17
Android 14 continues the work of refreshing Android's core libraries to align with the features in the latest OpenJDK LTS releases, including both library updates and Java 17 language support for app and platform developers.
The following features and improvements are included:
- Updated approximately 300
java.baseclasses to Java 17 support. - Text Blocks, which introduce multi-line string literals to the Java programming language.
- Pattern Matching for instanceof, which allows an object to
be treated as having a specific type in an
instanceofwithout any additional variables. - Sealed classes, which allow you restrict which classes and interfaces can extend or implement them.
Thanks to Google Play system updates (Project Mainline), over 600 million devices are enabled to receive the latest Android Runtime (ART) updates that include these changes. This is part of our commitment to give apps a more consistent, secure environment across devices, and to deliver new features and capabilities to users independent of platform releases.
Java and OpenJDK are trademarks or registered trademarks of Oracle and/or its affiliates.
Miglioramenti per gli store
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 dell'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 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 del foglio di condivisione e ranking migliorato
Android 14 updates the system sharesheet to support custom app actions and more informative preview results for users.
Add custom actions
With Android 14, your app can add custom actions to the system sharesheet it invokes.
Improve ranking of Direct Share targets
Android 14 uses more signals from apps to determine the ranking of the direct share targets to provide more helpful results for the user. To provide the most useful signal for ranking, follow the guidance for improving rankings of your Direct Share targets. Communication apps can also report shortcut usage for outgoing and incoming messages.
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=trueper 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,handleOnBackCancelledinOnBackPressedCallbackonBackStarted,onBackProgressed,onBackCancelledinOnBackAnimationCallback- Utilizza
overrideActivityTransitionanzichéoverridePendingTransitionper 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.
Override per app del produttore di dispositivi con schermo grande
Per-app overrides enable device manufacturers to change the behavior of apps on large screen devices. For example, the FORCE_RESIZE_APP override instructs the system to resize the app to fit display dimensions (avoiding size compatibility mode) even if resizeableActivity="false" is set in the app manifest.
Overrides are intended to improve the user experience on large screens.
New manifest properties enable you to disable some device manufacturer overrides for your app.
Override per app per utenti con schermi di grandi dimensioni
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
La condivisione dello schermo dell'app consente agli utenti di condividere una finestra dell'app anziché l'intero schermo del dispositivo durante la registrazione dei contenuti dello schermo.
Con la condivisione schermo dell'app, la barra di stato, la barra di navigazione, le notifiche e altri elementi dell'interfaccia utente di sistema sono esclusi dalla visualizzazione condivisa. Vengono condivisi solo i contenuti dell'app selezionata.
La condivisione dello schermo dell'app migliora la produttività e la privacy consentendo agli utenti di eseguire più app, ma limitando la condivisione dei contenuti a una singola app.
Risposta rapida basata su LLM in Gboard su Pixel 8 Pro
On Pixel 8 Pro devices with the December Feature Drop, developers can try out higher-quality smart replies in Gboard powered by on-device Large Language Models (LLMs) running on Google Tensor.
This feature is available as a limited preview for US English in WhatsApp, Line, and KakaoTalk. It requires using a Pixel 8 Pro device with Gboard as your keyboard.
To try it out, first enable the feature in Settings > Developer Options > AiCore Settings > Enable Aicore Persistent.
Next, open a conversation in a supported app to see LLM-powered Smart Reply in Gboard's suggestion strip in response to incoming messages.
Grafica
I percorsi sono interrogabili e interpolabili
Android's Path API is a powerful and flexible mechanism for
creating and rendering vector graphics, with the ability to stroke or fill a
path, construct a path from line segments or quadratic or cubic curves, perform
boolean operations to get even more complex shapes, or all of these
simultaneously. One limitation is the ability to find out what is actually in a
Path object; the internals of the object are opaque to callers after creation.
To create a Path, you call methods such as
moveTo(), lineTo(), and
cubicTo() to add path segments. But there has been no way to
ask that path what the segments are, so you must retain that information at
creation time.
Starting in Android 14, you can query paths to find out what's inside of them.
First, you need to get a PathIterator object using the
Path.getPathIterator API:
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();
Next, you can call PathIterator to iterate through the segments
one by one, retrieving all of the necessary data for each segment. This example
uses PathIterator.Segment objects, which packages up the data
for you:
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 also has a non-allocating version of next() where you can pass
in a buffer to hold the point data.
One of the important use cases of querying Path data is interpolation. For
example, you might want to animate (or morph) between two different paths. To
further simplify that use case, Android 14 also includes the
interpolate() method on Path. Assuming the two paths have
the same internal structure, the interpolate() method creates a new Path
with that interpolated result. This example returns a path whose shape is
halfway (a linear interpolation of .5) between path and otherPath:
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); }
The Jetpack graphics-path library enables similar APIs for earlier versions of Android as well.
Mesh personalizzate con shader di vertici e frammenti
Android has long supported drawing triangle meshes with custom shading, but the input mesh format has been limited to a few predefined attribute combinations. Android 14 adds support for custom meshes, which can be defined as triangles or triangle strips, and can, optionally, be indexed. These meshes are specified with custom attributes, vertex strides, varying, and vertex and fragment shaders written in AGSL.
The vertex shader defines the varyings, such as position and color, while the
fragment shader can optionally define the color for the pixel, typically by
using the varyings created by the vertex shader. If color is provided by the
fragment shader, it is then blended with the current Paint
color using the blend mode selected when
drawing the mesh. Uniforms can be passed
into the fragment and vertex shaders for additional flexibility.
Renderer del buffer hardware per Canvas
To assist in using Android's Canvas API to draw with
hardware acceleration into a HardwareBuffer, Android 14
introduces HardwareBufferRenderer. This API is
particularly useful when your use case involves communication with the system
compositor through SurfaceControl for low-latency
drawing.