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.
// 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.
@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.
<?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 :
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.
3. Liens et littérature▲
4. 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