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 .



Modified text is an extract of the original Stack Overflow Documentation
Licentie onder CC BY-SA 3.0
Niet aangesloten bij Stack Overflow