Android utilizza gli intent e i relativi extra per consentire agli utenti di condividere informazioni in modo rapido e semplice utilizzando le loro app preferite.
Android offre agli utenti due modi per condividere i dati tra le app:
- Android Sharesheet è progettato principalmente per inviare contenuti all'esterno dell'app e/o direttamente a un altro utente. Ad esempio, per condividere un URL con un amico.
- Il resolver di intent di Android è più adatto per passare i dati alla fase successiva di un'attività ben definita. Ad esempio, per aprire un PDF dall'app e consentire agli utenti di scegliere il visualizzatore preferito.
Quando crei un intent, devi specificare l'azione che vuoi che esegua.
Android utilizza l'azione ACTION_SEND per inviare dati da un'attività all'altra, anche tra i limiti dei processi. Devi specificare i dati e il relativo tipo. Il sistema identifica automaticamente le attività compatibili che possono ricevere i dati e le mostra all'utente. Nel caso del resolver di intent, se una sola attività può gestire l'intent, questa viene avviata immediatamente.
Perché utilizzare Android Sharesheet
Ti consigliamo vivamente di utilizzare Android Sharesheet per creare coerenza per gli utenti tra le app. Non mostrare l'elenco dei target di condivisione della tua app né creare varianti di Sharesheet.
Android Sharesheet consente agli utenti di condividere informazioni con la persona giusta, con suggerimenti di app suggerite pertinenti, il tutto con un solo tocco. Sharesheet può suggerire target non disponibili per le soluzioni personalizzate e utilizza una classificazione coerente. Questo perché Sharesheet può tenere conto delle informazioni sull'attività dell'app e dell'attività utente disponibili solo per il sistema.
Android Sharesheet offre anche molte funzionalità utili per gli sviluppatori. Ad esempio, puoi:
- Scoprire quando e dove gli utenti completano una condivisione
- Aggiungere un
ChooserTargetpersonalizzato e target dell'app - Fornire anteprime di contenuti di testo RTF, a partire da Android 10 (livello API 29)
- Escludere i target che corrispondono a nomi di componenti specifici
Utilizzare Android Sharesheet
Per tutti i tipi di condivisione, crea un intent e imposta la relativa azione su Intent.ACTION_SEND.
Per visualizzare Android Sharesheet, chiama
Intent.createChooser(),
passandogli l'oggetto Intent.
Restituisce una versione dell'intent che mostra sempre Android Sharesheet.
Inviare contenuti di testo
L'utilizzo più semplice e comune di Android Sharesheet è l'invio di contenuti di testo da un'attività all'altra. Ad esempio, la maggior parte dei browser può condividere l'URL della pagina attualmente visualizzata come testo con un'altra app. Questa funzionalità è utile per condividere un articolo o un sito web con gli amici tramite email o social network. Ecco un esempio di come farlo:
Kotlin
val sendIntent: Intent = Intent().apply { action = Intent.ACTION_SEND putExtra(Intent.EXTRA_TEXT, "This is my text to send.") type = "text/plain" } val shareIntent = Intent.createChooser(sendIntent, null) startActivity(shareIntent)
Java
Intent sendIntent = new Intent(); sendIntent.setAction(Intent.ACTION_SEND); sendIntent.putExtra(Intent.EXTRA_TEXT, "This is my text to send."); sendIntent.setType("text/plain"); Intent shareIntent = Intent.createChooser(sendIntent, null); startActivity(shareIntent);
Facoltativamente, puoi aggiungere extra per includere ulteriori informazioni, come i destinatari email (EXTRA_EMAIL, EXTRA_CC, EXTRA_BCC), l'oggetto dell'email (EXTRA_SUBJECT) e così via.
Nota: alcune app di posta elettronica, come Gmail, prevedono un String[] per gli extra come EXTRA_EMAIL e EXTRA_CC. Utilizza putExtra(String, String[]) per aggiungerli all'intent.
Inviare contenuti binari
Condividi i dati binari utilizzando l'azione ACTION_SEND.
Imposta il tipo MIME appropriato e inserisci un URI ai dati nell'extra EXTRA_STREAM, come mostrato nell'esempio seguente.
Questa operazione è di uso comune per condividere un'immagine, ma può essere utilizzata per condividere qualsiasi tipo di contenuto binario.
Kotlin
val shareIntent: Intent = Intent().apply { action = Intent.ACTION_SEND // Example: content://com.google.android.apps.photos.contentprovider/... putExtra(Intent.EXTRA_STREAM, uriToImage) type = "image/jpeg" } startActivity(Intent.createChooser(shareIntent, null))
Java
Intent shareIntent = new Intent(); shareIntent.setAction(Intent.ACTION_SEND); // Example: content://com.google.android.apps.photos.contentprovider/... shareIntent.putExtra(Intent.EXTRA_STREAM, uriToImage); shareIntent.setType("image/jpeg"); startActivity(Intent.createChooser(shareIntent, null));
L'applicazione ricevente deve disporre dell'autorizzazione per accedere ai dati a cui fa riferimento Uri. Esistono due modi consigliati per farlo:
- Archivia i dati nel tuo
ContentProvider, assicurandoti che le altre app dispongano dell'autorizzazione corretta per accedere al tuo provider. Il meccanismo preferito per fornire l'accesso è l'utilizzo delle autorizzazioni per URI, che sono temporanee e concedono l'accesso solo all'applicazione ricevente. Un modo semplice per creare unContentProviderdi questo tipo è utilizzare la classe helperFileProvider. - Utilizza
MediaStoredi sistema.MediaStoreè principalmente per i tipi MIME video, audio e immagine. Tuttavia, a partire da Android 3.0 (livello API 11), può anche archiviare tipi non multimediali. Per ulteriori informazioni, vediMediaStore.Files. I file possono essere inseriti inMediaStoreutilizzandoscanFile(), dopodiché viene passato unUriin stilecontent://adatto alla condivisione al callbackonScanCompleted()fornito. Tieni presente che una volta aggiunti aMediaStoredi sistema, i contenuti sono accessibili a qualsiasi app sul dispositivo.
Utilizzare il tipo MIME corretto
Fornisci il tipo MIME più specifico disponibile per i dati che stai inviando. Ad esempio, utilizza text/plain quando condividi testo normale. Ecco alcuni tipi MIME comuni quando invii dati semplici in Android:
| I ricevitori registrano | I mittenti inviano |
|---|---|
text/* |
|
`image/*` |
|
video/* |
|
| Estensioni di file supportate | application/pdf |
Per ulteriori informazioni sui tipi MIME, consulta il registro ufficiale IANA dei tipi di media MIME.
Android Sharesheet potrebbe mostrare un'anteprima dei contenuti, a seconda del tipo MIME fornito. Alcune funzionalità di anteprima sono disponibili solo per tipi specifici.
Condividere più contenuti
Per condividere più contenuti, utilizza l'azione ACTION_SEND_MULTIPLE insieme a un elenco di URI che rimandano ai contenuti. Il tipo MIME varia a seconda del mix di contenuti che stai condividendo. Ad esempio, se condividi tre immagini JPEG, utilizzi il tipo "image/jpg". Per un mix di tipi di immagine, utilizza "image/*" per trovare un'attività che gestisce qualsiasi tipo di immagine. Sebbene sia possibile condividere un mix di tipi, ti sconsigliamo vivamente di farlo, perché il destinatario non sa cosa deve essere inviato. Se è necessario inviare più tipi, utilizza "*/*". L'applicazione ricevente deve analizzare ed elaborare i dati. Ecco un esempio:
Kotlin
val imageUris: ArrayList<Uri> = arrayListOf( // Add your image URIs here imageUri1, imageUri2 ) val shareIntent = Intent().apply { action = Intent.ACTION_SEND_MULTIPLE putParcelableArrayListExtra(Intent.EXTRA_STREAM, imageUris) type = "image/*" } startActivity(Intent.createChooser(shareIntent, null))
Java
ArrayList<Uri> imageUris = new ArrayList<Uri>(); imageUris.add(imageUri1); // Add your image URIs here imageUris.add(imageUri2); Intent shareIntent = new Intent(); shareIntent.setAction(Intent.ACTION_SEND_MULTIPLE); shareIntent.putParcelableArrayListExtra(Intent.EXTRA_STREAM, imageUris); shareIntent.setType("image/*"); startActivity(Intent.createChooser(shareIntent, null));
Assicurati che gli oggetti Uri forniti rimandino a dati a cui un'applicazione ricevente può accedere.
Aggiungere contenuti avanzati alle anteprime di testo
A partire da Android 10 (livello API 29), Android Sharesheet mostra un'anteprima del testo condiviso. In alcuni casi, il testo condiviso può essere difficile da comprendere. Prendi in considerazione la condivisione di un URL complicato come https://www.google.com/search?ei=2rRVXcLkJajM0PEPoLy7oA4. Un'anteprima più ricca può rassicurare gli utenti su ciò che viene condiviso.
Se stai visualizzando l'anteprima del testo, puoi impostare un titolo, un'immagine miniatura o entrambi. Aggiungi una descrizione a Intent.EXTRA_TITLE prima di chiamare Intent.createChooser() e aggiungi una miniatura pertinente utilizzando ClipData.
Nota: l'URI contenuto dell'immagine viene fornito da un
FileProvider, in genere da un <cache-path>.
Per ulteriori informazioni, vedi Condividere file. Assicurati di concedere a Sharesheet le autorizzazioni corrette per leggere qualsiasi immagine che vuoi utilizzare come miniatura. Per ulteriori informazioni, vedi Intent.FLAG_GRANT_READ_URI_PERMISSION.
Ecco un esempio:
Kotlin
val share = Intent.createChooser(Intent().apply { action = Intent.ACTION_SEND putExtra(Intent.EXTRA_TEXT, "https://developer.android.com/training/sharing/") // (Optional) Here you're setting the title of the content putExtra(Intent.EXTRA_TITLE, "Introducing content previews") // (Optional) Here you're passing a content URI to an image to be displayed data = contentUri flags = Intent.FLAG_GRANT_READ_URI_PERMISSION }, null) startActivity(share)
Java
Intent sendIntent = new Intent(Intent.ACTION_SEND); sendIntent.putExtra(Intent.EXTRA_TEXT, "https://developer.android.com/training/sharing/"); // (Optional) Here you're setting the title of the content sendIntent.putExtra(Intent.EXTRA_TITLE, "Introducing content previews"); // (Optional) Here you're passing a content URI to an image to be displayed sendIntent.setData(contentUri); sendIntent.setFlags(Intent.FLAG_GRANT_READ_URI_PERMISSION); // Show the Sharesheet startActivity(Intent.createChooser(sendIntent, null));
L'anteprima ha un aspetto simile al seguente:
Aggiungere azioni personalizzate a Sharesheet
Screenshot delle azioni personalizzate su Android Sharesheet.
Su Android 14 (livello API 34) e versioni successive, le app possono aggiungere azioni personalizzate ad Android Sharesheet.
Le azioni personalizzate vengono visualizzate come piccole icone di azione nella parte superiore di Android Sharesheet e le app possono specificare qualsiasi Intent come azione richiamata quando si fa clic sull'icona.
Per aggiungere azioni personalizzate ad Android Sharesheet, crea prima un
ChooserAction
con
ChooserAction.Builder.
Puoi specificare un PendingIntent come azione richiamata quando si fa clic sull'icona. Crea
un array contenente tutte le azioni personalizzate e specificalo come
EXTRA_CHOOSER_CUSTOM_ACTIONS
dell'intent di condivisione Intent.
Kotlin
val sendIntent = Intent(Intent.ACTION_SEND) .setType("text/plain") .putExtra(Intent.EXTRA_TEXT, text) val shareIntent = Intent.createChooser(sendIntent, null) val customActions = arrayOf( ChooserAction.Builder( Icon.createWithResource(context, R.drawable.ic_custom_action), "Custom", PendingIntent.getBroadcast( context, 1, Intent(Intent.ACTION_VIEW), PendingIntent.FLAG_IMMUTABLE or PendingIntent.FLAG_CANCEL_CURRENT ) ).build() ) shareIntent.putExtra(Intent.EXTRA_CHOOSER_CUSTOM_ACTIONS, customActions) context.startActivity(shareIntent)
Java
Intent sendIntent = new Intent(Intent.ACTION_SEND) .setType("text.plain") .putExtra(Intent.EXTRA_TEXT, text); Intent shareIntent = Intent.createChooser(sendIntent, null); ChooserAction[] actions = new ChooserAction[]{ new ChooserAction.Builder( Icon.createWithResource(context, R.drawable.ic_custom_action), "Custom", PendingIntent.getBroadcast( context, 1, new Intent(Intent.ACTION_VIEW), PendingIntent.FLAG_IMMUTABLE | PendingIntent.FLAG_CANCEL_CURRENT ) ).build() }; shareIntent.putExtra(Intent.EXTRA_CHOOSER_CUSTOM_ACTIONS, actions); context.startActivity(shareIntent);
Aggiungere target personalizzati
Android Sharesheet consente di specificare fino a due ChooserTarget oggetti che
vengono visualizzati prima delle scorciatoie di condivisione e dei target del chooser caricati da ChooserTargetServices. Puoi anche specificare fino a due intent che rimandano ad attività elencate prima dei suggerimenti delle app:
Aggiungi Intent.EXTRA_CHOOSER_TARGETS e Intent.EXTRA_INITIAL_INTENTS all'intent di condivisione dopo aver chiamato Intent.createChooser():
Kotlin
val share = Intent.createChooser(myShareIntent, null).apply { putExtra(Intent.EXTRA_CHOOSER_TARGETS, myChooserTargetArray) putExtra(Intent.EXTRA_INITIAL_INTENTS, myInitialIntentArray) }
Java
Intent shareIntent = Intent.createChooser(sendIntent, null); share.putExtra(Intent.EXTRA_CHOOSER_TARGETS, myChooserTargetArray); share.putExtra(Intent.EXTRA_INITIAL_INTENTS, myInitialIntentArray);
Utilizza questa funzionalità con cautela. Ogni Intent e ChooserTarget personalizzato che aggiungi riduce il numero di suggerimenti del sistema. In genere, sconsigliamo di aggiungere target personalizzati. Un esempio comune e appropriato di aggiunta di Intent.EXTRA_INITIAL_INTENTS è fornire azioni aggiuntive che gli utenti possono intraprendere sui contenuti condivisi. Ad esempio, un utente condivide immagini e Intent.EXTRA_INITIAL_INTENTS viene utilizzato per consentirgli di inviare un link. Un esempio comune e appropriato di aggiunta di Intent.EXTRA_CHOOSER_TARGETS è mostrare persone o dispositivi pertinenti forniti dalla tua app.
Escludere target specifici per componente
Puoi escludere target specifici fornendo Intent.EXTRA_EXCLUDE_COMPONENTS.
Esegui questa operazione solo per rimuovere i target su cui hai il controllo. Un caso d'uso comune è nascondere i target di condivisione della tua app quando gli utenti condividono dall'interno dell'app, poiché il loro intento è probabilmente quello di condividere all'esterno dell'app.
Aggiungi Intent.EXTRA_EXCLUDE_COMPONENTS all'intent dopo aver chiamato Intent.createChooser():
Kotlin
val share = Intent.createChooser(Intent(), null).apply { // Only use for components you have control over val excludedComponentNames = arrayOf(ComponentName("com.example.android", "ExampleClass")) putExtra(Intent.EXTRA_EXCLUDE_COMPONENTS, excludedComponentNames) }
Java
Intent shareIntent = Intent.createChooser(new Intent(), null); // Only use for components you have control over ComponentName[] excludedComponentNames = { new ComponentName("com.example.android", "ExampleClass") }; shareIntent.putExtra(Intent.EXTRA_EXCLUDE_COMPONENTS, excludedComponentNames);
Ottenere informazioni sulla condivisione
Può essere utile sapere quando gli utenti condividono e quale target selezionano. Android Sharesheet consente di ottenere queste informazioni fornendo il ComponentName dei target selezionati dagli utenti utilizzando un IntentSender.
Innanzitutto, crea un PendingIntent per un BroadcastReceiver e fornisci il relativo IntentSender in Intent.createChooser():
Kotlin
var share = Intent(Intent.ACTION_SEND) // ... val pi = PendingIntent.getBroadcast( myContext, requestCode, Intent(myContext, MyBroadcastReceiver::class.java), PendingIntent.FLAG_MUTABLE or PendingIntent.FLAG_UPDATE_CURRENT ) share = Intent.createChooser(share, null, pi.intentSender)
Java
Intent share = new Intent(ACTION_SEND); ... PendingIntent pi = PendingIntent.getBroadcast(myContext, requestCode, new Intent(myContext, MyBroadcastReceiver.class), PendingIntent.FLAG_MUTABLE | PendingIntent.FLAG_UPDATE_CURRENT); share = Intent.createChooser(share, null, pi.getIntentSender());
Ricevi il callback in MyBroadcastReceiver e cerca in Intent.EXTRA_CHOOSER_RESULT:
Kotlin
override fun onReceive(context: Context, intent: Intent) { ... val chooserResult: ChooserResult? = IntentCompat.getParcelableExtra( intent, Intent.EXTRA_CHOOSER_RESULT, ChooserResult::class.java, ) chooserResult?.let { Log.i( TAG, "Share callback: isShortcut: ${it.isShortcut}, type: ${typeToString(it.type)}, componentName: ${it.selectedComponent}", ) } ?: Log.i(TAG, "chooserResult is null") }
Java
@Override public void onReceive(Context context, Intent intent) { ... ChooserResult chooserResult = intent.getParcelableExtra(EXTRA_CHOOSER_RESULT); Log.i( TAG, "Share callback: isShortcut: " + chooserResult.isShortcut() + ", type: " + chooserResult.getType() + ", componentName: " + chooserResult.getSelectedComponent() ); }
Aggiungere azioni personalizzate a Sharesheet
Su Android 14 (livello API 34) e versioni successive, le app possono aggiungere azioni personalizzate ad Android Sharesheet.
Crea un ChooserAction
con
ChooserAction.Builder.
Puoi specificare un PendingIntent come azione richiamata quando si fa clic sull'icona. Crea
un array contenente tutte le azioni personalizzate e specificalo come
EXTRA_CHOOSER_CUSTOM_ACTIONS
dell'intent di condivisione Intent.
Kotlin
val sendIntent = Intent(Intent.ACTION_SEND) .setType("text/plain") .putExtra(Intent.EXTRA_TEXT, text) val shareIntent = Intent.createChooser(sendIntent, null) val customActions = arrayOf( ChooserAction.Builder( Icon.createWithResource(context, R.drawable.ic_custom_action), "Custom", PendingIntent.getBroadcast( context, 1, Intent(Intent.ACTION_VIEW), PendingIntent.FLAG_IMMUTABLE or PendingIntent.FLAG_CANCEL_CURRENT ) ).build() ) shareIntent.putExtra(Intent.EXTRA_CHOOSER_CUSTOM_ACTIONS, customActions) context.startActivity(shareIntent)
Java
Intent sendIntent = new Intent(Intent.ACTION_SEND) .setType("text.plain") .putExtra(Intent.EXTRA_TEXT, text); Intent shareIntent = Intent.createChooser(sendIntent, null); ChooserAction[] actions = new ChooserAction[]{ new ChooserAction.Builder( Icon.createWithResource(context, R.drawable.ic_custom_action), "Custom", PendingIntent.getBroadcast( context, 1, new Intent(Intent.ACTION_VIEW), PendingIntent.FLAG_IMMUTABLE | PendingIntent.FLAG_CANCEL_CURRENT ) ).build() }; shareIntent.putExtra(Intent.EXTRA_CHOOSER_CUSTOM_ACTIONS, actions); context.startActivity(shareIntent);
Utilizzare il resolver di intent di Android
Screenshot del resolver di intent ACTION_SEND.
Il resolver di intent di Android è più adatto per l'invio di dati a un'altra app nell'ambito di un flusso di attività ben definito.
Per utilizzare il resolver di intent di Android, crea un intent e aggiungi gli extra come faresti per chiamare Android Sharesheet. Tuttavia, non chiamare
Intent.createChooser().
Se sono presenti più applicazioni installate con filtri che corrispondono a ACTION_SEND e al tipo MIME, il sistema visualizza una finestra di dialogo di disambiguazione chiamata resolver di intent che consente all'utente di scegliere un target di condivisione. Se corrisponde una singola applicazione, questa viene eseguita.
Ecco un esempio di come utilizzare il resolver di intent di Android per inviare testo:
Kotlin
val sendIntent: Intent = Intent().apply { action = Intent.ACTION_SEND putExtra(Intent.EXTRA_TEXT, "This is my text to send.") type = "text/plain" } startActivity(sendIntent)
Java
Intent sendIntent = new Intent(); sendIntent.setAction(Intent.ACTION_SEND); sendIntent.putExtra(Intent.EXTRA_TEXT, "This is my text to send."); sendIntent.setType("text/plain"); startActivity(sendIntent);
Scopri di più
Per ulteriori informazioni sull'invio di dati, vedi Intent e filtri di intent.