Android EditText dengan TextWatcher

Android EditText adalah subkelas dari TextView. EditText digunakan untuk memasukkan dan memodifikasi teks. Saat menggunakan lebar EditText, kita harus menentukan jenis inputnya di properti inputType edittext yang mengkonfigurasi keyboard sesuai dengan input.

EditText menggunakan antarmuka TextWatcher untuk menonton perubahan yang dibuat melalui EditText. Untuk melakukan ini, EditText memanggil metode addTextChangedListener().

Metode TextWatcher

  • beforeTextChanged(CharSequence arg0, int arg1, int arg2, int arg3): Ini dijalankan sebelum membuat perubahan apa pun melalui EditText.
  • onTextChanged(CharSequence cs, int arg1, int arg2, int arg3): Ini dijalankan saat membuat perubahan apa pun melalui EditText.
  • afterTextChanged(Editable arg0): Ini dijalankan setelah perubahan yang dibuat melalui EditText.

Contoh EditText dengan TextWatcher()

Dalam contoh ini, kita akan menerapkan EditText dengan TextWatcher untuk mencari data dari ListView.

* Main Activity

Buat file activity_main.xml di folder layout yang berisi EditText dan ListView.

File : activity_main.xml

<?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:paddingBottom="@dimen/activity_vertical_margin"  
    android:paddingLeft="@dimen/activity_horizontal_margin"  
    android:paddingRight="@dimen/activity_horizontal_margin"  
    android:paddingTop="@dimen/activity_vertical_margin"  
    tools:context="com.example.test.searchfromlistview.MainActivity">  
 
    <EditText  
        android:layout_width="wrap_content"  
        android:layout_height="wrap_content"  
        android:id="@+id/editText"  
        android:inputType="text"  
        android:layout_alignParentTop="true"  
        android:layout_alignParentLeft="true"  
        android:layout_alignParentStart="true"  
        android:layout_alignParentRight="true"  
        android:layout_alignParentEnd="true" />  
 
    <ListView  
        android:layout_width="wrap_content"  
        android:layout_height="wrap_content"  
        android:id="@+id/listView"  
        android:layout_below="@+id/editText"  
        android:layout_alignParentLeft="true"  
        android:layout_alignParentStart="true" />  
</RelativeLayout>  


Buat file lain list_item.xml dalam folder layout yang berisi data ListView.

File : list_item.xml

<?xml version="1.0" encoding="utf-8"?>  
<LinearLayout  
    xmlns:android="http://schemas.android.com/apk/res/android"  
    android:orientation="vertical"  
    android:layout_width="match_parent"  
    android:layout_height="match_parent">  
 
<TextView android:id="@+id/product_name"  
    android:layout_width="fill_parent"  
    android:layout_height="wrap_content"  
    android:padding="10dip"  
    android:textSize="16dip"  
    android:textStyle="bold"/>  
</LinearLayout>  


* Activity class

package com.example.test.searchfromlistview;  
 
import android.os.Bundle;  
import android.text.Editable;  
import android.text.TextWatcher;  
import android.widget.ArrayAdapter;  
import android.widget.EditText;  
import android.widget.ListView;  
import android.support.v7.app.AppCompatActivity;  
import android.widget.Toast;  
 
public class MainActivity extends AppCompatActivity {  
 
    private ListView lv;  
    private EditText editText;  
    private ArrayAdapter<String> adapter;  
 
    private String products[] = {"Apple", "Banana","Pinapple", "Orange", "Papaya", "Melon",  
            "Grapes", "Water Melon","Lychee", "Guava", "Mango", "Kivi"};  
    @Override  
    protected void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
        setContentView(R.layout.activity_main);  
 
        lv = (ListView) findViewById(R.id.listView);  
        editText = (EditText) findViewById(R.id.editText);  
        adapter = new ArrayAdapter<String>(this, R.layout.list_item, R.id.product_name, products);  
        lv.setAdapter(adapter);  
 
        editText.addTextChangedListener(new TextWatcher() {  
 
            @Override  
            public void onTextChanged(CharSequence cs, int arg1, int arg2, int arg3) {  
                adapter.getFilter().filter(cs);  
            }  
 
            @Override  
            public void beforeTextChanged(CharSequence arg0, int arg1, int arg2, int arg3) {  
                Toast.makeText(getApplicationContext(),"before text change",Toast.LENGTH_LONG).show();  
            }  
 
            @Override  
            public void afterTextChanged(Editable arg0) {  
                Toast.makeText(getApplicationContext(),"after text change",Toast.LENGTH_LONG).show();  
            }  
        });  
    }  
}  


Output :

Android EditText dengan TextWatcher


Berlangganan update artikel terbaru via email:

0 Response to "Android EditText dengan TextWatcher"

Posting Komentar

Iklan Atas Artikel

Iklan Bawah Artikel