Buscar..


Introducción

ListView es un grupo de vista que agrupa varios elementos de una fuente de datos como una matriz o base de datos y los muestra en una lista con capacidad de desplazamiento. Los datos se enlazan con listview usando una clase de adaptador.

Observaciones

ListView es un grupo de vistas que muestra una lista de elementos desplazables.
Los elementos de la lista se insertan automáticamente en la lista mediante un Adapter que extrae el contenido de una fuente, como una matriz o una consulta de base de datos, y convierte el resultado de cada elemento en una vista que se coloca en la lista.

Cuando el contenido de su diseño es dinámico o no está predeterminado, puede utilizar un diseño que subclases AdapterView para rellenar el diseño con vistas en tiempo de ejecución. Una subclase de la clase AdapterView usa un Adapter para enlazar datos a su diseño.

Antes de usar el ListView , también debe verificar los ejemplos de RecyclerView .

Filtrado con 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);
     }
});

Digamos que su consulta se ejecutará cada vez que el usuario EditText 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) {

        }
    });

ArrayAdapter personalizado

De forma predeterminada, la clase ArrayAdapter crea una vista para cada elemento de la matriz llamando a toString() en cada elemento y colocando el contenido en un TextView.

Para crear una vista compleja para cada elemento (por ejemplo, si desea un ImageView para cada elemento de la matriz), extienda la clase ArrayAdapter y anule el método getView() para devolver el tipo de vista que desea para cada elemento.

Por ejemplo:

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 básico con un ArrayAdapter

De forma predeterminada, ArrayAdapter crea una vista para cada elemento de la matriz llamando a toString() en cada elemento y colocando el contenido en un TextView .

Ejemplo:

ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,
        android.R.layout.simple_list_item_1, myStringArray);

donde android.R.layout.simple_list_item_1 es el diseño que contiene un TextView para cada cadena en la matriz.

Luego simplemente llame a setAdapter() en su ListView :

ListView listView = (ListView) findViewById(R.id.listview);
listView.setAdapter(adapter);

Para usar algo que no sea TextViews para la visualización de matriz, por ejemplo, ImageViews, o para que algunos de los datos, además de toString() , llenen las vistas, anule getView(int, View, ViewGroup) para devolver el tipo de vista que desea. Mira este ejemplo .



Modified text is an extract of the original Stack Overflow Documentation
Licenciado bajo CC BY-SA 3.0
No afiliado a Stack Overflow