Android
ListView
Recherche…
Introduction
ListView est un groupe de vues qui regroupe plusieurs éléments d'une source de données telle qu'un tableau ou une base de données et les affiche dans une liste déroulante. Les données sont liées à listview à l'aide d'une classe d'adaptateur.
Remarques
ListView
est un groupe de vues qui affiche une liste d'éléments défilables.
Les éléments de la liste sont automatiquement insérés dans la liste à l'aide d'un Adapter
qui extrait le contenu d'une source telle qu'un tableau ou une requête de base de données et convertit chaque résultat d'élément en une vue placée dans la liste.
Lorsque le contenu de votre mise en page est dynamique ou non prédéterminé, vous pouvez utiliser une présentation qui sous-classe AdapterView
pour remplir la présentation avec des vues à l'exécution. Une sous-classe de la classe AdapterView
utilise un Adapter
pour lier des données à sa disposition.
Avant d'utiliser ListView
vous devriez également vérifier les exemples RecyclerView
.
Filtrage avec CursorAdapter
// Get the reference to your ListView
ListView listResults = (ListView) findViewById(R.id.listResults);
// Set its adapter
listResults.setAdapter(adapter);
// Enable filtering in ListView
listResults.setTextFilterEnabled(true);
// Prepare your adapter for filtering
adapter.setFilterQueryProvider(new FilterQueryProvider() {
@Override
public Cursor runQuery(CharSequence constraint) {
// in real life, do something more secure than concatenation
// but it will depend on your schema
// This is the query that will run on filtering
String query = "SELECT _ID as _id, name FROM MYTABLE "
+ "where name like '%" + constraint + "%' "
+ "ORDER BY NAME ASC";
return db.rawQuery(query, null);
}
});
Supposons que votre requête s'exécute à chaque fois que l'utilisateur tape dans un EditText
:
EditText queryText = (EditText) findViewById(R.id.textQuery);
queryText.addTextChangedListener(new TextWatcher() {
@Override
public void beforeTextChanged(final CharSequence s, final int start, final int count, final int after) {
}
@Override
public void onTextChanged(final CharSequence s, final int start, final int before, final int count) {
// This is the filter in action
adapter.getFilter().filter(s.toString());
// Don't forget to notify the adapter
adapter.notifyDataSetChanged();
}
@Override
public void afterTextChanged(final Editable s) {
}
});
Custom ArrayAdapter
Par défaut, la classe ArrayAdapter crée une vue pour chaque élément du tableau en appelant toString()
sur chaque élément et en plaçant le contenu dans un TextView.
Pour créer une vue complexe pour chaque élément (par exemple, si vous voulez un ImageView pour chaque élément de tableau), étendez la classe ArrayAdapter et remplacez la méthode getView()
pour renvoyer le type de vue souhaité pour chaque élément.
Par exemple:
public class MyAdapter extends ArrayAdapter<YourClassData>{
private LayoutInflater inflater;
public MyAdapter (Context context, List<YourClassData> data){
super(context, 0, data);
inflater = LayoutInflater.from(context);
}
@Override
public long getItemId(int position)
{
//It is just an example
YourClassData data = (YourClassData) getItem(position);
return data.ID;
}
@Override
public View getView(int position, View view, ViewGroup parent)
{
ViewHolder viewHolder;
if (view == null) {
view = inflater.inflate(R.layout.custom_row_layout_design, null);
// Do some initialization
//Retrieve the view on the item layout and set the value.
viewHolder = new ViewHolder(view);
view.setTag(viewHolder);
}
else {
viewHolder = (ViewHolder) view.getTag();
}
//Retrieve your object
YourClassData data = (YourClassData) getItem(position);
viewHolder.txt.setTypeface(m_Font);
viewHolder.txt.setText(data.text);
viewHolder.img.setImageBitmap(BitmapFactory.decodeFile(data.imageAddr));
return view;
}
private class ViewHolder
{
private final TextView txt;
private final ImageView img;
private ViewHolder(View view)
{
txt = (TextView) view.findViewById(R.id.txt);
img = (ImageView) view.findViewById(R.id.img);
}
}
}
Un ListView de base avec un ArrayAdapter
Par défaut, ArrayAdapter
crée une vue pour chaque élément du tableau en appelant toString()
sur chaque élément et en plaçant le contenu dans un TextView
.
Exemple:
ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,
android.R.layout.simple_list_item_1, myStringArray);
où android.R.layout.simple_list_item_1
est la mise en page qui contient un TextView
pour chaque chaîne du tableau.
Ensuite, appelez simplement setAdapter()
sur votre ListView
:
ListView listView = (ListView) findViewById(R.id.listview);
listView.setAdapter(adapter);
Pour utiliser autre chose que TextViews pour l'affichage du tableau, par exemple, ImageViews, ou pour que certaines données en dehors des résultats de toString()
remplissent les vues, substituez getView(int, View, ViewGroup)
pour renvoyer le type de vue souhaité. Vérifiez cet exemple .