Un intent te permite iniciar una actividad en otra app mediante la descripción de un
acción que deseas realizar, como "ver un mapa" o "toma una
foto" en un objeto Intent
. Este tipo de intent
se denomina intent implícito porque no especifica la app
componente para comenzar, pero especifica una acción y proporciona
algunos datos con los que se realizará la acción.
Cuando llames a startActivity()
o startActivityForResult()
y le pasas un intent implícito, el sistema
resuelve
el intent a una app que pueda controlarlo e iniciar su
Activity
correspondiente. Si hay más de una app
que pueda manejar el intent, el sistema presenta al usuario un diálogo para
elige qué app usar.
En esta página, se describen varios intents implícitos que puedes usar para realizar acciones comunes, organizadas por el tipo de app que controla el intent Cada También te muestra cómo puedes crear un intento filtro para anunciar la capacidad de tu app de realizar la acción.
Precaución: Si no hay apps en el dispositivo que puedan
recibes un intent implícito, una app falla cuando llama a startActivity()
. Para verificar primero que
existe una app para recibir el intent, llama a resolveActivity()
en tu objeto Intent
. Si el resultado no es nulo, hay al menos
una app que pueda controlar el intent y es seguro llamar a startActivity()
. Si el resultado es
null, no uses el intent y, si es posible, inhabilita el
función que invoca el intent.
Si no sabes cómo crear intents o filtros de intents, primero consulta Intents y filtros de intents Filtros.
Para aprender a activar los intents enumerados en esta página del desarrollo consulta el vínculo Verifica intents con la app de puente.
Google Voice Actions
Google Voice Actions activa algunos de los intents enumerados en esta página en respuesta a comandos por voz. Para obtener más información, consulta Comienza a usar las Acciones de voz del sistema
Despertador
Las siguientes son acciones comunes para las apps de alarma, incluida la información que necesitas para crear un filtro de intents y así anunciar la capacidad de tu app de realizar cada acción.
Crear una alarma
Para crear una alarma nueva, usa la ACTION_SET_ALARM
acción y especifica detalles de la alarma, como la hora y el mensaje con los siguientes extras.
Nota: Solo están disponibles la hora, los minutos y los mensajes adicionales. en Android 2.3 (nivel de API 9) y versiones anteriores. Los demás extras están disponibles en versiones superiores del plataforma.
- Acción
ACTION_SET_ALARM
- URI de datos
- Ninguno
- Tipo de MIME
- Ninguno
- Adicional
-
EXTRA_HOUR
- Es la hora de la alarma.
EXTRA_MINUTES
- Son los minutos de la alarma.
EXTRA_MESSAGE
- Un mensaje personalizado para identificar la alarma
EXTRA_DAYS
- Un
ArrayList
que incluye cada día de la semana en el que esta alarma se repita. Cada día se debe declarar con un número entero deCalendar
comoMONDAY
.Para una alarma única, no especifiques este extra.
EXTRA_RINGTONE
- Un URI de
content:
que especifica un tono para usar con la alarma, oVALUE_RINGTONE_SILENT
para ningún tono.Para usar el tono predeterminado, no especifiques este extra.
EXTRA_VIBRATE
- Valor booleano que especifica si se debe vibrar para esta alarma.
EXTRA_SKIP_UI
- Valor booleano que especifica si la app que responde debe omitir su IU al establecer la alarma. Si es verdadero, la app debe omitir cualquier IU de confirmación y establecer la alarma especificada.
Intent de ejemplo:
Kotlin
fun createAlarm(message: String, hour: Int, minutes: Int) { val intent = Intent(AlarmClock.ACTION_SET_ALARM).apply { putExtra(AlarmClock.EXTRA_MESSAGE, message) putExtra(AlarmClock.EXTRA_HOUR, hour) putExtra(AlarmClock.EXTRA_MINUTES, minutes) } if (intent.resolveActivity(packageManager) != null) { startActivity(intent) } }
Java
public void createAlarm(String message, int hour, int minutes) { Intent intent = new Intent(AlarmClock.ACTION_SET_ALARM) .putExtra(AlarmClock.EXTRA_MESSAGE, message) .putExtra(AlarmClock.EXTRA_HOUR, hour) .putExtra(AlarmClock.EXTRA_MINUTES, minutes); if (intent.resolveActivity(getPackageManager()) != null) { startActivity(intent); } }
Para invocar el intent ACTION_SET_ALARM
, tu app debe tener el elemento
Permiso SET_ALARM
:
<uses-permission android:name="com.android.alarm.permission.SET_ALARM" />
Ejemplo de filtro de intents:
<activity ...> <intent-filter> <action android:name="android.intent.action.SET_ALARM" /> <category android:name="android.intent.category.DEFAULT" /> </intent-filter> </activity>
Crear un temporizador
Para crear un temporizador de cuenta regresiva, usa la acción ACTION_SET_TIMER
y especifica el temporizador
como la duración con los siguientes extras.
Nota: Este intent está disponible en Android 4.4 (nivel de API 19) y versiones posteriores.
- Acción
ACTION_SET_TIMER
- URI de datos
- Ninguno
- Tipo de MIME
- Ninguno
- Adicional
-
EXTRA_LENGTH
- La duración del temporizador en segundos.
EXTRA_MESSAGE
- Un mensaje personalizado para identificar el temporizador.
EXTRA_SKIP_UI
- Valor booleano que especifica si la app que responde debe omitir su IU cuando se configura el temporizador. Si es verdadero, la app debe omitir cualquier IU de confirmación e iniciar el temporizador especificado.
Intent de ejemplo:
Kotlin
fun startTimer(message: String, seconds: Int) { val intent = Intent(AlarmClock.ACTION_SET_TIMER).apply { putExtra(AlarmClock.EXTRA_MESSAGE, message) putExtra(AlarmClock.EXTRA_LENGTH, seconds) putExtra(AlarmClock.EXTRA_SKIP_UI, true) } if (intent.resolveActivity(packageManager) != null) { startActivity(intent) } }
Java
public void startTimer(String message, int seconds) { Intent intent = new Intent(AlarmClock.ACTION_SET_TIMER) .putExtra(AlarmClock.EXTRA_MESSAGE, message) .putExtra(AlarmClock.EXTRA_LENGTH, seconds) .putExtra(AlarmClock.EXTRA_SKIP_UI, true); if (intent.resolveActivity(getPackageManager()) != null) { startActivity(intent); } }
Para invocar el intent ACTION_SET_TIMER
, tu app debe tener el elemento
Permiso SET_ALARM
:
<uses-permission android:name="com.android.alarm.permission.SET_ALARM" />
Ejemplo de filtro de intents:
<activity ...> <intent-filter> <action android:name="android.intent.action.SET_TIMER" /> <category android:name="android.intent.category.DEFAULT" /> </intent-filter> </activity>
Mostrar todas las alarmas
Para mostrar la lista de alarmas, usa el ACTION_SHOW_ALARMS
acción.
Aunque no muchas apps invocan este intent, ya que lo usan principalmente las apps del sistema, cualquier app que se comporte como despertador puede implementar este filtro de intents y responder mostrando la lista de alarmas actuales.
Nota: Este intent está disponible en Android 4.4 (nivel de API 19) y versiones posteriores.
- Acción
ACTION_SHOW_ALARMS
- URI de datos
- Ninguno
- Tipo de MIME
- Ninguno
Ejemplo de filtro de intents:
<activity ...> <intent-filter> <action android:name="android.intent.action.SHOW_ALARMS" /> <category android:name="android.intent.category.DEFAULT" /> </intent-filter> </activity>
Calendario
Agregar un evento es una acción común de las apps de calendario. Crea un filtro de intents para anunciar la capacidad de tu app para realizar esta acción usando el información en la siguiente sección.
Agregar un evento de calendario
Para agregar un nuevo evento al calendario del usuario, usa el
ACTION_INSERT
y especifica el URI de datos usando
Events.CONTENT_URI
Luego, puedes especificar varios detalles del evento con los siguientes extras.
- Acción
ACTION_INSERT
- URI de datos
Events.CONTENT_URI
- Tipo de MIME
"vnd.android.cursor.dir/event"
- Adicional
-
EXTRA_EVENT_ALL_DAY
- Valor booleano que especifica si el evento dura todo el día.
EXTRA_EVENT_BEGIN_TIME
- Es la hora de inicio del evento (milisegundos desde el ciclo de entrenamiento).
EXTRA_EVENT_END_TIME
- Es la hora de finalización del evento (milisegundos desde el ciclo de entrenamiento).
TITLE
- Título del evento.
DESCRIPTION
- La descripción del evento.
EVENT_LOCATION
- Es la ubicación del evento.
EXTRA_EMAIL
- Una lista de direcciones de correo electrónico separadas por comas en la que se especifican los invitados.
Se pueden especificar muchos más detalles del evento con las constantes definidas en la Clase
CalendarContract.EventsColumns
.
Intent de ejemplo:
Kotlin
fun addEvent(title: String, location: String, begin: Long, end: Long) { val intent = Intent(Intent.ACTION_INSERT).apply { data = Events.CONTENT_URI putExtra(Events.TITLE, title) putExtra(Events.EVENT_LOCATION, location) putExtra(CalendarContract.EXTRA_EVENT_BEGIN_TIME, begin) putExtra(CalendarContract.EXTRA_EVENT_END_TIME, end) } if (intent.resolveActivity(packageManager) != null) { startActivity(intent) } }
Java
public void addEvent(String title, String location, long begin, long end) { Intent intent = new Intent(Intent.ACTION_INSERT) .setData(Events.CONTENT_URI) .putExtra(Events.TITLE, title) .putExtra(Events.EVENT_LOCATION, location) .putExtra(CalendarContract.EXTRA_EVENT_BEGIN_TIME, begin) .putExtra(CalendarContract.EXTRA_EVENT_END_TIME, end); if (intent.resolveActivity(getPackageManager()) != null) { startActivity(intent); } }
Ejemplo de filtro de intents:
<activity ...> <intent-filter> <action android:name="android.intent.action.INSERT" /> <data android:mimeType="vnd.android.cursor.dir/event" /> <category android:name="android.intent.category.DEFAULT" /> </intent-filter> </activity>
Cámara
Las siguientes son acciones comunes para las apps de cámara, incluida la información que necesitas para crear un filtro de intents y así anunciar la capacidad de tu app de realizar cada acción.
Capturar y mostrar una imagen o video
Para abrir una app de cámara y recibir la foto o el video resultante, usa la acción ACTION_IMAGE_CAPTURE
o ACTION_VIDEO_CAPTURE
. También especifica la ubicación del URI en la que
como la cámara para guardar la foto o el video, en la EXTRA_OUTPUT
adicionales.
- Acción
ACTION_IMAGE_CAPTURE
o
ACTION_VIDEO_CAPTURE
- Esquema de URI de datos
- Ninguno
- Tipo de MIME
- Ninguno
- Adicional
-
EXTRA_OUTPUT
- La ubicación del URI en la que la app de cámara guarda la foto o
como un archivo de video (como un objeto
Uri
).
Cuando la app de cámara devuelve resultados correctamente
enfocarte en tu actividad; en otras palabras, tu app recibe la devolución de llamada onActivityResult()
,
puede acceder a la foto o al video en el URI que especificaste
con el valor EXTRA_OUTPUT
.
Nota: Cuando usas ACTION_IMAGE_CAPTURE
para tomar una foto, la cámara también puede mostrar
copia reducida, o miniatura, de la foto en el resultado Intent
, guardada como Bitmap
en un campo adicional llamado
"data"
Intent de ejemplo:
Kotlin
const val REQUEST_IMAGE_CAPTURE = 1 val locationForPhotos: Uri = ... fun capturePhoto(targetFilename: String) { val intent = Intent(MediaStore.ACTION_IMAGE_CAPTURE).apply { putExtra(MediaStore.EXTRA_OUTPUT, Uri.withAppendedPath(locationForPhotos, targetFilename)) } if (intent.resolveActivity(packageManager) != null) { startActivityForResult(intent, REQUEST_IMAGE_CAPTURE) } } override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent) { if (requestCode == REQUEST_IMAGE_CAPTURE && resultCode == Activity.RESULT_OK) { val thumbnail: Bitmap = data.getParcelableExtra("data") // Do other work with full size photo saved in locationForPhotos. ... } }
Java
static final int REQUEST_IMAGE_CAPTURE = 1; static final Uri locationForPhotos; public void capturePhoto(String targetFilename) { Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE); intent.putExtra(MediaStore.EXTRA_OUTPUT, Uri.withAppendedPath(locationForPhotos, targetFilename)); if (intent.resolveActivity(getPackageManager()) != null) { startActivityForResult(intent, REQUEST_IMAGE_CAPTURE); } } @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { if (requestCode == REQUEST_IMAGE_CAPTURE && resultCode == RESULT_OK) { Bitmap thumbnail = data.getParcelableExtra("data"); // Do other work with full size photo saved in locationForPhotos. ... } }
Para hacer esto cuando trabajas en Android 12 (nivel de API 31) o versiones posteriores, consulta el siguiente ejemplo de intents.
Intent de ejemplo:
Kotlin
val REQUEST_IMAGE_CAPTURE = 1 private fun dispatchTakePictureIntent() { val takePictureIntent = Intent(MediaStore.ACTION_IMAGE_CAPTURE) try { startActivityForResult(takePictureIntent, REQUEST_IMAGE_CAPTURE) } catch (e: ActivityNotFoundException) { // Display error state to the user. } }
Java
static final int REQUEST_IMAGE_CAPTURE = 1; private void dispatchTakePictureIntent() { Intent takePictureIntent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE); try { startActivityForResult(takePictureIntent, REQUEST_IMAGE_CAPTURE); } catch (ActivityNotFoundException e) { // Display error state to the user. } } </section></div>
Para obtener más información sobre cómo usar este intent para capturar una foto,
cómo crear un Uri
apropiado para la ubicación de salida, lee
Toma fotos o
Graba videos.
Ejemplo de filtro de intents:
<activity ...> <intent-filter> <action android:name="android.media.action.IMAGE_CAPTURE" /> <category android:name="android.intent.category.DEFAULT" /> </intent-filter> </activity>
Cuando manejes este intent, haz que tu actividad verifique el EXTRA_OUTPUT
adicional en el Intent
entrante y, luego, guarde la imagen o el video capturados en el
ubicación especificada por ese extra y llama a setResult()
con un Intent
que incluya una miniatura comprimida en una extra
con el nombre "data"
.
Iniciar una aplicación de cámara en modo de imagen detenida
Para abrir una app de cámara en modo de imagen detenida, usa la acción INTENT_ACTION_STILL_IMAGE_CAMERA
.
- Acción
INTENT_ACTION_STILL_IMAGE_CAMERA
- Esquema de URI de datos
- Ninguno
- Tipo de MIME
- Ninguno
- Adicional
- Ninguno
Intent de ejemplo:
Kotlin
private fun dispatchTakePictureIntent() { val takePictureIntent = Intent(MediaStore.ACTION_IMAGE_CAPTURE) try { startActivityForResult(takePictureIntent, REQUEST_IMAGE_CAPTURE) } catch (e: ActivityNotFoundException) { // Display error state to the user. } }
Java
public void capturePhoto(String targetFilename) { Intent intent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE); intent.putExtra(MediaStore.EXTRA_OUTPUT, Uri.withAppendedPath(locationForPhotos, targetFilename)); if (intent.resolveActivity(getPackageManager()) != null) { startActivityForResult(intent, REQUEST_IMAGE_CAPTURE); } }
Ejemplo de filtro de intents:
<activity ...> <intent-filter> <action android:name="android.media.action.STILL_IMAGE_CAMERA" /> <category android:name="android.intent.category.DEFAULT" /> </intent-filter> </activity>
Iniciar una aplicación de cámara en modo de video
Para abrir una app de cámara en modo de video, usa la acción INTENT_ACTION_VIDEO_CAMERA
.
- Acción
INTENT_ACTION_VIDEO_CAMERA
- Esquema de URI de datos
- Ninguno
- Tipo de MIME
- Ninguno
- Adicional
- Ninguno
Intent de ejemplo:
Kotlin
fun capturePhoto() { val intent = Intent(MediaStore.INTENT_ACTION_VIDEO_CAMERA) if (intent.resolveActivity(packageManager) != null) { startActivityForResult(intent, REQUEST_IMAGE_CAPTURE) } }
Java
public void capturePhoto() { Intent intent = new Intent(MediaStore.INTENT_ACTION_VIDEO_CAMERA); if (intent.resolveActivity(getPackageManager()) != null) { startActivityForResult(intent, REQUEST_IMAGE_CAPTURE); } }
Ejemplo de filtro de intents:
<activity ...> <intent-filter> <action android:name="android.media.action.VIDEO_CAMERA" /> <category android:name="android.intent.category.DEFAULT" /> </intent-filter> </activity>
App de contactos/personas
Las siguientes son acciones comunes para las apps de administración de contactos, incluida la información que necesitas para crear un filtro de intents y así anunciar la capacidad de tu app de realizar cada acción.
Elige un contacto
Para que el usuario seleccione un contacto y le brinde a tu app acceso a toda la información de contacto, haz lo siguiente:
usar la acción ACTION_PICK
y especificar el tipo de MIME
Contacts.CONTENT_TYPE
El Intent
resultante entregado a tu devolución de llamada onActivityResult()
contiene la
La URI de content:
que apunta al contacto seleccionado. La respuesta otorga
los permisos temporales de tu app para leer ese contacto mediante la API de Contacts Provider, aun cuando
Tu app no incluye el permiso READ_CONTACTS
.
Nota: Si solo necesitas acceder a un contacto específico información, como un número de teléfono o una dirección de correo electrónico, consulta la siguiente sección sobre cómo Seleccionar datos de un contacto específico.
- Acción
ACTION_PICK
- Esquema de URI de datos
- Ninguno
- Tipo de MIME
Contacts.CONTENT_TYPE
Intent de ejemplo:
Kotlin
const val REQUEST_SELECT_CONTACT = 1 fun selectContact() { val intent = Intent(Intent.ACTION_PICK).apply { type = ContactsContract.Contacts.CONTENT_TYPE } if (intent.resolveActivity(packageManager) != null) { startActivityForResult(intent, REQUEST_SELECT_CONTACT) } } override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent) { if (requestCode == REQUEST_SELECT_CONTACT && resultCode == RESULT_OK) { val contactUri: Uri = data.data // Do something with the selected contact at contactUri. //... } }
Java
static final int REQUEST_SELECT_CONTACT = 1; public void selectContact() { Intent intent = new Intent(Intent.ACTION_PICK); intent.setType(ContactsContract.Contacts.CONTENT_TYPE); if (intent.resolveActivity(getPackageManager()) != null) { startActivityForResult(intent, REQUEST_SELECT_CONTACT); } } @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { if (requestCode == REQUEST_SELECT_CONTACT && resultCode == RESULT_OK) { Uri contactUri = data.getData(); // Do something with the selected contact at contactUri. ... } }
Para obtener información sobre cómo recuperar los detalles de contacto una vez que tienes el URI de contacto, lee Recuperar detalles de un contacto.
Por lo general, cuando recuperas el URI del contacto con este intent, no
necesito que
READ_CONTACTS
permiso para leer detalles básicos de ese contacto, como el nombre visible y
si el contacto está destacado. Sin embargo, si quieres
leer datos más específicos sobre un contacto determinado, como
como su número de teléfono o dirección de correo electrónico, necesitas el READ_CONTACTS
permiso.
Seleccionar datos de un contacto específico
Para que el usuario seleccione un dato específico de un contacto, como
un número de teléfono, una dirección de correo electrónico u otro tipo de datos, utiliza el
ACTION_PICK
y especifica el tipo de MIME en uno
de los siguientes tipos de contenido, como
CommonDataKinds.Phone.CONTENT_TYPE
para obtener el número de teléfono del contacto.
Nota: En muchos casos, tu app debe tener la
READ_CONTACTS
permiso para ver información específica sobre un contacto en particular.
Si necesitas recuperar un solo tipo de datos de un contacto, esta técnica con un
CONTENT_TYPE
desde
Las clases ContactsContract.CommonDataKinds
son más eficientes que
con Contacts.CONTENT_TYPE
, como se muestra en la sección anterior. El resultado te proporciona
acceder a los datos deseados sin que debas realizar una consulta más compleja al Proveedor de contactos.
El Intent
resultante entregado a tu devolución de llamada onActivityResult()
contiene la
Es el URI de content:
que apunta a los datos del contacto seleccionado. La respuesta otorga
los permisos temporales de tu app para leer esos datos de contacto, incluso si no incluye el permiso READ_CONTACTS
- Acción
ACTION_PICK
- Esquema de URI de datos
- Ninguno
- Tipo de MIME
-
CommonDataKinds.Phone.CONTENT_TYPE
- Elige entre los contactos que tienen un número de teléfono.
CommonDataKinds.Email.CONTENT_TYPE
- Elige entre los contactos que tienen una dirección de correo electrónico.
CommonDataKinds.StructuredPostal.CONTENT_TYPE
- Elige entre los contactos con una dirección postal.
O uno de los otros valores
CONTENT_TYPE
por debajo deContactsContract
.
Intent de ejemplo:
Kotlin
const val REQUEST_SELECT_PHONE_NUMBER = 1 fun selectContact() { // Start an activity for the user to pick a phone number from contacts. val intent = Intent(Intent.ACTION_PICK).apply { type = CommonDataKinds.Phone.CONTENT_TYPE } if (intent.resolveActivity(packageManager) != null) { startActivityForResult(intent, REQUEST_SELECT_PHONE_NUMBER) } } override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent) { if (requestCode == REQUEST_SELECT_PHONE_NUMBER && resultCode == Activity.RESULT_OK) { // Get the URI and query the content provider for the phone number. val contactUri: Uri = data.data val projection: Array<String> = arrayOf(CommonDataKinds.Phone.NUMBER) contentResolver.query(contactUri, projection, null, null, null).use { cursor -> // If the cursor returned is valid, get the phone number. if (cursor.moveToFirst()) { val numberIndex = cursor.getColumnIndex(CommonDataKinds.Phone.NUMBER) val number = cursor.getString(numberIndex) // Do something with the phone number. ... } } } }
Java
static final int REQUEST_SELECT_PHONE_NUMBER = 1; public void selectContact() { // Start an activity for the user to pick a phone number from contacts. Intent intent = new Intent(Intent.ACTION_PICK); intent.setType(CommonDataKinds.Phone.CONTENT_TYPE); if (intent.resolveActivity(getPackageManager()) != null) { startActivityForResult(intent, REQUEST_SELECT_PHONE_NUMBER); } } @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { if (requestCode == REQUEST_SELECT_PHONE_NUMBER && resultCode == RESULT_OK) { // Get the URI and query the content provider for the phone number. Uri contactUri = data.getData(); String[] projection = new String[]{CommonDataKinds.Phone.NUMBER}; Cursor cursor = getContentResolver().query(contactUri, projection, null, null, null); // If the cursor returned is valid, get the phone number. if (cursor != null && cursor.moveToFirst()) { int numberIndex = cursor.getColumnIndex(CommonDataKinds.Phone.NUMBER); String number = cursor.getString(numberIndex); // Do something with the phone number. //... } } }
Ver un contacto
Para mostrar los detalles de un contacto conocido, usa el ACTION_VIEW
y especifica el contacto con un URI content:
como datos del intent.
Existen dos formas principales de recuperar inicialmente el URI del contacto:
- Usa el URI del contacto que muestra la acción
ACTION_PICK
. como se muestra en la sección anterior. Este enfoque no requiere ningún permiso de la app. - Acceder a la lista de todos los contactos directamente, como se describe en Cómo obtener una lista de
Contactos. Este enfoque requiere el
READ_CONTACTS
permiso.
- Acción
ACTION_VIEW
- Esquema de URI de datos
content:<URI>
- Tipo de MIME
- Ninguno El tipo se infiere del URI de contacto.
Intent de ejemplo:
Kotlin
fun viewContact(contactUri: Uri) { val intent = Intent(Intent.ACTION_VIEW, contactUri) if (intent.resolveActivity(packageManager) != null) { startActivity(intent) } }
Java
public void viewContact(Uri contactUri) { Intent intent = new Intent(Intent.ACTION_VIEW, contactUri); if (intent.resolveActivity(getPackageManager()) != null) { startActivity(intent); } }
Editar un contacto existente
Para editar un contacto conocido, usa el ACTION_EDIT
acción, especifica el contacto con un URI content:
como los datos de la intent e incluir cualquier información de contacto conocida en los campos extras especificados por
constantes en ContactsContract.Intents.Insert
.
Existen dos formas principales de recuperar inicialmente el URI de contacto:
- Usa el URI del contacto que muestra la acción
ACTION_PICK
. como se muestra en la sección anterior. Este enfoque no requiere ningún permiso de la app. - Acceder a la lista de todos los contactos directamente, como se describe en Cómo obtener una lista de
Contactos. Este enfoque requiere el
READ_CONTACTS
permiso.
- Acción
ACTION_EDIT
- Esquema de URI de datos
content:<URI>
- Tipo de MIME
- El tipo se infiere del URI de contacto.
- Adicional
- Uno o más de los extras definidos en
ContactsContract.Intents.Insert
para que puedas completar los campos de los detalles de contacto.
Intent de ejemplo:
Kotlin
fun editContact(contactUri: Uri, email: String) { val intent = Intent(Intent.ACTION_EDIT).apply { data = contactUri putExtra(ContactsContract.Intents.Insert.EMAIL, email) } if (intent.resolveActivity(packageManager) != null) { startActivity(intent) } }
Java
public void editContact(Uri contactUri, String email) { Intent intent = new Intent(Intent.ACTION_EDIT); intent.setData(contactUri); intent.putExtra(Intents.Insert.EMAIL, email); if (intent.resolveActivity(getPackageManager()) != null) { startActivity(intent); } }
Para obtener más información sobre cómo editar un contacto, lee Modificar contactos con intents.
Insertar un contacto
Para insertar un contacto nuevo, usa la acción ACTION_INSERT
.
especificar Contacts.CONTENT_TYPE
como
el tipo de MIME e incluir cualquier información de contacto conocida en los campos extras especificados por
constantes en ContactsContract.Intents.Insert
.
- Acción
ACTION_INSERT
- Esquema de URI de datos
- Ninguno
- Tipo de MIME
Contacts.CONTENT_TYPE
- Adicional
- Uno o más de los extras definidos en
ContactsContract.Intents.Insert
.
Intent de ejemplo:
Kotlin
fun insertContact(name: String, email: String) { val intent = Intent(Intent.ACTION_INSERT).apply { type = ContactsContract.Contacts.CONTENT_TYPE putExtra(ContactsContract.Intents.Insert.NAME, name) putExtra(ContactsContract.Intents.Insert.EMAIL, email) } if (intent.resolveActivity(packageManager) != null) { startActivity(intent) } }
Java
public void insertContact(String name, String email) { Intent intent = new Intent(Intent.ACTION_INSERT); intent.setType(Contacts.CONTENT_TYPE); intent.putExtra(Intents.Insert.NAME, name); intent.putExtra(Intents.Insert.EMAIL, email); if (intent.resolveActivity(getPackageManager()) != null) { startActivity(intent); } }
Para obtener más información sobre cómo insertar un contacto, consulta Modificar contactos con intents.
Correo electrónico
Redactar un correo electrónico con archivos adjuntos opcionales es una acción común para las apps de correo electrónico. Crea un filtro de intents para anunciar la capacidad de tu app para realizar esta acción usando el información en la siguiente sección.
Redactar un correo electrónico con archivos adjuntos opcionales
Para redactar un correo electrónico, usa una de las siguientes acciones en función de si incluirás archivos adjuntos o no: e incluye detalles del correo electrónico, como el destinatario y el asunto, con las claves adicionales indicadas.
- Acción
ACTION_SENDTO
(sin archivos adjuntos) o
ACTION_SEND
(para un archivo adjunto) o
ACTION_SEND_MULTIPLE
(para varios archivos adjuntos)- Esquema de URI de datos
- Ninguno
- Tipo de MIME
-
"text/plain"
"*/*"
- Adicional
-
Intent.EXTRA_EMAIL
- Un array de cadenas de todos los valores “To” direcciones de correo electrónico de los destinatarios.
Intent.EXTRA_CC
- Un array de cadenas de todos los caracteres “CC” direcciones de correo electrónico de los destinatarios.
Intent.EXTRA_BCC
- Un array de cadenas de todo el campo “Cco” direcciones de correo electrónico de los destinatarios.
Intent.EXTRA_SUBJECT
- Una cadena con el asunto del correo electrónico.
Intent.EXTRA_TEXT
- Es una cadena con el cuerpo del correo electrónico.
Intent.EXTRA_STREAM
- Es un
Uri
que apunta al archivo adjunto. Si se utilizaACTION_SEND_MULTIPLE
acción, esta es en cambio unArrayList
con contenido varios objetosUri
Intent de ejemplo:
Kotlin
fun composeEmail(addresses: Array<String>, subject: String, attachment: Uri) { val intent = Intent(Intent.ACTION_SEND).apply { type = "*/*" putExtra(Intent.EXTRA_EMAIL, addresses) putExtra(Intent.EXTRA_SUBJECT, subject) putExtra(Intent.EXTRA_STREAM, attachment) } if (intent.resolveActivity(packageManager) != null) { startActivity(intent) } }
Java
public void composeEmail(String[] addresses, String subject, Uri attachment) { Intent intent = new Intent(Intent.ACTION_SEND); intent.setType("*/*"); intent.putExtra(Intent.EXTRA_EMAIL, addresses); intent.putExtra(Intent.EXTRA_SUBJECT, subject); intent.putExtra(Intent.EXTRA_STREAM, attachment); if (intent.resolveActivity(getPackageManager()) != null) { startActivity(intent); } }
Si quieres asegurarte de que solo una app de correo electrónico y no una
mensajes de texto o una app social y, luego, usa la acción ACTION_SENDTO
e incluye el esquema de datos "mailto:"
, como se muestra en el siguiente ejemplo:
Kotlin
fun composeEmail(addresses: Array<String>, subject: String) { val intent = Intent(Intent.ACTION_SENDTO).apply { data = Uri.parse("mailto:") // Only email apps handle this. putExtra(Intent.EXTRA_EMAIL, addresses) putExtra(Intent.EXTRA_SUBJECT, subject) } if (intent.resolveActivity(packageManager) != null) { startActivity(intent) } }
Java
public void composeEmail(String[] addresses, String subject) { Intent intent = new Intent(Intent.ACTION_SENDTO); intent.setData(Uri.parse("mailto:")); // Only email apps handle this. intent.putExtra(Intent.EXTRA_EMAIL, addresses); intent.putExtra(Intent.EXTRA_SUBJECT, subject); if (intent.resolveActivity(getPackageManager()) != null) { startActivity(intent); } }
Ejemplo de filtro de intents:
<activity ...> <intent-filter> <action android:name="android.intent.action.SEND" /> <data android:type="*/*" /> <category android:name="android.intent.category.DEFAULT" /> </intent-filter> <intent-filter> <action android:name="android.intent.action.SENDTO" /> <data android:scheme="mailto" /> <category android:name="android.intent.category.DEFAULT" /> </intent-filter> </activity>
Almacenamiento de archivos
Las siguientes son acciones comunes para las apps de almacenamiento de archivos, incluida la información que necesitas para crear un filtro de intents y así anunciar la capacidad de tu app de realizar cada acción.
Recuperar un tipo específico de archivo
Para solicitar que el usuario seleccione un archivo, como un documento o una foto, y devuelva una referencia a
para tu app, usa la acción ACTION_GET_CONTENT
y especifica la
Es el tipo de MIME. La referencia del archivo que se muestra en tu app es transitoria al valor actual de tu actividad
del ciclo de vida. Si quieres acceder a él más tarde, debes importar una copia que podrás leer más tarde.
Este intent también le permite al usuario crear un archivo nuevo en el proceso. Para Por ejemplo, en lugar de seleccionar una foto existente, el usuario puede capturar una foto nueva con la cámara.
El intent del resultado entregado a tu método onActivityResult()
incluye datos con un URI que apunta al archivo.
El URI puede ser cualquier cosa, como un URI http:
, file:
o content:
.
URI Sin embargo, si quieres restringir los archivos seleccionables a solo aquellos a los que se puede acceder
de un proveedor de contenido (un URI content:
) y que están disponibles como una transmisión de archivos con
openFileDescriptor()
,
agregar
la categoría CATEGORY_OPENABLE
a tu intent.
En Android 4.3 (nivel de API 18) y versiones posteriores, haz lo siguiente:
También puedes permitir que el usuario seleccione varios archivos agregando
EXTRA_ALLOW_MULTIPLE
para el intent, establecido en true
Luego, podrás acceder a cada uno de los archivos seleccionados en una ClipData
.
objeto que muestra getClipData()
.
- Acción
ACTION_GET_CONTENT
- Esquema de URI de datos
- Ninguno
- Tipo de MIME
- El tipo de MIME correspondiente al tipo de archivo que el usuario debe seleccionar.
- Adicional
-
EXTRA_ALLOW_MULTIPLE
- Es un valor booleano que declara si el usuario puede seleccionar más de un archivo a la vez.
EXTRA_LOCAL_ONLY
- Valor booleano que declara si el archivo que se muestra debe estar disponible directamente en en el dispositivo, en lugar de requerir una descarga desde un servicio remoto.
- Categoría (opcional)
-
CATEGORY_OPENABLE
- Mostrar solo los elementos “openable” que se pueden representar como un flujo de archivos
con
openFileDescriptor()
.
Ejemplo de intención para tomar una foto:
Kotlin
const val REQUEST_IMAGE_GET = 1 fun selectImage() { val intent = Intent(Intent.ACTION_GET_CONTENT).apply { type = "image/*" } if (intent.resolveActivity(packageManager) != null) { startActivityForResult(intent, REQUEST_IMAGE_GET) } } override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent) { if (requestCode == REQUEST_IMAGE_GET && resultCode == Activity.RESULT_OK) { val thumbnail: Bitmap = data.getParcelableExtra("data") val fullPhotoUri: Uri = data.data // Do work with photo saved at fullPhotoUri. ... } }
Java
static final int REQUEST_IMAGE_GET = 1; public void selectImage() { Intent intent = new Intent(Intent.ACTION_GET_CONTENT); intent.setType("image/*"); if (intent.resolveActivity(getPackageManager()) != null) { startActivityForResult(intent, REQUEST_IMAGE_GET); } } @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { if (requestCode == REQUEST_IMAGE_GET && resultCode == RESULT_OK) { Bitmap thumbnail = data.getParcelable("data"); Uri fullPhotoUri = data.getData(); // Do work with photo saved at fullPhotoUri. ... } }
Ejemplo de filtro de intents para mostrar una foto:
<activity ...> <intent-filter> <action android:name="android.intent.action.GET_CONTENT" /> <data android:type="image/*" /> <category android:name="android.intent.category.DEFAULT" /> <!-- The OPENABLE category declares that the returned file is accessible from a content provider that supportsOpenableColumns
andContentResolver.openFileDescriptor()
. --> <category android:name="android.intent.category.OPENABLE" /> </intent-filter> </activity>
Abrir un tipo específico de archivo
En lugar de recuperar una copia de un archivo que debes importar a tu app, con la acción ACTION_GET_CONTENT
, cuando se ejecute en Android
4.4 o versiones posteriores, en cambio, puedes solicitar que se abra un archivo administrado por otra app
usando la acción ACTION_OPEN_DOCUMENT
y especificando un tipo de MIME.
Para permitir que el usuario cree un documento nuevo en el que tu app pueda escribir, usa la acción ACTION_CREATE_DOCUMENT
en su lugar.
Por ejemplo, en lugar de
seleccionando entre los documentos PDF existentes, el archivo ACTION_CREATE_DOCUMENT
El intent permite a los usuarios seleccionar dónde les gustaría crear un documento nuevo, por ejemplo, dentro de otra app
que administra el almacenamiento del documento. Luego, tu app recibe la ubicación del URI de donde
puede escribir el documento nuevo.
Por otro lado, el intent entregado a tu onActivityResult()
método de la acción ACTION_GET_CONTENT
podría
Devuelve un URI de cualquier tipo, la intent resultante de ACTION_OPEN_DOCUMENT
y ACTION_CREATE_DOCUMENT
siempre especifican el archivo elegido como un URI content:
respaldado por un DocumentsProvider
. Puedes abrir el
archivo con openFileDescriptor()
y
consultar sus detalles con columnas de DocumentsContract.Document
.
El URI devuelto le otorga a tu app acceso de lectura a largo plazo al archivo, también
con acceso de escritura. La acción ACTION_OPEN_DOCUMENT
es
Esto es particularmente útil cuando quieres leer un archivo existente sin hacer una copia en tu app.
o cuando quieres abrir y editar un archivo.
También puedes permitir que el usuario seleccione varios archivos agregando
EXTRA_ALLOW_MULTIPLE
para el intent, establecido en true
Si el usuario selecciona solo un elemento, puedes recuperarlo desde getData()
.
Si el usuario selecciona más de un elemento, getData()
muestra un valor nulo y debes hacerlo.
recuperar cada elemento de una ClipData
el objeto que muestra getClipData()
.
Nota: Tu intent debe especificar un tipo de MIME y
debes declarar la categoría CATEGORY_OPENABLE
. Si
apropiado, puedes especificar más de un tipo de MIME agregando una matriz de tipos de MIME con el
EXTRA_MIME_TYPES
adicional. Si lo haces, debes establecer el
tipo de MIME principal en setType()
a "*/*"
.
- Acción
ACTION_OPEN_DOCUMENT
o
ACTION_CREATE_DOCUMENT
- Esquema de URI de datos
- Ninguno
- Tipo de MIME
- El tipo de MIME correspondiente al tipo de archivo que el usuario debe seleccionar.
- Adicional
-
EXTRA_MIME_TYPES
- Una matriz de tipos de MIME correspondiente a los tipos de archivos que es tu app
solicitando. Cuando usas este extra, debes establecer el tipo de MIME principal en
De
setType()
a"*/*"
. EXTRA_ALLOW_MULTIPLE
- Es un valor booleano que declara si el usuario puede seleccionar más de un archivo a la vez.
EXTRA_TITLE
- Se usa con
ACTION_CREATE_DOCUMENT
para especificar. un nombre de archivo inicial. EXTRA_LOCAL_ONLY
- Valor booleano que declara si el archivo que se muestra debe estar disponible directamente en en el dispositivo, en lugar de requerir una descarga desde un servicio remoto.
- Categoría
-
CATEGORY_OPENABLE
- Mostrar solo los elementos “openable” que se pueden representar como un flujo de archivos
con
openFileDescriptor()
.
Ejemplo de intención para tomar una foto:
Kotlin
const val REQUEST_IMAGE_OPEN = 1 fun selectImage2() { val intent = Intent(Intent.ACTION_OPEN_DOCUMENT).apply { type = "image/*" addCategory(Intent.CATEGORY_OPENABLE) } // Only the system receives the ACTION_OPEN_DOCUMENT, so no need to test. startActivityForResult(intent, REQUEST_IMAGE_OPEN) } override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent) { if (requestCode == REQUEST_IMAGE_OPEN && resultCode == Activity.RESULT_OK) { val fullPhotoUri: Uri = data.data // Do work with full size photo saved at fullPhotoUri. ... } }
Java
static final int REQUEST_IMAGE_OPEN = 1; public void selectImage() { Intent intent = new Intent(Intent.ACTION_OPEN_DOCUMENT); intent.setType("image/*"); intent.addCategory(Intent.CATEGORY_OPENABLE); // Only the system receives the ACTION_OPEN_DOCUMENT, so no need to test. startActivityForResult(intent, REQUEST_IMAGE_OPEN); } @Override protected void onActivityResult(int requestCode, int resultCode, Intent data) { if (requestCode == REQUEST_IMAGE_OPEN && resultCode == RESULT_OK) { Uri fullPhotoUri = data.getData(); // Do work with full size photo saved at fullPhotoUri. ... } }
Las apps de terceros no pueden responder a un intent con el
ACTION_OPEN_DOCUMENT
. En cambio, el sistema recibe este
y muestra todos los archivos disponibles desde varias aplicaciones en una interfaz de usuario unificada.
Para proporcionar los archivos de tu app en esta IU y permitir que otras apps los abran, debes implementar
un objeto DocumentsProvider
e incluye un filtro de intents para
PROVIDER_INTERFACE
("android.content.action.DOCUMENTS_PROVIDER"
), como se muestra en el siguiente ejemplo:
<provider ... android:grantUriPermissions="true" android:exported="true" android:permission="android.permission.MANAGE_DOCUMENTS"> <intent-filter> <action android:name="android.content.action.DOCUMENTS_PROVIDER" /> </intent-filter> </provider>
Para obtener más información sobre cómo permitir que los archivos administrados por tu app se puedan abrir desde otras apps, Consulta Cómo abrir archivos con el framework de acceso al almacenamiento.
Acciones locales
Llamar a un automóvil es una acción local habitual. Crea un filtro de intents para publicitar capacidad para realizar esta acción con la información de la siguiente sección.
Llamar un taxi
Para pedir un taxi, usa el
ACTION_RESERVE_TAXI_RESERVATION
acción.
Nota: Las apps deben solicitar la confirmación del usuario. antes de completar esta acción.
- Acción
ACTION_RESERVE_TAXI_RESERVATION
- URI de datos
- Ninguno
- Tipo de MIME
- Ninguno
- Adicional
- Ninguno
Intent de ejemplo:
Kotlin
fun callCar() { val intent = Intent(ReserveIntents.ACTION_RESERVE_TAXI_RESERVATION) if (intent.resolveActivity(packageManager) != null) { startActivity(intent) } }
Java
public void callCar() { Intent intent = new Intent(ReserveIntents.ACTION_RESERVE_TAXI_RESERVATION); if (intent.resolveActivity(getPackageManager()) != null) { startActivity(intent); } }
Ejemplo de filtro de intents:
<activity ...> <intent-filter> <action android:name="com.google.android.gms.actions.RESERVE_TAXI_RESERVATION" /> <category android:name="android.intent.category.DEFAULT" /> </intent-filter> </activity>
Maps
Mostrar una ubicación en un mapa es una acción común de las apps de mapas. Crea un filtro de intents para anunciar la capacidad de tu app para realizar esta acción usando el información en la siguiente sección.
Mostrar una ubicación en un mapa
Para abrir un mapa, usa la acción ACTION_VIEW
y especifica
la información de ubicación en los datos del intent con uno de los esquemas siguientes
- Acción
ACTION_VIEW
- Esquema de URI de datos
-
geo:latitude,longitude
- Mostrar el mapa en la longitud y latitud dadas.
Ejemplo:
"geo:47.6,-122.3"
geo:latitude,longitude?z=zoom
- Muestra el mapa en la longitud y latitud dadas en un nivel de zoom determinado. Un nivel de zoom de
1 muestra toda la Tierra, centrada en las lat y lng dadas. El máximo
El nivel de zoom (más cercano) es 23.
Ejemplo:
"geo:47.6,-122.3?z=11"
geo:0,0?q=lat,lng(label)
- Muestra el mapa en la longitud y latitud dadas con una etiqueta de cadena.
Ejemplo:
"geo:0,0?q=34.99,-106.61(Treasure)"
geo:0,0?q=my+street+address
- Muestra la ubicación de “mi dirección”, que puede ser una dirección específica o una búsqueda de ubicación.
Ejemplo:
"geo:0,0?q=1600+Amphitheatre+Parkway%2C+CA"
Nota: Todas las cadenas que se pasen en el URI
geo
deben codificarse. Por ejemplo, la cadena1st & Pike, Seattle
se convierte en1st%20%26%20Pike%2C%20Seattle
Los espacios en la cadena se codifican con%20
o se reemplaza por el signo más (+
).
- Tipo de MIME
- Ninguno
Intent de ejemplo:
Kotlin
fun showMap(geoLocation: Uri) { val intent = Intent(Intent.ACTION_VIEW).apply { data = geoLocation } if (intent.resolveActivity(packageManager) != null) { startActivity(intent) } }
Java
public void showMap(Uri geoLocation) { Intent intent = new Intent(Intent.ACTION_VIEW); intent.setData(geoLocation); if (intent.resolveActivity(getPackageManager()) != null) { startActivity(intent); } }
Ejemplo de filtro de intents:
<activity ...> <intent-filter> <action android:name="android.intent.action.VIEW" /> <data android:scheme="geo" /> <category android:name="android.intent.category.DEFAULT" /> </intent-filter> </activity>
Música o video
Las siguientes son acciones comunes para apps de música y video, incluida la información que necesitas para crear un filtro de intents y así anunciar la capacidad de tu app de realizar cada acción.
Reproducir un archivo multimedia
Para reproducir un archivo de música, usa la acción ACTION_VIEW
y
especificar la ubicación del URI del archivo en los datos del intent.
- Acción
ACTION_VIEW
- Esquema de URI de datos
-
file:<URI>
content:<URI>
http:<URL>
- Tipo de MIME
-
"audio/*"
"application/ogg"
"application/x-ogg"
"application/itunes"
- O cualquier otro que requiera tu app.
Intent de ejemplo:
Kotlin
fun playMedia(file: Uri) { val intent = Intent(Intent.ACTION_VIEW).apply { data = file } if (intent.resolveActivity(packageManager) != null) { startActivity(intent) } }
Java
public void playMedia(Uri file) { Intent intent = new Intent(Intent.ACTION_VIEW); intent.setData(file); if (intent.resolveActivity(getPackageManager()) != null) { startActivity(intent); } }
Ejemplo de filtro de intents:
<activity ...> <intent-filter> <action android:name="android.intent.action.VIEW" /> <data android:type="audio/*" /> <data android:type="application/ogg" /> <category android:name="android.intent.category.DEFAULT" /> </intent-filter> </activity>
Reproducir música según una consulta de búsqueda
Para reproducir música según una consulta de búsqueda, usa el
INTENT_ACTION_MEDIA_PLAY_FROM_SEARCH
. Es posible que se active una app
este intent en respuesta al comando por voz del usuario para reproducir música. La app receptora de esto
intent realiza una búsqueda en su inventario para hacer coincidir el contenido existente con la consulta dada y
comienza a reproducir ese contenido.
En este intent, incluye la cadena EXTRA_MEDIA_FOCUS
extra, que especifica el modo de búsqueda previsto. Por ejemplo, el modo de búsqueda puede especificar si
la búsqueda es el nombre del artista o de la canción.
- Acción
INTENT_ACTION_MEDIA_PLAY_FROM_SEARCH
- Esquema de URI de datos
- Ninguno
- Tipo de MIME
- Ninguno
- Adicional
-
MediaStore.EXTRA_MEDIA_FOCUS
(obligatorio)-
Indica el modo de búsqueda: si el usuario busca un artista, un álbum, una canción, o una playlist. La mayoría de los modos de búsqueda requieren extras adicionales. Por ejemplo, si el usuario tiene interés en escuchar una canción en particular, el intent podría tener tres extras adicionales: el título de la canción, el artista y el álbum. Este intent admite los siguientes modos de búsqueda para cada valor de
EXTRA_MEDIA_FOCUS
:Cualquiera:
"vnd.android.cursor.item/*"
-
Reproducir cualquier canción. La app receptora reproduce música según una elección inteligente, como como la última playlist que escuchó el usuario.
Extras adicionales:
QUERY
(obligatorio): Es una cadena vacía. Este extra siempre para brindar retrocompatibilidad. Las aplicaciones existentes que no conocen los modos de búsqueda pueden procesar este intent como una búsqueda no estructurada.
No estructurados:
"vnd.android.cursor.item/*"
-
Reproducir una canción, un álbum o un género en particular desde una búsqueda no estructurada. Las apps pueden generar una intent con este modo de búsqueda cuando no puede identificar el tipo de contenido que el usuario quiere escuchar. Usa modos de búsqueda más específicos cuando sea posible.
Extras adicionales:
QUERY
(obligatorio): Es una cadena que contiene cualquier combinación. del artista, el álbum, el nombre de la canción o el género.
Género:
Audio.Genres.ENTRY_CONTENT_TYPE
-
Reproducir música de un género en particular.
Extras adicionales:
"android.intent.extra.genre"
(obligatorio): Es el género.QUERY
(obligatorio): Es el género. Siempre se proporciona este extra para garantizar la retrocompatibilidad. Las aplicaciones existentes que no conocen los modos de búsqueda pueden procesar este intent como una búsqueda no estructurada.
Artista:
Audio.Artists.ENTRY_CONTENT_TYPE
-
Reproducir música de un artista en particular.
Extras adicionales:
EXTRA_MEDIA_ARTIST
(obligatorio): Es el artista."android.intent.extra.genre"
: Es el género.QUERY
(obligatorio): una cadena que contiene cualquier combinación de el artista o el género. Este extra siempre se proporciona para brindar retrocompatibilidad. Las aplicaciones existentes que no conocen los modos de búsqueda pueden procesar este intent como un búsqueda.
-
Reproducir música de un álbum en particular.
Extras adicionales:
EXTRA_MEDIA_ALBUM
(obligatorio): Es el álbum.EXTRA_MEDIA_ARTIST
: Es el artista."android.intent.extra.genre"
: Es el género.QUERY
(obligatorio): una cadena que contiene cualquier combinación de el álbum o el artista. Este extra siempre se proporciona compatibilidad. Las aplicaciones existentes que no conocen los modos de búsqueda pueden procesar este intent como un búsqueda no estructurada.
Canción:
"vnd.android.cursor.item/audio"
-
Reproducir una canción en particular.
Extras adicionales:
EXTRA_MEDIA_ALBUM
: Es el álbum.EXTRA_MEDIA_ARTIST
: Es el artista."android.intent.extra.genre"
: Es el género.EXTRA_MEDIA_TITLE
(obligatorio): Es el nombre de la canción.QUERY
(obligatorio): una cadena que contiene cualquier combinación de el álbum, el artista, el género o el título. Este extra siempre se proporciona para retrocompatibilidad. Las apps existentes que no conocen los modos de búsqueda pueden procesar esto. de búsqueda como una búsqueda no estructurada.
Playlist:
Audio.Playlists.ENTRY_CONTENT_TYPE
-
Reproducir una playlist en particular o que coincida con algunos criterios especificados por extras adicionales.
Extras adicionales:
EXTRA_MEDIA_ALBUM
: Es el álbum.EXTRA_MEDIA_ARTIST
: Es el artista."android.intent.extra.genre"
: Es el género."android.intent.extra.playlist"
: Es la playlist.EXTRA_MEDIA_TITLE
: Es el nombre de la canción de la playlist. en función de ellos.QUERY
(obligatorio): Es una cadena que contiene cualquier combinación. del álbum, el artista, el género, la playlist o el título. Este extra siempre para brindar retrocompatibilidad. Las aplicaciones existentes que no conocen los modos de búsqueda pueden procesar este intent como una búsqueda no estructurada.
Intent de ejemplo:
Si el usuario desea escuchar música de un artista en particular, una aplicación de búsqueda puede generar la siguiente intent:
Kotlin
fun playSearchArtist(artist: String) { val intent = Intent(MediaStore.INTENT_ACTION_MEDIA_PLAY_FROM_SEARCH).apply { putExtra(MediaStore.EXTRA_MEDIA_FOCUS, MediaStore.Audio.Artists.ENTRY_CONTENT_TYPE) putExtra(MediaStore.EXTRA_MEDIA_ARTIST, artist) putExtra(SearchManager.QUERY, artist) } if (intent.resolveActivity(packageManager) != null) { startActivity(intent) } }
Java
public void playSearchArtist(String artist) { Intent intent = new Intent(MediaStore.INTENT_ACTION_MEDIA_PLAY_FROM_SEARCH); intent.putExtra(MediaStore.EXTRA_MEDIA_FOCUS, MediaStore.Audio.Artists.ENTRY_CONTENT_TYPE); intent.putExtra(MediaStore.EXTRA_MEDIA_ARTIST, artist); intent.putExtra(SearchManager.QUERY, artist); if (intent.resolveActivity(getPackageManager()) != null) { startActivity(intent); } }
Ejemplo de filtro de intents:
<activity ...> <intent-filter> <action android:name="android.media.action.MEDIA_PLAY_FROM_SEARCH" /> <category android:name="android.intent.category.DEFAULT" /> </intent-filter> </activity>
Cuando controles este intent en tu actividad, verifica el valor de la
EXTRA_MEDIA_FOCUS
extra en el archivo entrante
Intent
para determinar el modo de búsqueda. Una vez que tu actividad haya identificado
el modo de búsqueda, lee los valores de los extras adicionales para ese modo de búsqueda en particular.
Con esta información, tu app puede realizar la búsqueda dentro de su inventario para reproducir
contenido que coincida con la búsqueda. Esto se muestra en el siguiente ejemplo.
Kotlin
override fun onCreate(savedInstanceState: Bundle?) { ... if (intent.action.compareTo(MediaStore.INTENT_ACTION_MEDIA_PLAY_FROM_SEARCH) == 0) { val mediaFocus: String? = intent.getStringExtra(MediaStore.EXTRA_MEDIA_FOCUS) val query: String? = intent.getStringExtra(SearchManager.QUERY) // Some of these extras might not be available depending on the search mode. val album: String? = intent.getStringExtra(MediaStore.EXTRA_MEDIA_ALBUM) val artist: String? = intent.getStringExtra(MediaStore.EXTRA_MEDIA_ARTIST) val genre: String? = intent.getStringExtra("android.intent.extra.genre") val playlist: String? = intent.getStringExtra("android.intent.extra.playlist") val title: String? = intent.getStringExtra(MediaStore.EXTRA_MEDIA_TITLE) // Determine the search mode and use the corresponding extras. when { mediaFocus == null -> { // 'Unstructured' search mode (backward compatible) playUnstructuredSearch(query) } mediaFocus.compareTo("vnd.android.cursor.item/*") == 0 -> { if (query?.isNotEmpty() == true) { // 'Unstructured' search mode. playUnstructuredSearch(query) } else { // 'Any' search mode. playResumeLastPlaylist() } } mediaFocus.compareTo(MediaStore.Audio.Genres.ENTRY_CONTENT_TYPE) == 0 -> { // 'Genre' search mode. playGenre(genre) } mediaFocus.compareTo(MediaStore.Audio.Artists.ENTRY_CONTENT_TYPE) == 0 -> { // 'Artist' search mode. playArtist(artist, genre) } mediaFocus.compareTo(MediaStore.Audio.Albums.ENTRY_CONTENT_TYPE) == 0 -> { // 'Album' search mode. playAlbum(album, artist) } mediaFocus.compareTo("vnd.android.cursor.item/audio") == 0 -> { // 'Song' search mode. playSong(album, artist, genre, title) } mediaFocus.compareTo(MediaStore.Audio.Playlists.ENTRY_CONTENT_TYPE) == 0 -> { // 'Playlist' search mode. playPlaylist(album, artist, genre, playlist, title) } } } }
Java
protected void onCreate(Bundle savedInstanceState) { //... Intent intent = this.getIntent(); if (intent.getAction().compareTo(MediaStore.INTENT_ACTION_MEDIA_PLAY_FROM_SEARCH) == 0) { String mediaFocus = intent.getStringExtra(MediaStore.EXTRA_MEDIA_FOCUS); String query = intent.getStringExtra(SearchManager.QUERY); // Some of these extras might not be available depending on the search mode. String album = intent.getStringExtra(MediaStore.EXTRA_MEDIA_ALBUM); String artist = intent.getStringExtra(MediaStore.EXTRA_MEDIA_ARTIST); String genre = intent.getStringExtra("android.intent.extra.genre"); String playlist = intent.getStringExtra("android.intent.extra.playlist"); String title = intent.getStringExtra(MediaStore.EXTRA_MEDIA_TITLE); // Determine the search mode and use the corresponding extras. if (mediaFocus == null) { // 'Unstructured' search mode (backward compatible). playUnstructuredSearch(query); } else if (mediaFocus.compareTo("vnd.android.cursor.item/*") == 0) { if (query.isEmpty()) { // 'Any' search mode. playResumeLastPlaylist(); } else { // 'Unstructured' search mode. playUnstructuredSearch(query); } } else if (mediaFocus.compareTo(MediaStore.Audio.Genres.ENTRY_CONTENT_TYPE) == 0) { // 'Genre' search mode. playGenre(genre); } else if (mediaFocus.compareTo(MediaStore.Audio.Artists.ENTRY_CONTENT_TYPE) == 0) { // 'Artist' search mode. playArtist(artist, genre); } else if (mediaFocus.compareTo(MediaStore.Audio.Albums.ENTRY_CONTENT_TYPE) == 0) { // 'Album' search mode. playAlbum(album, artist); } else if (mediaFocus.compareTo("vnd.android.cursor.item/audio") == 0) { // 'Song' search mode. playSong(album, artist, genre, title); } else if (mediaFocus.compareTo(MediaStore.Audio.Playlists.ENTRY_CONTENT_TYPE) == 0) { // 'Playlist' search mode. playPlaylist(album, artist, genre, playlist, title); } } }
Nueva nota
Crear una nota es una acción común de las apps para tomar notas. Crea un filtro de intents para anunciar la capacidad de tu app para realizar esta acción usando el información en la siguiente sección.
Cómo crear una nota
Para crear una nota nueva, usa el
ACTION_CREATE_NOTE
y especifica detalles de la nota, como el asunto y el texto, con los siguientes extras.
Nota: Las apps deben solicitar la confirmación del usuario. antes de completar esta acción.
- Acción
-
ACTION_CREATE_NOTE
- Esquema de URI de datos
- Ninguno
- Tipo de MIME
-
PLAIN_TEXT_TYPE
- “*/*”
- Adicional
-
-
EXTRA_NAME
- Es una cadena que indica el título o asunto de la nota.
-
EXTRA_TEXT
- Es una cadena que indica el texto de la nota.
-
- Acción
-
ACTION_DIAL
: Abre la app de teléfono o marcador.ACTION_CALL
: Realiza una llamada telefónica (requiere elCALL_PHONE
)
- Esquema de URI de datos
-
tel:<phone-number>
voicemail:<phone-number>
- Tipo de MIME
- Ninguno
tel:2125551212
tel:(212) 555 1212
- Acción
-
"com.google.android.gms.actions.SEARCH_ACTION"
- Apoyar las búsquedas de Acciones de voz de Google
- Adicional
-
QUERY
- Es una cadena que contiene la búsqueda.
- Acción
ACTION_WEB_SEARCH
- Esquema de URI de datos
- Ninguno
- Tipo de MIME
- Ninguno
- Adicional
-
SearchManager.QUERY
- La cadena de búsqueda.
- Acción
-
ACTION_SETTINGS
ACTION_WIRELESS_SETTINGS
ACTION_AIRPLANE_MODE_SETTINGS
ACTION_WIFI_SETTINGS
ACTION_APN_SETTINGS
ACTION_BLUETOOTH_SETTINGS
ACTION_DATE_SETTINGS
ACTION_LOCALE_SETTINGS
ACTION_INPUT_METHOD_SETTINGS
ACTION_DISPLAY_SETTINGS
ACTION_SECURITY_SETTINGS
ACTION_LOCATION_SOURCE_SETTINGS
ACTION_INTERNAL_STORAGE_SETTINGS
ACTION_MEMORY_CARD_SETTINGS
Para ver las pantallas de configuración adicionales que están disponibles, consulta la documentación de
Settings
. - Esquema de URI de datos
- Ninguno
- Tipo de MIME
- Ninguno
- Acción
ACTION_SENDTO
o
ACTION_SEND
o
ACTION_SEND_MULTIPLE
- Esquema de URI de datos
-
sms:<phone_number>
smsto:<phone_number>
mms:<phone_number>
mmsto:<phone_number>
Todos estos esquemas se manejan de la misma manera.
- Tipo de MIME
-
"text/plain"
"image/*"
"video/*"
- Adicional
-
"subject"
- Es una cadena para el asunto del mensaje (generalmente, solo para MMS).
"sms_body"
- Es una cadena para el mensaje de texto.
EXTRA_STREAM
- Un
Uri
que apunta a imagen o video para adjuntar. Si usas la acciónACTION_SEND_MULTIPLE
, este extra es unArrayList
deUri
objetos que apuntan a las imágenes o los videos que se adjuntarán.
- Acción
ACTION_VIEW
- Esquema de URI de datos
http:<URL>
https:<URL>
- Tipo de MIME
-
"text/plain"
"text/html"
"application/xhtml+xml"
"application/vnd.wap.xhtml+xml"
- Configura un dispositivo Android para el desarrollo. o usar un dispositivo virtual.
- Instala una versión de tu app que maneje las intents que quieres admitir.
- Activa un intent con
adb
:adb shell am start -a <ACTION> -t <MIME_TYPE> -d <DATA> \ -e <EXTRA_NAME> <EXTRA_VALUE> -n <ACTIVITY>
Por ejemplo:
adb shell am start -a android.intent.action.DIAL \ -d tel:555-5555 -n org.example.MyApp/.MyActivity
- Si defines los filtros de intents requeridos, controla el intent.
Intent de ejemplo:
Kotlin
fun createNote(subject: String, text: String) { val intent = Intent(NoteIntents.ACTION_CREATE_NOTE).apply { putExtra(NoteIntents.EXTRA_NAME, subject) putExtra(NoteIntents.EXTRA_TEXT, text) } if (intent.resolveActivity(packageManager) != null) { startActivity(intent) } }
Java
public void createNote(String subject, String text) { Intent intent = new Intent(NoteIntents.ACTION_CREATE_NOTE) .putExtra(NoteIntents.EXTRA_NAME, subject) .putExtra(NoteIntents.EXTRA_TEXT, text); if (intent.resolveActivity(getPackageManager()) != null) { startActivity(intent); } }
Ejemplo de filtro de intents:
<activity ...> <intent-filter> <action android:name="com.google.android.gms.actions.CREATE_NOTE" /> <category android:name="android.intent.category.DEFAULT" /> <data android:mimeType="*/*" /> </intent-filter> </activity>
Teléfono
Iniciar una llamada es una acción común en las apps para teléfonos. Crea un filtro de intents para anunciar la capacidad de tu app para realizar esta acción usando el información en la siguiente sección.
Iniciar una llamada telefónica
Para abrir la app de teléfono y marcar un número, usa la acción ACTION_DIAL
y especifica un número de teléfono con el
el siguiente esquema de URI. Cuando se abre la aplicación de Teléfono, muestra el número de teléfono,
y el usuario debe presionar el botón Llamar para comenzar la llamada.
Para realizar una llamada telefónica directamente, usa la acción ACTION_CALL
.
y especifica un número de teléfono con el siguiente esquema de URI. Cuando se abre la aplicación de teléfono,
comenzará la llamada telefónica. No es necesario que el usuario presione el botón Llamar.
La acción ACTION_CALL
requiere que agregues el
CALL_PHONE
para tu archivo de manifiesto:
<uses-permission android:name="android.permission.CALL_PHONE" />
Los números de teléfono válidos son aquellos definidos en el IETF RFC 3966. Algunos ejemplos válidos son los siguientes:
El marcador de la aplicación de Teléfono es bueno para normalizar esquemas, como
números de teléfono. Por lo tanto, el esquema descrito no es estrictamente obligatorio en el
Uri.parse()
.
Sin embargo, si aún no ha probado un esquema o no está seguro de si
se puede controlar, usa el Uri.fromParts()
en su lugar.
Intent de ejemplo:
Kotlin
fun dialPhoneNumber(phoneNumber: String) { val intent = Intent(Intent.ACTION_DIAL).apply { data = Uri.parse("tel:$phoneNumber") } if (intent.resolveActivity(packageManager) != null) { startActivity(intent) } }
Java
public void dialPhoneNumber(String phoneNumber) { Intent intent = new Intent(Intent.ACTION_DIAL); intent.setData(Uri.parse("tel:" + phoneNumber)); if (intent.resolveActivity(getPackageManager()) != null) { startActivity(intent); } }
Buscar
Las siguientes son acciones comunes para las apps de búsqueda, incluida la información que necesitas para crear un filtro de intents y así anunciar la capacidad de tu app de realizar cada acción.
Buscar usando una aplicación específica
Para admitir la búsqueda en el contexto de tu app, declara un filtro de intents en la app con
la acción SEARCH_ACTION
, como se muestra en el siguiente ejemplo de filtro de intents.
Nota: No recomendamos usar SEARCH_ACTION
para la búsqueda de apps.
En su lugar, implementa
GET_THING
para aprovechar la compatibilidad integrada de Asistente de Google con la búsqueda en la app. Para obtener más información, consulta
Asistente de Google
Consulta la documentación de Acciones en apps.
Ejemplo de filtro de intents:
<activity android:name=".SearchActivity"> <intent-filter> <action android:name="com.google.android.gms.actions.SEARCH_ACTION"/> <category android:name="android.intent.category.DEFAULT"/> </intent-filter> </activity>
Realizar una búsqueda web
Para iniciar una búsqueda web, usa la acción ACTION_WEB_SEARCH
.
y especifica la cadena de búsqueda en el
SearchManager.QUERY
adicionales.
Intent de ejemplo:
Kotlin
fun searchWeb(query: String) { val intent = Intent(Intent.ACTION_WEB_SEARCH).apply { putExtra(SearchManager.QUERY, query) } if (intent.resolveActivity(packageManager) != null) { startActivity(intent) } }
Java
public void searchWeb(String query) { Intent intent = new Intent(Intent.ACTION_WEB_SEARCH); intent.putExtra(SearchManager.QUERY, query); if (intent.resolveActivity(getPackageManager()) != null) { startActivity(intent); } }
Configuración
Para abrir una pantalla en la app de Configuración del sistema cuando tu app requiere que el usuario realice un cambio, haz lo siguiente: usa una de las siguientes acciones de intent:
Intent de ejemplo:
Kotlin
fun openWifiSettings() { val intent = Intent(Settings.ACTION_WIFI_SETTINGS) if (intent.resolveActivity(packageManager) != null) { startActivity(intent) } }
Java
public void openWifiSettings() { Intent intent = new Intent(Settings.ACTION_WIFI_SETTINGS); if (intent.resolveActivity(getPackageManager()) != null) { startActivity(intent); } }
Mensajes de texto
Redactar un mensaje SMS o MMS con un archivo adjunto es una acción común para las apps de mensajería de texto. Crea un filtro de intents para anunciar la capacidad de tu app para realizar esta acción usando el información en la siguiente sección.
Redactar un mensaje SMS o MMS con archivos adjuntos
Para iniciar un mensaje de texto SMS o MMS, usa una de las siguientes acciones de intent y especifica el mensaje como el número de teléfono, el asunto y el cuerpo del mensaje con las siguientes claves adicionales.
Intent de ejemplo:
Kotlin
fun composeMmsMessage(message: String, attachment: Uri) { val intent = Intent(Intent.ACTION_SENDTO).apply { type = HTTP.PLAIN_TEXT_TYPE putExtra("sms_body", message) putExtra(Intent.EXTRA_STREAM, attachment) } if (intent.resolveActivity(packageManager) != null) { startActivity(intent) } }
Java
public void composeMmsMessage(String message, Uri attachment) { Intent intent = new Intent(Intent.ACTION_SENDTO); intent.setType(HTTP.PLAIN_TEXT_TYPE); intent.putExtra("sms_body", message); intent.putExtra(Intent.EXTRA_STREAM, attachment); if (intent.resolveActivity(getPackageManager()) != null) { startActivity(intent); } }
Si quieres asegurarte de que solo una app de mensajería de texto, y no otra
correo electrónico o apps sociales y, luego, usa la acción ACTION_SENDTO
e incluye el esquema de datos "smsto:"
, como se muestra en el siguiente ejemplo:
Kotlin
fun composeMmsMessage(message: String, attachment: Uri) { val intent = Intent(Intent.ACTION_SEND).apply { data = Uri.parse("smsto:") // Only SMS apps respond to this. putExtra("sms_body", message) putExtra(Intent.EXTRA_STREAM, attachment) } if (intent.resolveActivity(packageManager) != null) { startActivity(intent) } }
Java
public void composeMmsMessage(String message, Uri attachment) { Intent intent = new Intent(Intent.ACTION_SEND); intent.setData(Uri.parse("smsto:")); // Only SMS apps respond to this. intent.putExtra("sms_body", message); intent.putExtra(Intent.EXTRA_STREAM, attachment); if (intent.resolveActivity(getPackageManager()) != null) { startActivity(intent); } }
Ejemplo de filtro de intents:
<activity ...> <intent-filter> <action android:name="android.intent.action.SEND" /> <data android:type="text/plain" /> <data android:type="image/*" /> <category android:name="android.intent.category.DEFAULT" /> </intent-filter> </activity>
Nota: Si estás desarrollando una app de mensajería SMS/MMS, debes
implementar filtros de intents para varias acciones adicionales de modo que estén disponibles como
app de SMS predeterminada en Android 4.4 y versiones posteriores. Para obtener más información, consulta la documentación
a las Telephony
.
Navegador web
Cargar una URL web es una acción común de las apps de navegador web. Crea un filtro de intents para anunciar la capacidad de tu app para realizar esta acción usando el información en la siguiente sección.
Cargar una URL web
Para abrir una página web, usa la acción ACTION_VIEW
y especifica la URL web en los datos del intent.
Intent de ejemplo:
Kotlin
fun openWebPage(url: String) { val webpage: Uri = Uri.parse(url) val intent = Intent(Intent.ACTION_VIEW, webpage) if (intent.resolveActivity(packageManager) != null) { startActivity(intent) } }
Java
public void openWebPage(String url) { Uri webpage = Uri.parse(url); Intent intent = new Intent(Intent.ACTION_VIEW, webpage); if (intent.resolveActivity(getPackageManager()) != null) { startActivity(intent); } }
Ejemplo de filtro de intents:
<activity ...> <intent-filter> <action android:name="android.intent.action.VIEW" /> <!-- Include the host attribute if you want your app to respond only to URLs with your app's domain. --> <data android:scheme="http" android:host="www.example.com" /> <category android:name="android.intent.category.DEFAULT" /> <!-- The BROWSABLE category is required to get links from web pages. --> <category android:name="android.intent.category.BROWSABLE" /> </intent-filter> </activity>
Nota: Si la app para Android proporciona una funcionalidad similar a la siguiente: su sitio web, incluya un filtro de intenciones para las URL que dirijan a su sitio web. Luego, si los usuarios tienen instalada tu app, vínculos de correos electrónicos u otras páginas web que dirijan a tu sitio web abre tu app para Android en lugar de tu página web. Más información en Cómo controlar Android App Links
A partir de Android 12 (nivel de API 31), un intent web genérico se resuelve en una actividad de la app solo si esta se aprobó para el dominio específico que se incluye en ese intent web. Si no se aprueba la app para el dominio, la Web se resuelve en la app del navegador predeterminada del usuario.
Cómo verificar los intents con Android Debug Bridge
Para verificar que tu app responda a los intents que quieres admitir, puedes usar el
La herramienta adb
para activar intents específicos mediante la ejecución
lo siguiente:
Para obtener más información, consulta Emite comandos del shell.