Modifier des contacts à l'aide d'intents

Cette leçon vous explique comment utiliser un Intent pour insérer un nouveau contact ou modifier les données d'un contact. Au lieu d'accéder directement au fournisseur de contacts, Intent lance l'application Contacts, qui exécute les applications Activity Pour les actions de modification décrites dans cette leçon, si vous envoyez des données étendues dans Intent, elles sont saisies dans l'UI de Activity qui est lancée.

L'utilisation d'un Intent pour insérer ou mettre à jour un seul contact est la méthode recommandée pour modifier le fournisseur de contacts, pour les raisons suivantes :

  • Elle vous épargne le temps et les efforts nécessaires au développement de votre propre interface utilisateur et de votre propre code.
  • Cela évite d'introduire des erreurs causées par des modifications qui ne respectent pas les règles du fournisseur de contacts.
  • Cela réduit le nombre d'autorisations que vous devez demander. Votre appli n'a pas besoin d'autorisation pour écrire au fournisseur Contacts, car il délègue les modifications apportées à l'application Contacts, qui dispose déjà de cette autorisation.

Insérer un nouveau contact à l'aide d'un intent

Vous souhaitez souvent autoriser l'utilisateur à insérer un nouveau contact lorsque votre application reçoit de nouvelles données. Par exemple, une application d'avis sur les restaurants peut permettre aux utilisateurs d'ajouter le restaurant en tant que contact lorsqu'ils écrivent un avis. Pour ce faire, utilisez un intent en utilisant autant de données que possible. puis envoyez l'intent à l'application Contacts.

Lorsque vous insérez un contact à l'aide de l'application Contacts, un nouveau contact brut est inséré dans Contacts. Table ContactsContract.RawContacts du fournisseur. Si nécessaire, l'application Contacts invite l'utilisateur à indiquer le type de compte et le compte à utiliser lors de la création du compte contact. L'application Contacts informe également les utilisateurs si le contact brut existe déjà. Les utilisateurs ont alors d'annulation de l'insertion, auquel cas aucun contact n'est créé. Pour apprendre en savoir plus sur les contacts bruts, consultez Fournisseur de contacts Guide de l'API.

Créer un intent

Pour commencer, créez un objet Intent avec l'action Intents.Insert.ACTION Définissez le type MIME sur RawContacts.CONTENT_TYPE. Exemple :

Kotlin

...
// Creates a new Intent to insert a contact
val intent = Intent(ContactsContract.Intents.Insert.ACTION).apply {
    // Sets the MIME type to match the Contacts Provider
    type = ContactsContract.RawContacts.CONTENT_TYPE
}

Java

...
// Creates a new Intent to insert a contact
Intent intent = new Intent(ContactsContract.Intents.Insert.ACTION);
// Sets the MIME type to match the Contacts Provider
intent.setType(ContactsContract.RawContacts.CONTENT_TYPE);

Si vous disposez déjà d'informations sur le contact, telles qu'un numéro de téléphone ou une adresse e-mail, vous pouvez les insérer dans l'intent en tant que données étendues. Pour une valeur de clé, utilisez la constante appropriée de Intents.Insert. L'application Contacts affiche les données dans l'écran d'insertion, ce qui permet aux utilisateurs d'effectuer d'autres modifications et ajouts.

Kotlin

private var emailAddress: EditText? = null
private var phoneNumber: EditText? = null
...
/* Assumes EditText fields in your UI contain an email address
 * and a phone number.
 *
 */
emailAddress = findViewById(R.id.email)
phoneNumber = findViewById(R.id.phone)
...
/*
 * Inserts new data into the Intent. This data is passed to the
 * contacts app's Insert screen
 */
intent.apply {
    // Inserts an email address
    putExtra(ContactsContract.Intents.Insert.EMAIL, emailAddress?.text)
    /*
     * In this example, sets the email type to be a work email.
     * You can set other email types as necessary.
     */
    putExtra(
            ContactsContract.Intents.Insert.EMAIL_TYPE,
            ContactsContract.CommonDataKinds.Email.TYPE_WORK
    )
    // Inserts a phone number
    putExtra(ContactsContract.Intents.Insert.PHONE, phoneNumber?.text)
    /*
     * In this example, sets the phone type to be a work phone.
     * You can set other phone types as necessary.
     */
    putExtra(
            ContactsContract.Intents.Insert.PHONE_TYPE,
            ContactsContract.CommonDataKinds.Phone.TYPE_WORK
    )
}

Java

private EditText emailAddress = null;
private EditText phoneNumber = null;
...
/* Assumes EditText fields in your UI contain an email address
 * and a phone number.
 *
 */
emailAddress = (EditText) findViewById(R.id.email);
phoneNumber = (EditText) findViewById(R.id.phone);
...
/*
 * Inserts new data into the Intent. This data is passed to the
 * contacts app's Insert screen
 */
// Inserts an email address
intent.putExtra(ContactsContract.Intents.Insert.EMAIL, emailAddress.getText())
/*
 * In this example, sets the email type to be a work email.
 * You can set other email types as necessary.
 */
      .putExtra(ContactsContract.Intents.Insert.EMAIL_TYPE,
            ContactsContract.CommonDataKinds.Email.TYPE_WORK)
// Inserts a phone number
      .putExtra(ContactsContract.Intents.Insert.PHONE, phoneNumber.getText())
/*
 * In this example, sets the phone type to be a work phone.
 * You can set other phone types as necessary.
 */
      .putExtra(ContactsContract.Intents.Insert.PHONE_TYPE,
            ContactsContract.CommonDataKinds.Phone.TYPE_WORK);

Une fois que vous avez créé le Intent, envoyez-le en appelant startActivity().

Kotlin

    /* Sends the Intent
     */
    startActivity(intent)

Java

    /* Sends the Intent
     */
    startActivity(intent);

Cet appel ouvre un écran dans l'application Contacts, qui permet aux utilisateurs de saisir un nouveau contact. La le type de compte et le nom du compte pour le contact sont indiqués en haut de l'écran. Une fois que les utilisateurs saisissez les données requises, puis cliquez sur OK. La liste de contacts de l'application s'affiche. Les utilisateurs reviennent à votre application en cliquant sur Retour.

Modifier un contact existant à l'aide d'un intent

Modifier un contact existant à l'aide d'un Intent est utile si l'utilisateur a déjà choisi un contact qui l'intéresse. Par exemple, une application qui recherche des contacts ayant des adresses postales, mais pas de code postal, peut permettre aux utilisateurs de rechercher le code, puis de l'ajouter au contact.

Pour modifier un contact existant à l'aide d'un intent, suivez une procédure semblable à l'insertion d'un contact. Créez un intent comme décrit dans la section. Insérer un nouveau contact à l'aide d'un intent, mais ajouter son Contacts.CONTENT_LOOKUP_URI et le type MIME Contacts.CONTENT_ITEM_TYPE à l'intent. Si vous souhaitez modifier le contact avec des informations que vous possédez déjà, vous pouvez les placer dans les données étendues de l'intent. Notez que certaines colonnes de noms ne peuvent pas être modifiées à l'aide d'un intent. Ces colonnes sont listées dans la section récapitulative de la documentation de référence de l'API pour la classe ContactsContract.Contacts sous l'en-tête "Mise à jour".

Enfin, envoyez l'intent. En réponse, l'application Contacts affiche un écran de modification. Lorsque l'utilisateur termine la modification et l'enregistre, l'application Contacts affiche une liste de contacts. Lorsque l'utilisateur clique sur Retour, votre application s'affiche.

Créer l'intent

Pour modifier un contact, appelez Intent(action) pour Créez un intent avec l'action ACTION_EDIT. Appeler setDataAndType() pour définir la valeur des données l'intent vers le Contacts.CONTENT_LOOKUP_URI du contact et le type MIME pour Contacts.CONTENT_ITEM_TYPE type MIME ; parce qu'un appel à setType() écrase la valeur de données actuelle pour le paramètre Intent, vous devez définir les données et le type MIME en même temps.

Pour obtenir l'Contacts.CONTENT_LOOKUP_URI d'un contact, appelez Contacts.getLookupUri(id, lookupkey) avec les valeurs Contacts._ID et Contacts.LOOKUP_KEY du contact comme arguments.

Remarque:L'adresse e-mail d'un contact La valeur LOOKUP_KEY est l'identifiant que vous devez utiliser pour récupérer un contact. Il reste constant, même si le fournisseur modifie l'ID de ligne du contact pour gérer les opérations internes.

L'extrait de code suivant montre comment créer un intent :

Kotlin

    // The Cursor that contains the Contact row
    var mCursor: Cursor? = null
    // The index of the lookup key column in the cursor
    var lookupKeyIndex: Int = 0
    // The index of the contact's _ID value
    var idIndex: Int = 0
    // The lookup key from the Cursor
    var currentLookupKey: String? = null
    // The _ID value from the Cursor
    var currentId: Long = 0
    // A content URI pointing to the contact
    var selectedContactUri: Uri? = null
    ...
    /*
     * Once the user has selected a contact to edit,
     * this gets the contact's lookup key and _ID values from the
     * cursor and creates the necessary URI.
     */
    mCursor?.apply {
        // Gets the lookup key column index
        lookupKeyIndex = getColumnIndex(ContactsContract.Contacts.LOOKUP_KEY)
        // Gets the lookup key value
        currentLookupKey = getString(lookupKeyIndex)
        // Gets the _ID column index
        idIndex = getColumnIndex(ContactsContract.Contacts._ID)
        currentId = getLong(idIndex)
        selectedContactUri = ContactsContract.Contacts.getLookupUri(currentId, mCurrentLookupKey)
    }

    // Creates a new Intent to edit a contact
    val editIntent = Intent(Intent.ACTION_EDIT).apply {
        /*
         * Sets the contact URI to edit, and the data type that the
         * Intent must match
         */
        setDataAndType(selectedContactUri, ContactsContract.Contacts.CONTENT_ITEM_TYPE)
    }

Java

    // The Cursor that contains the Contact row
    public Cursor mCursor;
    // The index of the lookup key column in the cursor
    public int lookupKeyIndex;
    // The index of the contact's _ID value
    public int idIndex;
    // The lookup key from the Cursor
    public String currentLookupKey;
    // The _ID value from the Cursor
    public long currentId;
    // A content URI pointing to the contact
    Uri selectedContactUri;
    ...
    /*
     * Once the user has selected a contact to edit,
     * this gets the contact's lookup key and _ID values from the
     * cursor and creates the necessary URI.
     */
    // Gets the lookup key column index
    lookupKeyIndex = mCursor.getColumnIndex(ContactsContract.Contacts.LOOKUP_KEY);
    // Gets the lookup key value
    currentLookupKey = mCursor.getString(lookupKeyIndex);
    // Gets the _ID column index
    idIndex = mCursor.getColumnIndex(ContactsContract.Contacts._ID);
    currentId = mCursor.getLong(idIndex);
    selectedContactUri =
            Contacts.getLookupUri(currentId, mCurrentLookupKey);
    ...
    // Creates a new Intent to edit a contact
    Intent editIntent = new Intent(Intent.ACTION_EDIT);
    /*
     * Sets the contact URI to edit, and the data type that the
     * Intent must match
     */
    editIntent.setDataAndType(selectedContactUri, ContactsContract.Contacts.CONTENT_ITEM_TYPE);

Ajouter l'indicateur de navigation

Sur Android 4.0 (version 14 de l'API) ou version ultérieure, un problème dans l'application Contacts entraîne des erreurs la navigation. Lorsque votre application envoie un intent de modification à l'application Contacts, et que les utilisateurs modifient et enregistrent un intent lorsqu'il clique sur Retour, l'écran de la liste des contacts s'affiche. Pour revenir à votre application, ils doivent cliquer sur Récents et choisir votre application.

Pour contourner ce problème sous Android 4.0.3 (version 15 de l'API) ou version ultérieure, ajoutez l'extension clé de données finishActivityOnSaveCompleted à l'intent, avec la valeur true. Les versions d'Android antérieures à Android 4.0 acceptent cette clé, mais elle n'a aucun effet. Pour définir le paramètre données étendues, procédez comme suit:

Kotlin

    // Sets the special extended data for navigation
    editIntent.putExtra("finishActivityOnSaveCompleted", true)

Java

    // Sets the special extended data for navigation
    editIntent.putExtra("finishActivityOnSaveCompleted", true);

Ajouter d'autres données étendues

Pour ajouter des données étendues supplémentaires au Intent, appelez putExtra() comme vous le souhaitez. Vous pouvez ajouter des données étendues pour les champs de contact courants en utilisant les valeurs-clés spécifiées dans Intents.Insert N'oubliez pas que certaines Les colonnes de la table ContactsContract.Contacts ne peuvent pas être modifiées. Ces colonnes sont répertoriées dans la section "summary" de la documentation de référence de l'API pour la classe. ContactsContract.Contacts sous le titre "Mettre à jour".

Envoyer l'intent

Enfin, envoyez l'intent que vous avez créé. Exemple :

Kotlin

    // Sends the Intent
    startActivity(editIntent)

Java

    // Sends the Intent
    startActivity(editIntent);

Laisser les utilisateurs choisir d'insérer ou de modifier un intent

Vous pouvez autoriser les utilisateurs à choisir d'insérer un contact ou de modifier un contact existant en envoyant un élément Intent avec l'action ACTION_INSERT_OR_EDIT Par exemple, une application de client de messagerie peut autoriser les utilisateurs à ajouter une adresse e-mail entrante à un nouveau contact ou à l'ajouter en tant qu'adresse e-mail pour un contact existant. Définissez le type MIME de cet intent sur Contacts.CONTENT_ITEM_TYPE, mais ne définissez pas d'URI de données.

Lorsque vous envoyez cet intent, l'application Contacts affiche une liste de contacts. Les utilisateurs peuvent soit insérer un nouveau contact, soit sélectionner un contact existant et le modifier. Tous les champs de données étendus que vous ajoutez à l'intent remplissent l'écran qui s'affiche. Vous pouvez utiliser l'une des valeurs de clé spécifiées dans Intents.Insert. L'extrait de code suivant montre comment créer et envoyer l'intent :

Kotlin

    // Creates a new Intent to insert or edit a contact
    val intentInsertEdit = Intent(Intent.ACTION_INSERT_OR_EDIT).apply {
        // Sets the MIME type
        type = ContactsContract.Contacts.CONTENT_ITEM_TYPE
    }
    // Add code here to insert extended data, if desired

    // Sends the Intent with an request ID
    startActivity(intentInsertEdit)

Java

    // Creates a new Intent to insert or edit a contact
    Intent intentInsertEdit = new Intent(Intent.ACTION_INSERT_OR_EDIT);
    // Sets the MIME type
    intentInsertEdit.setType(ContactsContract.Contacts.CONTENT_ITEM_TYPE);
    // Add code here to insert extended data, if desired
    ...
    // Sends the Intent with an request ID
    startActivity(intentInsertEdit);