昨晚学习了徐大神的关于BaseAdapter的讲解,让我受益匪浅特来博客留下印记
说到baseadapter大家一定都不陌生,下面这张图就展示了数据、listview、baseadapter
之间的关系。我们可以看出baseadapter是用来将不同数据,经过转化使其成为listview能够显示的格式
,再提供给listview展示的数据适配器(listview对展示的数据是有要求的)
想要更详细的了解baseadapter请自行百度吧。
下面就用一个例子描述下baseadapter的具体用法
我们可以创建一个MyAdapter 继承BaseAdapter
实现其四个基本方法:
// 获取数据量
@Override
public int getCount() {
return null;
} // 获取对应ID项对应的Item
@Override
public Object getItem(int position) {
return null;
} // 获取对应项ID
@Override
public long getItemId(int position) {
return null;
}
以上三个方法比较简单,功能明确,也有注释
下面介绍getview方法:
@Override
public View getView(int position, View convertView, ViewGroup parent) {}
用于获取每一个item的显示内容
参数一:position 是指当前dataset的位置,通过getCount和getItem来使用。
参数二:conertView 是指可以重用的视图,即刚刚出队的视图。
参数三:parent应该就是list。
看的云里雾里是不是?!这就对了不如直接上手试试
public class MyAdapter extends BaseAdapter { private LayoutInflater mLayoutInflater;
// 映射数据
private List<ItemBean> mDataList;
private long mSumTime; public MyAdapter(Context context, List<ItemBean> list) {
mLayoutInflater = LayoutInflater.from(context);
mDataList = list;
} // 获取数据量
@Override
public int getCount() {
return mDataList.size();
} // 获取对应ID项对应的Item
@Override
public Object getItem(int position) {
return mDataList.get(position);
} // 获取对应项ID
@Override
public long getItemId(int position) {
return position;
} @Override
public View getView(int position, View convertView, ViewGroup parent) { // 文艺式 >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
//获取纳秒时间 更加精确
ViewHolder holder = null;
if (convertView == null) {
holder = new ViewHolder();
//由于我们只需要将XML转化为View,并不涉及到具体的布局,所以第二个参数通常设置为null
convertView = mLayoutInflater.inflate(R.layout.tasklistitem, null);
holder.title = (TextView) convertView.findViewById(R.id.task_title);
holder.explain = (TextView) convertView.findViewById(R.id.task_explain);
holder.price = (TextView) convertView.findViewById(R.id.task_price);
holder.faraway = (TextView) convertView.findViewById(R.id.task_distance);
convertView.setTag(holder);
} else {
holder = (ViewHolder) convertView.getTag();
}
// 取出bean对象
ItemBean bean = mDataList.get(position);
// 设置控件的数据
holder.title.setText(bean.itemTitle);
holder.explain.setText(bean.itemContent);
holder.price.setText(bean.itemPrice);
holder.faraway.setText(bean.itemFaraway);
// 输出每次getView消耗的时间和
Log.d("xys", String.valueOf(mSumTime));
return convertView;
// 文艺式 >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>16325820
} // ViewHolder用于缓存控件
class ViewHolder{
public TextView title;//标题
public TextView explain;//说明
public TextView price;//价格
public TextView faraway;//距离
}
}
创建完了MyAdapter
在layout下添加一个布局文件(如果是自己新创建的app测试一下的话可以main.xml)
名字随意这里就叫
list.xml 了
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" android:background="#f0f0f0"> <TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="@string/hello" /> <ListView
android:id="@+id/xListView"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:cacheColorHint="#00000000"> </ListView> </LinearLayout>
创建ItemBean.java
public class ItemBean { public int itemImageResid;
public String itemTitle;
public String itemContent; public ItemBean(int itemImageResid, String itemTitle, String itemContent) {
this.itemImageResid = itemImageResid;
this.itemTitle = itemTitle;
this.itemContent = itemContent;
}
}
为list创建对应的java文件
在onCreat方法中插入如下代码
//绑定数据
ListView listView = (ListView) findViewById(R.id.lv_main);
List<ItemBean> dataList = new ArrayList<>();
// 创建假数据
for (int i = 0; i < 20; i++) {
dataList.add(new ItemBean(
R.mipmap.ic_launcher,
"我是标题" + i,
"我是内容" + i));
}
// 设置适配器
listView.setAdapter(new MyAdapter(this, dataList));
完成上面的操作就可以去看看运行效果了(如果不是新创建的app还要先到androidMainfest中注册下新页面)