本文是作者原创文章,欢迎转载,请注明出处 from:@Eric_Lai

ListView控件

简单用法

ListView是用来展示大量数据的,所有我们首先要有数据,其次数组里面的数据不能够直接地传递给控件,需要使用配适器。下面看一个简单的例子:

public class MainActivity extends Activity{
	//定义一个数组,里面假设有某种数据(比如各种水果)
	private String[] data = {...};
    protected void onCreate(Bundle saveInstanceState){
    	super.onCreate();
        setContentView(R.layout.activity_main);
        ArrayAdapter<String> adapter = new ArrayAdapter<String>(MainActivity.this, android.R.layout.simple_list_item_1, data);
        listView listView = (ListView) findViewById(R.id.list_view);
        listView.setAdapter(adapter);
    }
}

在这里,需要注意的是配适器的构造函数,这里接受三个参数:

构造完成之后,调用setAdapter()方法将这个配适器和listView联系起来即可。

定制一个属于你自己的ListView界面

按照上面的代码,我们调用了内置的一种子布局,该布局只能显示一个文本,比较单调。如果我门需要自己写一个比较特别的界面我们应该怎么做呢。下面我们来一起做一个demo 首先,为了方便以后的操作,需要先建一个实体类:

public class Fruit(){
	private String name;
    private int imageId;
    public Fruit(String name, int imageId){
    	this.name = name;
        this.imageId = imageId;
    }
    public string getName(){
    	return name;
    }
    public int getImageId(){
    	return imageId;
    }
}

然后是重新定义一个有自己特色的子布局(这里我定义成一张图片和一个文本):

	<LinearLayout xmlns:android="?????????"
      android:layout_width="match_parent"
      android:layout_height="match_parent">
      
      <ImageView
        android:id="@+id/fruit_image"
        android:layout_width="wrap_parent"
        android:layout_height="wrap_parent />
        
      <TextView
        android:id="@+id/fruit_name"
        android:layout_width="wrap_parent"
        android:layout_height="wrap_parent 
        android:layout_marginLeft="10dip" />
        
    </LinearLayout>

最后,我们需要创建一个自定义的配适器,而不是使用原来的ArrayAdapter了:

public class FruitAdapter extends Adapter(){
	private int resourceId;
    
    public FruitAdapter(Context context, int textVitwResourceId, List<Fruit> object){
    super(context, textVitwResourceId, object);
    resuorceId = textVitwResourceId;
    }
    
    //这个方法在每个子项被滚动到屏幕内部时调用
    @Override
    public View getView(int prosition, View covertView, ViewGroup parent){
    Fruit fruit = getItem(position);
    View view;
    if(covertView == null){
    view = LayoutInflater.from(getContext()).inflate(resourceId,null);
    ViewHolder viewHolder = new ViewHolder();
    viewHolder.fruitImage = (ImageView) view.findViewById(R.id.fruit_iamge);
    viewHolder.fruitName = (TextView) view.findViewById(R.id.fruit_name);
    //将viewHolder存储在view当中
    view.setTag(viewHolder);
    }else{
    	view = converView;
        //重新获取viewHolder
        viewHolder = (ViewHolder) view.getTag();
        }
    viewHolder.fruitImage.setImageResource(fruit.getImageId);
    viewHolder.fruitName.setText(furit.getName());
    }
    return view;
    
    class ViewHolder(){
    	ImageView fruitImage;
        TextView furitName;
    }
}

从上面代码可以看到,FruitAdapter重写了父类的一组构造函数,将上下文,子项布局id和数据传递了进去。另外,又重写了getView()方法,这个方法在每个子项被滚动到屏幕内时被调用。在这个方法当中,首先通过getItem()方法得到当前项的Fruit实例,然后使用LayoutInflater来为这个子项加载布局。 为了不用每次都将布局重新加载一次,这里使用了第二个参数covertView来提高性能,这里代码的意思是先判断convertView是否为空,如果是就调用LayoutInflater加载,否则就直接重用covertView(因为每一个子项的布局都是一样的)。很明显,代码当中还有一个ViewHolder,这个类是用来缓存图片和文本控件实例的。不用每一次都用findViewById来进行查找,以达到提升效率的目的。 这里往后面的代码就都比较好理解了,适用图片和文本的实例,分别调用相关函数来设置显示的图片和文本。

ListView的点击事件

控件的存在时为了进行UI交互,如果一个ListView的子项不能点击的话,这个控件其实并没有什么作用。因此,我们还需要学习一下怎么响应点击事件。 为了方便,我就直接食用一开始的代码进行修改了:

public class MainActivity extends activity{
	
    private List<Fruit> furitList = new ArrayList<Fruit>();
    
    @Override
    protected void onCreate(Bundle saveInstanceState){
    	super.onCreate();
        setContentView(R.layout.activity_main);
        //自己写的一个初始化方法
        initFruits();
        ArrayAdapter<String> adapter = new ArrayAdapter<String>(MainActivity.this,android.R.layout.simple_list_item_1fruitList);
        listView listView = (ListView) findViewById(R.id.list_view);
        listView.setAdapter(adapter);
        listview.setOnItemClickListener(new OnItemClickListener(){
        	
            @Override
            public void onItemClick(AdapterView<?>parent, View view, int position, long id){
            //通过position可以知道用户点击了哪一个item
            Fruit fruit = fruitlist.get(positon);
            Toast.makeText(MainActivity.this,  fruit.getName(), Toast.LENGTH_SHORT).show();
            }
        });
    }
}

好了,关于ListView的内容就先这么多。