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'

icône Exécuter dans la barre d'outils. Le studio Android installera cette application dans votre AVD et votre AVD affichera l'écran suivant.

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.