listview布局知识,它将帮助我们根据自己所需的样子设置每个表象组件的模样,并且能够响应点击事件。
首先应该在xml文件中写入listview控件,代码如下:
<ListView
android:id="@+id/lvNews"
android:layout_width="match_parent"
android:layout_height="match_parent"
>
</ListView>
我们使用adapater作为适配器,可以改变列表项组件的模样。新建一个包,其中建立一个class继承BaseAdapter
public class NewsAdapter extend BaseAdapter{
private Context context;//上下文对象
public NewsAdapter(Context context){
this.context = contetx;//通过构造方法传进上下文对象
}
}
我们需要对列表项布局,所以需要再写一个xml文件,对该组件进行布局
<ImaeView
android:id="@+id/ivPic"
android:layout_width="42dp"
android:layout_height="42dp"
android:src="@drawable/ic_launcher"
/>
<TextView
android:id="@+id/tvTitle"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_toRightOf="@id/ivPic"
/>
<TextView
android:id="@+id/tvDesc"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@id/tvTitle"
android:layout_toRightOf="@id/ivPic"/>
当我们继承了BaseAdapter后,将会有四个函数需要我们重写,分别是:
//改函数是返回列表项的个数
public int getCount(){
return 0;
}
public Object getItem(int position){
return null;
}
public long getItemId(int position){
return 0;
}
//下面这个函数就是对我们列表项布局的函数
public View getView(int position, View convertView,ViewGroup parent){
if(convertView == null){
convertView = LayoutInflater.from(context).inflate(R.layout.xxx,null);//该处的xxx就是你对列表项写的xml文件名字
}
TextView tvTitle = (TextView) convertView.findViewById(R.id.tvTitle);
TextView tvDesc = (TextView) convertView.findViewById(R.id.tvDesc);
ImageView ivPic = (ImageView) convertView.findViewById(R.id.ivPic);
return convertView;
}
当写好上面的代码之后,我们就可以在activity中使用listview了
private ListView lzz;
private NewsAdapter adapter;
//在onCreate中加入
lzz = (ListView) findViewById(R.id.lvNews);
adapter = new NewsAdapter(this);//初始化adapter
lvNews.setAdapter(adapter);//将adapter传入listview
以上就是listview的基本操作