Android
Lijstweergave
Zoeken…
Invoering
ListView is een viewgroup die verschillende items uit een gegevensbron zoals een array of database groepeert en deze in een lijst met schuifbare lijsten weergeeft. Gegevens worden verbonden met lijstweergave met behulp van een adapterklasse.
Opmerkingen
ListView
is een weergavegroep die een lijst met schuifbare items weergeeft.
De lijstitems worden automatisch in de lijst ingevoegd met behulp van een Adapter
die inhoud uit een bron zoals een array- of databasequery haalt en elk itemresultaat omzet in een weergave die in de lijst wordt geplaatst.
Wanneer de inhoud voor uw lay-out dynamisch is of niet vooraf is bepaald, kunt u een lay-out gebruiken die AdapterView
in subklassen AdapterView
om de lay-out te vullen met weergaven tijdens runtime. Een subklasse van de klasse AdapterView
gebruikt een Adapter
om gegevens aan de lay-out te binden.
Voordat u de ListView
, moet u ook de RecyclerView
voorbeelden controleren.
Filteren met 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);
}
});
Stel dat uw zoekopdracht wordt uitgevoerd telkens wanneer de gebruiker in een 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) {
}
});
Aangepaste array-adapter
Standaard maakt de klasse ArrayAdapter een weergave voor elk arrayitem door aan elk item toString()
aan te roepen en de inhoud in een TextView te plaatsen.
Als u een complexe weergave voor elk item wilt maken (als u bijvoorbeeld een ImageView voor elk arrayitem wilt), breidt u de klasse ArrayAdapter uit en overschrijft u de methode getView()
om het gewenste type weergave voor elk item te retourneren.
Bijvoorbeeld:
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);
}
}
}
Een eenvoudige lijstweergave met een ArrayAdapter
Standaard maakt de ArrayAdapter
een weergave voor elk ArrayAdapter
door aan elk item toString()
aan te roepen en de inhoud in een TextView
.
Voorbeeld:
ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,
android.R.layout.simple_list_item_1, myStringArray);
waarbij android.R.layout.simple_list_item_1
de lay-out is die een TextView
voor elke tekenreeks in de array bevat.
setAdapter()
vervolgens setAdapter()
op uw ListView
:
ListView listView = (ListView) findViewById(R.id.listview);
listView.setAdapter(adapter);
Als u iets anders dan TextViews wilt gebruiken voor de arrayweergave, bijvoorbeeld ImageViews, of als u gegevens naast de resultaten van getView(int, View, ViewGroup)
toString()
vult u de views, vervangt u getView(int, View, ViewGroup)
om het gewenste type view te retourneren. Bekijk dit voorbeeld .