1. Les dialogues Android

1-1. Introduction

Vous pouvez ouvrir les boîtes de dialogue de votre activité avec la méthode ShowDialog (int). Les dialogues sont toujours créés et font partie de l'activité. Une boîte de dialogue conserve le focus jusqu'à ce que l'utilisateur la ferme.

Dialog est la classe de base pour les dialogues. En général, vous utilisez ses classes dérivées, par exemple, AlertDialog, ProgressDialog, DatePickerDialog ou TimePickerDialog.

 
Sélectionnez
// Constant for identifying the dialog
private static final int DIALOG_ALERT = 10;

public void onClick(View view) {
    showDialog(DIALOG_ALERT);
} 

Si la boîte de dialogue s'affiche pour la première fois, Android appelle la méthode onCreateDialog (int). Dans cette méthode, vous pouvez instancier le dialogue de manière correcte en fonction des paramètres d'entrée. Vous devez toujours créer un dialogue à partir de la méthode onCreateDialog (int) ou alors laisser Android gérer la boîte de dialogue pour vous.

 
Sélectionnez
@Override
protected Dialog onCreateDialog(int id) {
  switch (id) {
    case DIALOG_ALERT:
    // Create out AlterDialog
    Builder builder = new AlertDialog.Builder(this);
    builder.setMessage("This will end the activity");
    builder.setCancelable(true);
    builder.setPositiveButton("I agree", new OkOnClickListener());
    builder.setNegativeButton("No, no", new CancelOnClickListener());
    AlertDialog dialog = builder.create();
    dialog.show();
   }
  return super.onCreateDialog(id);
}

private final class CancelOnClickListener implements
  DialogInterface.OnClickListener {
  public void onClick(DialogInterface dialog, int which) {
  Toast.makeText(getApplicationContext(), "Activity will continue",
    Toast.LENGTH_LONG).show();
  }
}

private final class OkOnClickListener implements
    DialogInterface.OnClickListener {
  public void onClick(DialogInterface dialog, int which) {
  AlertExampleActivity.this.finish();
  }
} 

onCreateDialog(int) est appelée seulement la première fois. Si vous voulez influer sur le dialogue plus tard, utilisez la méthode optionnelle onPrepareDialog(int, Dialog).

1-2. ProgressDialog

Android fournit aussi un ProgressDialog, qui peut être ouvert par l'appel à la méthode ProgressDialog.open().

1-3. Ses propres dialogues

Si vous souhaitez créer vos propres boîtes de dialogue, il faut créer un fichier de configuration par dialogue. Ce fichier de configuration est attribué à la boîte de dialogue par l'intermédiaire de la méthode setContentView ().

Vous pouvez ensuite utiliser dialog.findViewById () pour trouver les éléments de votre dialogue et lui attribuer des valeurs.

Le titre de la boîte de dialogue peut être positionné avec la méthode setTitle ().

2. Tutoriel : Alert Dialog

Ce qui suit donne un exemple d'utilisation de la boîte de dialogue AlertDialog. Une instance de cette classe peut être créée par le modèle du constructeur, par exemple, vous pouvez enchaîner les appels de méthode.
Créez un nouveau projet Android nommé « de.vogella.android.dialog.alert » avec l'activité appelée AlertExampleActivity. Maintenir le schéma suivant pour main.xml.

 
Sélectionnez
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical" >

    <Button
        android:id="@+id/button1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:onClick="onClick"
        android:text="Button" />

</LinearLayout> 

Changez le code de votre activité comme suit :

 
Sélectionnez

package de.vogella.android.dialog.alert;

import android.app.Activity;
import android.app.AlertDialog;
import android.app.AlertDialog.Builder;
import android.app.Dialog;
import android.content.DialogInterface;
import android.os.Bundle;
import android.view.View;
import android.widget.Toast;

public class AlertExampleActivity extends Activity {

  private static final int DIALOG_ALERT = 10;

  
/** Called when the activity is first created. */


  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);

  }

  public void onClick(View view) {
    showDialog(DIALOG_ALERT);
  }

  @Override
  protected Dialog onCreateDialog(int id) {
    switch (id) {
    case DIALOG_ALERT:
      // Create out AlterDialog
      Builder builder = new AlertDialog.Builder(this);
      builder.setMessage("This will end the activity");
      builder.setCancelable(true);
      builder.setPositiveButton("I agree", new OkOnClickListener());
      builder.setNegativeButton("No, no", new CancelOnClickListener());
      AlertDialog dialog = builder.create();
      dialog.show();
    }
    return super.onCreateDialog(id);
  }

  private final class CancelOnClickListener implements
      DialogInterface.OnClickListener {
    public void onClick(DialogInterface dialog, int which) {
      Toast.makeText(getApplicationContext(), "Activity will continue",
          Toast.LENGTH_LONG).show();
    }
  }

  private final class OkOnClickListener implements
      DialogInterface.OnClickListener {
    public void onClick(DialogInterface dialog, int which) {
      AlertExampleActivity.this.finish();
    }
  }

} 

Si vous lancez votre application et cliquez sur le bouton, vous devriez voir le dialogue attendu.

Image non disponible

3. Merci

Vous pouvez faire un don à Lars Vogel sur la page de l'article original.

4. Questions et discussions

Si vous trouvez des erreurs dans ce tutoriel, s'il vous plaît informez-moi (voir en haut de la page). Veuillez noter qu'en raison du volume élevé de retours que je reçois, je ne peux pas répondre aux questions concernant votre application. Assurez-vous d'avoir lu la FAQ vogella, je ne réponds pas non plus aux questions traitées dans la FAQ.

5. Liens et littérature

5-1. Code source

5-2. Ressources Android

5-3. Ressources vogella

6. Remerciements Developpez

Vous pouvez retrouver l'article original ici : Android Dialogs. Nous remercions Lars Vogel qui nous a aimablement autorisés à traduire et héberger ses articles.

Nos remerciements à ClaudeLELOUP pour sa relecture orthographique.

N'hésitez pas à commenter cet article ! Commentez Donner une note à l´article (5)