Google Play utilizza gli <uses-sdk>
attributi dichiarati nel file manifest dell'app per filtrare la tua app dai dispositivi
che non soddisfano i requisiti della versione della piattaforma. Prima di impostare questi attributi, assicurati di conoscere i filtri di Google Play.
- syntax:
<uses-sdk android:minSdkVersion="integer" android:targetSdkVersion="integer" android:maxSdkVersion="integer" />
- contenuti in:
<manifest>
- description:
Ti consente di esprimere la compatibilità di un'applicazione con una o più versioni della piattaforma Android tramite un numero intero del livello API. Il livello API espresso da un'applicazione viene confrontato con il livello API di un determinato sistema Android, che può variare da un dispositivo Android all'altro.
Nonostante il nome, questo elemento viene utilizzato per specificare il livello API, non il numero di versione del software development kit (SDK) o della piattaforma Android. Il livello API è sempre un singolo numero intero. Non puoi dedurre il livello API dal numero di versione di Android associato. Ad esempio, non è uguale alla versione principale o alla somma delle versioni principali e secondarie.
Leggi anche il documento sul controllo delle versioni delle applicazioni.
- attributes:
-
android:minSdkVersion
- Un numero intero che indica il livello API minimo richiesto per l'esecuzione dell'applicazione. Il sistema Android impedisce all'utente di installare
l'applicazione se il livello API del sistema è inferiore al valore specificato in
questo attributo. Dichiara sempre questo attributo.
Attenzione: se non dichiari questo attributo, il sistema assume un valore predefinito di "1", che indica che la tua applicazione è compatibile con tutte le versioni di Android. Se non lo è e non hai dichiarato il valore
minSdkVersion
corretto, quando l'applicazione viene installata su un sistema con un livello API incompatibile, l'applicazione si arresta in modo anomalo durante l'esecuzione quando tenta di accedere alle API non disponibili. Per questo motivo, assicurati di dichiarare il livello API appropriato nell'attributominSdkVersion
. android:targetSdkVersion
- Un numero intero che indica il livello API di destinazione dell'applicazione. Se non viene impostato, il valore predefinito è uguale a quello assegnato a
minSdkVersion
.Questo attributo informa il sistema che hai eseguito il test rispetto alla versione di destinazione e il sistema non attiva alcun comportamento di compatibilità per mantenere la compatibilità futura della tua app con la versione di destinazione. L'applicazione può comunque essere eseguita su versioni precedenti (fino a
minSdkVersion
).Per via dell'evoluzione di Android a ogni nuova versione, alcuni comportamenti e persino aspetti visivi possono cambiare. Tuttavia, se il livello API della piattaforma è superiore alla versione dichiarata dal
targetSdkVersion
della tua app, il sistema può attivare comportamenti di compatibilità in modo che l'app continui a funzionare come previsto. Puoi disattivare questi comportamenti di compatibilità specificandotargetSdkVersion
in modo che corrisponda al livello dell'API della piattaforma su cui è in esecuzione.Ad esempio, impostando questo valore su "11" o versioni successive, il sistema applica il tema predefinito Holo alla tua app quando viene eseguita su Android 3.0 o versioni successive e disattiva anche la modalità di compatibilità dello schermo quando viene eseguita su schermi più grandi, perché il supporto del livello API 11 supporta implicitamente gli schermi più grandi.
Esistono molti comportamenti di compatibilità che il sistema può attivare in base al valore impostato per questo attributo. Molti di questi comportamenti sono descritti dalle versioni della piattaforma corrispondenti nel documento di riferimento
Build.VERSION_CODES
.Per mantenere l'applicazione con ogni release di Android, aumenta il valore di questo attributo in modo che corrisponda al livello API più recente, quindi testa attentamente l'applicazione sulla versione della piattaforma corrispondente.
Introdotta in: livello API 4
- Un numero intero che indica il livello API massimo su cui è progettata l'esecuzione dell'applicazione.
In Android 1.5, 1.6, 2.0 e 2.0.1, il sistema controlla il valore di questo attributo durante l'installazione di un'applicazione e durante la convalida dell'applicazione dopo un aggiornamento di sistema. In entrambi i casi, se l'attributo
maxSdkVersion
dell'applicazione è inferiore al livello API utilizzato dal sistema stesso, il sistema non consente l'installazione dell'applicazione. In caso di convalida dopo l'aggiornamento di sistema, l'applicazione viene effettivamente rimossa dal dispositivo.Per illustrare in che modo questo attributo può influire sulla tua applicazione dopo gli aggiornamenti di sistema, considera il seguente esempio:
Un'applicazione che dichiara
maxSdkVersion="5"
nel suo manifest è pubblicata su Google Play. Un utente con un dispositivo su cui è installato Android 1.6 (livello API 4) scarica e installa l'app. Dopo alcune settimane, l'utente riceve un aggiornamento di sistema over-the-air ad Android 2.0 (livello API 5). Dopo l'installazione dell'aggiornamento, il sistema controlla ilmaxSdkVersion
dell'applicazione e lo convalida di nuovo.L'applicazione funziona normalmente. Tuttavia, qualche tempo dopo, il dispositivo riceve un altro aggiornamento di sistema, questa volta ad Android 2.0.1 (livello API 6). Dopo l'aggiornamento, il sistema non può più convalidare nuovamente l'applicazione perché il suo livello API (6) è ora superiore a quello massimo supportato dall'applicazione (5). Il sistema impedisce all'applicazione di essere visibile all'utente, rimuovendola di fatto dal dispositivo.
Avviso: sconsigliamo di dichiarare questo attributo. Innanzitutto, non è necessario impostare l'attributo come mezzo per bloccare il deployment della tua applicazione sulle nuove versioni della piattaforma Android man mano che vengono rilasciate. Per impostazione predefinita, le nuove versioni della piattaforma sono completamente compatibili con le versioni precedenti. La tua applicazione funziona correttamente sulle nuove versioni, a condizione che utilizzi solo API standard e segua le best practice di sviluppo. In secondo luogo, in alcuni casi la dichiarazione dell'attributo può comportare la rimozione della tua applicazione dai dispositivi degli utenti dopo un aggiornamento di sistema a un livello API superiore. La maggior parte dei dispositivi su cui è probabile che la tua applicazione sia installata riceve aggiornamenti di sistema periodici over-the-air, quindi tieni conto del loro effetto sulla tua applicazione prima di impostare questo attributo.
Introdotta in: livello API 4
Alcune versioni di Android (successive ad Android 2.0.1) non controllano né applicano l'attributomaxSdkVersion
durante l'installazione o la convalida. Tuttavia, Google Play continua a utilizzare l'attributo come filtro quando presenta agli utenti le applicazioni disponibili per il download.
- introdotto in:
- Livello API 1
Che cos'è il livello API?
Il livello API è un valore intero che identifica in modo univoco la revisione dell'API del framework offerta da una versione della piattaforma Android.
La piattaforma Android fornisce un'API framework che le applicazioni possono utilizzare per interagire con il sistema Android sottostante. L'API del framework è costituita da:
- Un insieme di pacchetti e classi di base
- Un insieme di elementi e attributi XML per dichiarare un file manifest
- Un insieme di elementi e attributi XML per dichiarare e accedere alle risorse
- Un insieme di intent
- Un insieme di autorizzazioni che le applicazioni possono richiedere, nonché le applicazioni forze di applicazione incluse nel sistema
Ogni versione successiva della piattaforma Android può includere aggiornamenti all'API Android Application Framework che fornisce.
Gli aggiornamenti all'API del framework sono progettati in modo che la nuova API rimanga compatibile con le versioni precedenti dell'API. In altre parole, la maggior parte delle modifiche all'API è additiva e introduce funzionalità nuove o sostitutive. Quando viene eseguito l'upgrade di parti dell'API, le parti sostituite precedenti vengono ritirate, ma non rimosse, in modo che le applicazioni esistenti possano continuare a utilizzarle.
In un numero molto ridotto di casi, alcune parti dell'API vengono modificate o rimosse, anche se in genere queste modifiche sono necessarie solo per supportare la robustezza dell'API e la sicurezza dell'applicazione o del sistema. Tutte le altre parti dell'API delle revisioni precedenti vengono portate avanti senza modifiche.
L'API framework fornita da una piattaforma Android viene specificata utilizzando un identificativo intero chiamato livello API. Ogni versione della piattaforma Android supporta esattamente un livello API, anche se il supporto è implicito per tutti i livelli API precedenti (fino al livello API 1). La release iniziale della piattaforma Android forniva il livello API 1 e le release successive hanno incrementato il livello API.
La tabella seguente specifica il livello API supportato da ogni versione della piattaforma Android. Per informazioni sui numeri relativi di dispositivi su cui è in esecuzione ogni versione, consulta la dashboard Distribuzione.
Utilizzi del livello API in Android
L'identificatore del livello API svolge un ruolo fondamentale per garantire la migliore esperienza possibile a utenti e sviluppatori di applicazioni:
- Consente alla piattaforma Android di descrivere la revisione massima dell'API del framework supportata.
- Consente alle applicazioni di descrivere la revisione dell'API del framework di cui hanno bisogno.
- Consente al sistema di negoziare l'installazione di applicazioni sul dispositivo dell'utente in modo che non vengano installate applicazioni incompatibili con la versione.
Ogni versione della piattaforma Android memorizza il proprio identificatore del livello API internamente, nel sistema Android stesso.
Le applicazioni possono utilizzare un elemento manifest fornito dall'API del framework <uses-sdk>
per descrivere i livelli API minimi e massimi in cui possono essere eseguite, nonché il livello API preferito che sono progettate per supportare. L'elemento offre tre attributi chiave:
android:minSdkVersion
: il livello API minimo su cui l'applicazione può essere eseguita. Il valore predefinito è "1".android:targetSdkVersion
: il livello API su cui è progettata l'esecuzione dell'applicazione. In alcuni casi, consente all'applicazione di utilizzare elementi o comportamenti manifest definiti nel livello API di destinazione, anziché essere limitata all'utilizzo solo di quelli definiti per il livello API minimo.android:maxSdkVersion
: il livello API massimo su cui l'applicazione è in grado di funzionare. Importante: prima di utilizzarlo, leggi le informazioni su questo attributo in questa pagina.
Ad esempio, per specificare il livello minimo dell'API di sistema richiesto da un'applicazione per poter funzionare, l'applicazione include nel proprio file manifest un elemento <uses-sdk>
con un attributo android:minSdkVersion
. Il valore di android:minSdkVersion
è l'intero corrispondente al livello API della versione precedente della piattaforma Android su cui può essere eseguita l'applicazione.
Quando l'utente tenta di installare un'applicazione o di convalidare nuovamente un'applicazione dopo un aggiornamento di sistema, il sistema Android controlla innanzitutto gli attributi <uses-sdk>
nel file manifest dell'applicazione e li confronta con i valori del proprio livello API interno. Il sistema consente di iniziare l'installazione solo se sono soddisfatte le seguenti condizioni:
- Se viene dichiarato un attributo
android:minSdkVersion
, il relativo valore deve essere minore o uguale al numero intero del livello API del sistema. Se non viene dichiarato, il sistema presuppone che l'applicazione richieda il livello API 1. - Se viene dichiarato un attributo
android:maxSdkVersion
, il suo valore deve essere uguale o maggiore al numero intero del livello API del sistema. Se non dichiarato, il sistema presume che l'applicazione non abbia un livello API massimo. Leggi la descrizione di questo attributo per saperne di più su come viene gestito dal sistema.
Se dichiarato nel file manifest di un'applicazione, un elemento <uses-sdk>
potrebbe avere il seguente aspetto:
<manifest> <uses-sdk android:minSdkVersion="5" /> ... </manifest>
Il motivo principale per cui un'applicazione dichiara un livello API in
android:minSdkVersion
è indicare al sistema Android che
utilizza le API introdotte nel livello API specificato.
Se l'applicazione si installa in qualche modo su una piattaforma con un livello API inferiore, si arresta in modo anomalo in fase di esecuzione quando tenta di accedere ad API inesistenti. Il sistema impedisce questo risultato impedendo l'installazione dell'applicazione se il livello API minimo richiesto è superiore a quello della versione della piattaforma sul dispositivo di destinazione.
Considerazioni sullo sviluppo
Le seguenti sezioni forniscono informazioni relative al livello API che devi considerare durante lo sviluppo dell'applicazione.
Compatibilità con le versioni future delle applicazioni
In genere, le applicazioni Android sono compatibili con le nuove versioni della piattaforma Android.
Poiché quasi tutte le modifiche all'API del framework sono additive, un'applicazione Android sviluppata utilizzando una determinata versione dell'API, come specificato dal relativo livello API, è compatibile con le versioni successive della piattaforma Android e con i livelli API superiori. L'applicazione può essere eseguita su tutte le versioni successive della piattaforma Android, tranne in casi isolati in cui l'applicazione utilizza una parte dell'API che viene successivamente rimossa per qualche motivo.
La compatibilità con le versioni successive è importante perché molti dispositivi Android ricevono aggiornamenti di sistema over-the-air (OTA). L'utente potrebbe installare la tua applicazione e utilizzarla correttamente, per poi ricevere in un secondo momento un aggiornamento OTA a una nuova versione della piattaforma Android. Una volta installato l'aggiornamento, l'applicazione viene eseguita in una nuova versione di runtime dell'ambiente, ma che dispone ancora delle API e delle funzionalità di sistema di cui l'applicazione dipende.
Le modifiche al di sotto dell'API, ad esempio quelle nel sistema di base stesso, possono influire sulla tua applicazione quando viene eseguita nel nuovo ambiente. In qualità di sviluppatore dell'applicazione, è importante che tu comprenda l'aspetto e il comportamento dell'applicazione in ogni ambiente di sistema.
Per aiutarti a testare la tua applicazione su varie versioni della piattaforma Android, l'SDK Android include più piattaforme che puoi scaricare. Ogni piattaforma include un'immagine di sistema compatibile che puoi eseguire in un AVD per testare la tua applicazione.
Compatibilità con le versioni precedenti delle applicazioni
Le applicazioni Android non sono necessariamente compatibili con le versioni precedenti della piattaforma Android rispetto a quella in base alla quale sono state compilate.
Ogni nuova versione della piattaforma Android può includere nuove API di framework, ad esempio quelle che consentono alle applicazioni di accedere a nuove funzionalità della piattaforma o sostituiscono parti delle API esistenti. Le nuove API sono accessibili alle applicazioni quando vengono eseguite sulla nuova piattaforma e anche sulle versioni successive della piattaforma, come specificato dal livello API. Tuttavia, poiché le versioni precedenti della piattaforma non includono le nuove API, le applicazioni che le utilizzano non possono essere eseguite su queste piattaforme.
Sebbene sia improbabile che venga eseguito il downgrade di un dispositivo Android a una versione precedente della piattaforma, è importante tenere presente che è probabile che molti dispositivi sul campo eseguono versioni precedenti della piattaforma. Anche tra i dispositivi che ricevono aggiornamenti OTA, alcuni potrebbero avere un ritardo e potrebbero non ricevere un aggiornamento per un periodo di tempo significativo.
Seleziona una versione della piattaforma e un livello API
Quando sviluppi l'applicazione, scegli la versione della piattaforma in base alla quale la compili. In generale, compila l'applicazione in base alla versione più bassa possibile della piattaforma supportata.
Puoi determinare la versione della piattaforma più bassa possibile compilando l'applicazione in base a target di compilazione progressivamente inferiori. Dopo aver determinato la versione minima, crea un AVD utilizzando la versione della piattaforma e il livello API corrispondenti e testa completamente l'applicazione. Assicurati di dichiarare un attributo android:minSdkVersion
nel file manifest dell'applicazione e impostarne il valore sul livello API della versione della piattaforma.
Dichiarare un livello API minimo
Se crei un'applicazione che utilizza API o funzionalità di sistema introdotte nell'ultima versione della piattaforma, imposta l'attributo android:minSdkVersion
sul livello API dell'ultima versione della piattaforma. In questo modo, gli utenti potranno installare la tua applicazione solo se i loro dispositivi eseguono una versione compatibile della piattaforma Android. Ciò contribuisce a garantire che la tua applicazione possa funzionare correttamente sui loro dispositivi.
Se la tua applicazione utilizza le API introdotte nell'ultima versione della piattaforma, ma non dichiara un attributo android:minSdkVersion
, funziona correttamente sui dispositivi con l'ultima versione della piattaforma, ma non su quelli con versioni precedenti della piattaforma. Nel secondo caso, l'applicazione si arresta in modo anomalo in fase di esecuzione quando tenta di utilizzare API che non esistono nelle versioni precedenti.
Eseguire test su livelli API superiori
Dopo aver compilato l'applicazione, assicurati di testarla sulla piattaforma specificata nell'attributo android:minSdkVersion
dell'applicazione. Per farlo, crea un AVD che utilizzi la versione della piattaforma richiesta dalla tua applicazione. Inoltre, per verificare la compatibilità con le versioni successive, esegui e testa l'applicazione su tutte le piattaforme che utilizzano un livello API superiore a quello utilizzato dalla tua applicazione.
L'SDK Android include più versioni della piattaforma che puoi utilizzare, tra cui la versione più recente, e fornisce uno strumento di aggiornamento che puoi utilizzare per scaricare altre versioni della piattaforma, se necessario.
Per accedere all'aggiornamento, utilizza lo strumento a riga di comando android
, situato nella directory <sdk>/tools. Puoi avviare l'aggiornamento dell'SDK eseguendo android sdk
. Puoi anche fare doppio clic sul file android.bat
(Windows) o android
(OS X/Linux).
Per eseguire l'applicazione su diverse versioni della piattaforma nell'emulatore, crea un AVD per ogni versione della piattaforma che vuoi testare. Per ulteriori informazioni sugli AVD, consulta Creare e gestire i dispositivi virtuali. Se utilizzi un dispositivo fisico per i test, assicurati di conoscere il livello API della piattaforma Android su cui è in esecuzione. Consulta la tabella in questo documento per un elenco delle versioni della piattaforma e dei relativi livelli API.
Filtrare la documentazione di riferimento per livello API
Le pagine della documentazione di riferimento della piattaforma Android offrono un controllo "Livello API" nell'area in alto a sinistra di ogni pagina. Puoi utilizzare il controllo per mostrare la documentazione solo per le parti dell'API effettivamente accessibili alla tua applicazione, in base al livello dell'API specificato nell'attributo android:minSdkVersion
del file manifest.
Per utilizzare i filtri, seleziona dal menu il livello API specificato dalla tua applicazione. Le API introdotte in un livello API successivo non sono selezionabili e i relativi contenuti sono mascherati, poiché non sono accessibili alla tua applicazione.
L'applicazione di filtri in base al livello API nella documentazione non fornisce una visualizzazione delle novità o delle funzionalità introdotte in ogni livello API. Fornisce un modo per visualizzare l'intera API associata a un determinato livello API, escludendo al contempo gli elementi API introdotti nei livelli API successivi.
Per tornare alla visualizzazione della documentazione completa, seleziona REL nella parte superiore del menu a livello di API. Per impostazione predefinita, il filtro a livello di API è disabilitato, in modo da poter visualizzare l'API completa del framework, indipendentemente dal livello.
La documentazione di riferimento per i singoli elementi dell'API specifica il livello dell'API in cui viene introdotto ogni elemento. Il livello API per i pacchetti e le classi è specificato come "Aggiunto a livello di API" nell'angolo in alto a destra dell'area dei contenuti di ogni pagina della documentazione. Il livello API per i membri della classe è specificato nelle intestazioni delle descrizioni dettagliate, sul margine destro.