Android - Saisie automatique
Si vous souhaitez obtenir des suggestions, lorsque vous saisissez un champ de texte modifiable, vous pouvez le faire via AutoCompleteTextView. Il fournit des suggestions automatiquement lorsque l'utilisateur tape. La liste des suggestions est affichée dans un menu déroulant dans lequel l'utilisateur peut choisir un élément pour remplacer le contenu de la zone d'édition par.
Pour utiliser AutoCompleteTextView, vous devez d'abord créer un champ AutoCompletTextView dans le xml. Sa syntaxe est donnée ci-dessous.
<AutoCompleteTextView
android:id="@+id/autoCompleteTextView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_centerHorizontal="true"
android:layout_marginTop="65dp"
android:ems="10" >
Après cela, vous devez obtenir une référence de cette vue de texte en java. Sa syntaxe est donnée ci-dessous.
private AutoCompleteTextView actv;
actv = (AutoCompleteTextView) findViewById(R.id.autoCompleteTextView1);
La prochaine chose que vous devez faire est de spécifier la liste des éléments de suggestions à afficher. Vous pouvez spécifier les éléments de la liste sous forme de tableau de chaînes dans java ou dans strings.xml. Sa syntaxe est donnée ci-dessous.
String[] countries = getResources().getStringArray(R.array.list_of_countries);
ArrayAdapter<String> adapter = new ArrayAdapter<String>
(this,android.R.layout.simple_list_item_1,countries);
actv.setAdapter(adapter);
La classe d'adaptateur de tableau est responsable de l'affichage des données sous forme de liste dans la boîte de suggestion du champ de texte. lesetAdapterest utilisée pour définir l'adaptateur de la fonction autoCompleteTextView. En dehors de ces méthodes, les autres méthodes de saisie semi-automatique sont répertoriées ci-dessous.
Sr. Non | Méthode et description |
---|---|
1 | getAdapter() Cette méthode renvoie un adaptateur de liste filtrable utilisé pour la saisie semi-automatique |
2 | getCompletionHint() Cette méthode retourne un texte d'indication facultatif affiché en bas de la liste correspondante |
3 | getDropDownAnchor() Cette méthode renvoie retourne l'ID de la vue à laquelle la liste déroulante de saisie semi-automatique est ancrée. |
4 | getListSelection() Cette méthode renvoie la position de la sélection de la vue déroulante, s'il y en a une |
5 | isPopupShowing() Cette méthode indique si le menu contextuel s'affiche |
6 | setText(CharSequence text, boolean filter) Cette méthode définit le texte sauf qu'elle peut désactiver le filtrage |
sept | showDropDown() Cette méthode affiche la liste déroulante à l'écran. |
Exemple
L'exemple ci-dessous illustre l'utilisation de la classe AutoCompleteTextView. Il crée une application de base qui vous permet de taper et affiche des suggestions sur votre appareil.
Pour expérimenter cet exemple, vous devez l'exécuter sur un appareil réel ou dans un émulateur.
Pas | La description |
---|---|
1 | Vous utiliserez Android Studio pour créer une application Android sous un package de package com.example.sairamkrishna.myapplication. |
2 | Modifiez le fichier src / MainActivity.java pour ajouter du code AutoCompleteTextView |
3 | Modifiez le fichier XML de mise en page res / layout / activity_main.xml, ajoutez tout composant GUI si nécessaire. |
4 | Exécutez l'application et choisissez un appareil Android en cours d'exécution, installez l'application dessus et vérifiez les résultats. |
Voici le contenu de src/MainActivity.java
package com.example.sairamkrishna.myapplication;
import android.app.Activity;
import android.content.Context;
import android.media.AudioManager;
import android.media.MediaPlayer;
import android.media.MediaRecorder;
import android.os.Bundle;
import android.os.Environment;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.animation.Animation;
import android.view.animation.AnimationUtils;
import android.widget.ArrayAdapter;
import android.widget.AutoCompleteTextView;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.MultiAutoCompleteTextView;
import android.widget.Toast;
import java.io.IOException;
public class MainActivity extends Activity {
AutoCompleteTextView text;
MultiAutoCompleteTextView text1;
String[] languages={"Android ","java","IOS","SQL","JDBC","Web services"};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
text=(AutoCompleteTextView)findViewById(R.id.autoCompleteTextView1);
text1=(MultiAutoCompleteTextView)findViewById(R.id.multiAutoCompleteTextView1);
ArrayAdapter adapter = new
ArrayAdapter(this,android.R.layout.simple_list_item_1,languages);
text.setAdapter(adapter);
text.setThreshold(1);
text1.setAdapter(adapter);
text1.setTokenizer(new MultiAutoCompleteTextView.CommaTokenizer());
}
}
Voici le contenu de activity_main.xml
Ici abc indique le logo de tutorialspoint
<xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:paddingBottom="@dimen/activity_vertical_margin"
tools:context=".MainActivity">
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Android Auto Complete"
android:id="@+id/textView"
android:textSize="30dp"
android:layout_alignParentTop="true"
android:layout_alignParentRight="true"
android:layout_alignParentEnd="true" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Tutorialspoint"
android:id="@+id/textView2"
android:textColor="#ff3eff0f"
android:textSize="35dp"
android:layout_below="@+id/textView"
android:layout_centerHorizontal="true" />
<ImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/imageView"
android:src="@drawable/logo"
android:layout_below="@+id/textView2"
android:layout_alignLeft="@+id/textView2"
android:layout_alignStart="@+id/textView2"
android:layout_alignRight="@+id/textView2"
android:layout_alignEnd="@+id/textView2" />
<AutoCompleteTextView
android:id="@+id/autoCompleteTextView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:ems="10"
android:layout_below="@+id/imageView"
android:layout_alignLeft="@+id/imageView"
android:layout_alignStart="@+id/imageView"
android:layout_marginTop="72dp"
android:hint="AutoComplete TextView">
<requestFocus />
</AutoCompleteTextView>
<MultiAutoCompleteTextView
android:id="@+id/multiAutoCompleteTextView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:ems="10"
android:layout_below="@+id/autoCompleteTextView1"
android:layout_alignLeft="@+id/autoCompleteTextView1"
android:layout_alignStart="@+id/autoCompleteTextView1"
android:hint="Multi Auto Complete " />
</RelativeLayout>
Voici le contenu de Strings.xml
<resources>
<string name="app_name">My Application</string>
</resources>
Voici le contenu de AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.example.sairamkrishna.myapplication" >
<application
android:allowBackup="true"
android:icon="@drawable/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme" >
<activity
android:name="com.example.sairamkrishna.myapplication.MainActivity"
android:label="@string/app_name" >
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
Essayons d'exécuter votre application. Je suppose que vous avez connecté votre AVD lors de la configuration de l'environnement. Pour exécuter l'application à partir d'Android Studio, ouvrez l'un des fichiers d'activité de votre projet et cliquez sur l'
Maintenant, tapez simplement dans la vue texte pour voir les suggestions des langues. Comme je viens de taper une lettre qui sont commea, et cela me montre une suggestion de langage.
Le multiAutoCompleteTextView montre des suggestions non seulement pour un mot mais pour le texte entier. Comme après avoir écrit le premier mot, lorsque je commence à écrire le deuxième mot, il me montre les suggestions. Cela peut être montré dans l'image ci-dessous.