电子商务加盟网站建设,中国企业公司,企业网页建设公司联系电话,仿一个展示型网站多少钱Adapter基础讲解
本节引言
从本节开始我们要讲的UI控件都是跟Adapter(适配器)打交道的#xff0c;了解并学会使用这个Adapter很重要#xff0c; Adapter是用来帮助填充数据的中间桥梁#xff0c;简单点说就是#xff1a;将各种数据以合适的形式显示到view上,提供 给用户看…Adapter基础讲解
本节引言
从本节开始我们要讲的UI控件都是跟Adapter(适配器)打交道的了解并学会使用这个Adapter很重要 Adapter是用来帮助填充数据的中间桥梁简单点说就是将各种数据以合适的形式显示到view上,提供 给用户看
1.MVC模式的简单理解
在开始学习Adapter之前我们要来了解下这个MVC模式概念 举个例子大型的商业程序通常由多人一同开发完成,比如有人负责操作接口的规划与设计, 有人负责程序代码的编写如果要能够做到程序项目的分工就必须在程序的结构上做适合的安排 ,如果,接口设计与修改都涉及到程序代码的改变的话,那么两者的分工就会造成执行上的困难 良好的程序架构师将整个程序项目划分为如图的三个部分: 关系图解析
Model通常可以理解为数据,负责执行程序的核心运算与判断逻辑,通过view获得用户 输入的数据,然后根据从数据库查询相关的信息,最后进行运算和判断,再将得到的结果交给view来显示view:用户的操作接口,说白了就是GUI,应该使用哪种接口组件,组件间的排列位置与顺序都需要设计Controller:控制器,作为model与view之间的枢纽,负责控制程序的执行流程以及对象之间的一个互动 而这个Adapter则是中间的这个Controller的部分 Model(数据) — Controller(以什么方式显示到)— View(用户界面) 这就是简单MVC组件的简单理解
2.Adapter概念解析
首先我们来看看他的继承结构图 上面就是Adapter以及继承结构图了接着我们介绍一下实际开发中还用到的几个Adapter吧
BaseAdapter抽象类实际开发中我们会继承这个类并且重写相关方法用得最多的一个AdapterArrayAdapter支持泛型操作最简单的一个Adapter只能展现一行文字~SimpleAdapter同样具有良好扩展性的一个Adapter可以自定义多种效果SimpleCursorAdapter用于显示简单文本类型的listView一般在数据库那里会用到不过有点过时 不推荐使用
其实一个BaseAdapter就够玩的了至于其他的实际开发中用得不多后面用到在讲解~
3.代码示例
好的多说无益写代码最实际接下来我们来写几个简单的Adapter实例 帮助我们了解Adapter给我们带来的便利另外因为Adapter需要结合ListView GridView等等控件讲解一些高级一点的用法我们都放在ListView那里讲 这里就简单演示下效果另外这里用到的控件是ListView下一节就会讲解 现在看不懂也没关系
1ArrayAdapter使用示例
运行效果图 代码实现
public class MainActivity extends AppCompatActivity {Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);//要显示的数据String[] strs {基神,B神,翔神,曹神,J神};//创建ArrayAdapterArrayAdapterString adapter new ArrayAdapterString(this,android.R.layout.simple_expandable_list_item_1,strs);//获取ListView对象通过调用setAdapter方法为ListView设置Adapter设置适配器ListView list_test (ListView) findViewById(R.id.list_test);list_test.setAdapter(adapter);}
}一些相关的东西
1.除了通过数组外我们还可以写到一个数组资源文件中
比如在res\values下创建一个数组资源的xml文件arrays.xml
?xml version1.0 encodingutf-8?
resources string-array namemyarray item语文/item item数学/item item英语/item /string-array
/resources接着布局的listview属性设置下这个列表项
ListView android:idid/list_test android:layout_heightmatch_parent android:layout_widthmatch_parent android:entriesarray/myarray/就可以了~
当然我们也可以在Java代码中这样写
ArrayAdapterCharSequence adapter ArrayAdapter.createFromResource(this,R.array.myarray,android.R.layout.simple_list_item_multiple_choice );同样也是可以的
2.一开始也说了这个ArrayAdapter支持泛型那么集合必不可少啦比如这样写
ListString data new ArrayListString();
data.add(基神);
data.add(B神)
ArrayAdapterString adapter new ArrayAdapterString(this,android.R.layout.simple_expandable_list_item_1,data);就可以了~
3.我们看到了在实例化ArrayAdapter的第二个参数 android.R.layout.simple_expandable_list_item_1 其实这些是系统给我们提供好的一些ListView模板有下面几种
simple_list_item_1 : 单独一行的文本框 simple_list_item_2 : 两个文本框组成 simple_list_item_checked : 每项都是由一个已选中的列表项 simple_list_item_multiple_choice : 都带有一个复选框 simple_list_item_single_choice : 都带有一个单选钮
2SimpleAdapter使用示例
SimpleAdapter简单的Adapter看似简单功能强大下面我们来写个稍微复杂一点的列表 布局吧
代码实现
先来编写一个列表项目每一项的布局
list_item.xml
?xml version1.0 encodingutf-8?
LinearLayout xmlns:androidhttp://schemas.android.com/apk/res/androidandroid:layout_widthmatch_parentandroid:layout_heightmatch_parentandroid:orientationhorizontal!-- 定义一个用于显示头像的ImageView --ImageViewandroid:idid/imgtouandroid:layout_width64dpandroid:layout_height64dpandroid:baselineAlignBottomtrueandroid:paddingLeft8dp /!-- 定义一个竖直方向的LinearLayout,把QQ呢称与说说的文本框设置出来 --LinearLayoutandroid:layout_widthmatch_parentandroid:layout_heightwrap_contentandroid:orientationverticalTextViewandroid:idid/nameandroid:layout_widthwrap_contentandroid:layout_heightwrap_contentandroid:paddingLeft8dpandroid:textColor#1D1D1Candroid:textSize20sp /TextViewandroid:idid/saysandroid:layout_widthwrap_contentandroid:layout_heightwrap_contentandroid:paddingLeft8pxandroid:textColor#B4B4B9android:textSize14sp //LinearLayout/LinearLayout接下来是MainActivity.java:
public class MainActivity extends AppCompatActivity {private String[] names new String[]{B神, 基神, 曹神};private String[] says new String[]{无形被黑最为致命, 大神好厉害~, 我将带头日狗~};private int[] imgIds new int[]{R.mipmap.head_icon1, R.mipmap.head_icon2, R.mipmap.head_icon3};Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);ListMapString, Object listitem new ArrayListMapString, Object();for (int i 0; i names.length; i) {MapString, Object showitem new HashMapString, Object();showitem.put(touxiang, imgIds[i]);showitem.put(name, names[i]);showitem.put(says, says[i]);listitem.add(showitem);}//创建一个simpleAdapterSimpleAdapter myAdapter new SimpleAdapter(getApplicationContext(), listitem, R.layout.list_item, new String[]{touxiang, name, says}, new int[]{R.id.imgtou, R.id.name, R.id.says});ListView listView (ListView) findViewById(R.id.list_test);listView.setAdapter(myAdapter);}
}好的上面就是SimpleAdapter的简单用法了有点意思~
3SimpleCursorAdapter使用示例
虽然这东西过时了不过对于不怎么会SQLite的初学者来说用起来还是蛮方便的 记得前面我们学ContentProivder写过的读取联系人的例子么之前是通过打印Log的 方式显示出来现在我们通过这个SimpleCursorAdapter把它显示到ListView上
实现效果图 代码实现
先写下listView每个item的布局
list_item.xml:
?xml version1.0 encodingutf-8?
LinearLayout xmlns:androidhttp://schemas.android.com/apk/res/androidandroid:layout_widthmatch_parentandroid:layout_heightmatch_parentandroid:orientationhorizontalTextViewandroid:idid/list_nameandroid:layout_width0dpandroid:layout_height64dpandroid:layout_weight1android:gravitycenterandroid:text小猪android:textColor#0000FFandroid:textSize18sp /TextViewandroid:idid/list_phoneandroid:layout_width0dpandroid:layout_height64dpandroid:layout_weight1android:gravitycenterandroid:text13798989898android:textColor#EA5C4Dandroid:textSize18sp //LinearLayout接着activity_main布局和前面的一样就是简单的ListView然后是
MainActivity.java:
public class MainActivity extends AppCompatActivity {Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);ListView list_test (ListView) findViewById(R.id.list_test);//读取联系人Cursor cursor getContentResolver().query(ContactsContract.CommonDataKinds.Phone.CONTENT_URI, null, null, null, null);SimpleCursorAdapter spcAdapter new SimpleCursorAdapter(this,R.layout.list_item,cursor,new String[]{ContactsContract.CommonDataKinds.Phone.DISPLAY_NAME,ContactsContract.CommonDataKinds.Phone.NUMBER},new int[]{R.id.list_name,R.id.list_phone});list_test.setAdapter(spcAdapter);}
}最后AndroidManifest.xml里加个读联系人的权限就可以了
uses-permission android:nameandroid.permission.READ_CONTACTS/一问一答
问就这么简单 ——答是的直接获取到Cursor然后绑定就好了无需你自己再写什么SQL语句 问你说这东西过时了那拿什么来代替 ——答一般的做法是自己重写BaseAdapter获取到数据集合后跟对应的控件进行绑定 问这个SimpleCursorAdapter还有没有要注意的地方 ——答有使用SimpleCursorAdapter的话,绑定的数据库表中一定要有id这个字段, 或者as id;而且在绑定时取出的数据必须包含这个id项,否则的话会报以下错误! java.lang.IllegalArgumentException: column ‘id’ does not exist**
BaseAdapter优化分类
本节引言
上一节中我们学习了如何来使用一个ListView以及自定义一个简单的BaseAdapter我们从代码 中可以看出比较重要的两个方法:getCount()和getView()界面上有多少列就会调用多少次getView 这个时候可能看出一些端倪每次都是新inflate一个View都要进行这个XML的解析这样会 很浪费资源当然几十列或者几百列的列表并不能体现什么问题但假如更多或者布局更加复杂 所以学习ListView的优化很重要而本节针对的是BaseAdapter的优化优化的两点有复用convertView 以及使用ViewHolder重用组件不用每次都findViewById我们具体通过代码来体会吧
1.复用ConvertView
上面也说了界面上有多少个Item那么getView方法就会被调用多少次 我们来看看上一节我们写的getView()部分的代码
Override
public View getView(int position, View convertView, ViewGroup parent) {convertView LayoutInflater.from(mContext).inflate(R.layout.item_list_animal,parent,false);ImageView img_icon (ImageView) convertView.findViewById(R.id.img_icon);TextView txt_aName (TextView) convertView.findViewById(R.id.txt_aName);TextView txt_aSpeak (TextView) convertView.findViewById(R.id.txt_aSpeak);img_icon.setBackgroundResource(mData.get(position).getaIcon());txt_aName.setText(mData.get(position).getaName());txt_aSpeak.setText(mData.get(position).getaSpeak());return convertView;
}是吧inflate()每次都要加载一次xml其实这个convertView是系统提供给我们的可供服用的View 的缓存对象那就坐下判断咯修改下优化后的代码
Override
public View getView(int position, View convertView, ViewGroup parent) {if(convertView null){convertView LayoutInflater.from(mContext).inflate(R.layout.item_list_animal,parent,false);}ImageView img_icon (ImageView) convertView.findViewById(R.id.img_icon);TextView txt_aName (TextView) convertView.findViewById(R.id.txt_aName);TextView txt_aSpeak (TextView) convertView.findViewById(R.id.txt_aSpeak);img_icon.setBackgroundResource(mData.get(position).getaIcon());txt_aName.setText(mData.get(position).getaName());txt_aSpeak.setText(mData.get(position).getaSpeak());return convertView;
}2.ViewHolder重用组件
嘿嘿getView()会被调用多次那么findViewById不一样得调用多次而我们的ListView的Item 一般都是一样的布局我们可以对这里在优化下我们可以自己定义一个ViewHolder类来对这一部分 进行性能优化修改后的代码如下
Override
public View getView(int position, View convertView, ViewGroup parent) {ViewHolder holder null;if(convertView null){convertView LayoutInflater.from(mContext).inflate(R.layout.item_list_animal,parent,false);holder new ViewHolder();holder.img_icon (ImageView) convertView.findViewById(R.id.img_icon);holder.txt_aName (TextView) convertView.findViewById(R.id.txt_aName);holder.txt_aSpeak (TextView) convertView.findViewById(R.id.txt_aSpeak);convertView.setTag(holder); //将Holder存储到convertView中}else{holder (ViewHolder) convertView.getTag();}holder.img_icon.setBackgroundResource(mData.get(position).getaIcon());holder.txt_aName.setText(mData.get(position).getaName());holder.txt_aSpeak.setText(mData.get(position).getaSpeak());return convertView;
}static class ViewHolder{ImageView img_icon;TextView txt_aName;TextView txt_aSpeak;
}没错就是这么简单你以后BaseAdapter照着这个模板写就对了哈哈另外这个修饰ViewHolder的 static关于是否定义成静态跟里面的对象数目是没有关系的加静态是为了在多个地方使用这个 Holder的时候类只需加载一次如果只是使用了一次加不加也没所谓。
构建一个可复用的自定义 BaseAdapter
本节引言
如题本节给大家带来的是构建一个可复用的自定义BaseAdapter我们每每涉及到ListView GridView等其他的Adapter控件都需要自己另外写一个BaseAdapter类这样显得非常麻烦 又比如我们想在一个界面显示两个ListView的话我们也是需要些两个BaseAdapter… 这程序员都是喜欢偷懒的哈这节我们就来写一个可复用的自定义BaseAdapter类~
1.我们一点点开始改
首先我们把上节写的自定义BaseAdapter贴下等下我们就要对他进行升级改造
/*** Created by Jay on 2015/9/21 0021.*/
public class MyAdapter extends BaseAdapter {private Context mContext;private LinkedListData mData;public MyAdapter() {}public MyAdapter(LinkedListData mData, Context mContext) {this.mData mData;this.mContext mContext;}Overridepublic int getCount() {return mData.size();}Overridepublic Object getItem(int position) {return null;}Overridepublic long getItemId(int position) {return position;}Overridepublic View getView(int position, View convertView, ViewGroup parent) {ViewHolder holder null;if (convertView null) {convertView LayoutInflater.from(mContext).inflate(R.layout.item_list, parent, false);holder new ViewHolder();holder.img_icon (ImageView) convertView.findViewById(R.id.img_icon);holder.txt_content (TextView) convertView.findViewById(R.id.txt_content);convertView.setTag(holder);} else {holder (ViewHolder) convertView.getTag();}holder.img_icon.setImageResource(mData.get(position).getImgId());holder.txt_content.setText(mData.get(position).getContent());return convertView;}//添加一个元素public void add(Data data) {if (mData null) {mData new LinkedList();}mData.add(data);notifyDataSetChanged();}//往特定位置添加一个元素public void add(int position,Data data){if (mData null) {mData new LinkedList();}mData.add(position, data);notifyDataSetChanged();}public void remove(Data data) {if(mData ! null) {mData.remove(data);}notifyDataSetChanged();}public void remove(int position) {if(mData ! null) {mData.remove(position);}notifyDataSetChanged();}public void clear() {if(mData ! null) {mData.clear();}notifyDataSetChanged();}private class ViewHolder {ImageView img_icon;TextView txt_content;}}升级1将Entity设置成泛型 好的毕竟我们传递过来的Entitiy实体类可能千奇百怪比如有PersonBookWether等所以我们 将Entity设置成泛型修改后的代码如下
public class MyAdapterT extends BaseAdapter {private Context mContext;private LinkedListT mData;public MyAdapter() {}public MyAdapter(LinkedListT mData, Context mContext) {this.mData mData;this.mContext mContext;}Overridepublic int getCount() {return mData.size();}Overridepublic Object getItem(int position) {return null;}Overridepublic long getItemId(int position) {return position;}Overridepublic View getView(int position, View convertView, ViewGroup parent) {ViewHolder holder null;if (convertView null) {convertView LayoutInflater.from(mContext).inflate(R.layout.item_list, parent, false);holder new ViewHolder();holder.img_icon (ImageView) convertView.findViewById(R.id.img_icon);holder.txt_content (TextView) convertView.findViewById(R.id.txt_content);convertView.setTag(holder);} else {holder (ViewHolder) convertView.getTag();}holder.img_icon.setImageResource(mData.get(position).getImgId());holder.txt_content.setText(mData.get(position).getContent());return convertView;}//添加一个元素public void add(T data) {if (mData null) {mData new LinkedList();}mData.add(data);notifyDataSetChanged();}//往特定位置添加一个元素public void add(int position,T data){if (mData null) {mData new LinkedList();}mData.add(position, data);notifyDataSetChanged();}public void remove(T data) {if(mData ! null) {mData.remove(data);}notifyDataSetChanged();}public void remove(int position) {if(mData ! null) {mData.remove(position);}notifyDataSetChanged();}public void clear() {if(mData ! null) {mData.clear();}notifyDataSetChanged();}private class ViewHolder {ImageView img_icon;TextView txt_content;}}好的上面我们做的事仅仅是将Data类型换成了泛型T
升级2ViewHolder类的升级改造 我们先来看看前面我们的ViewHolder干了什么 答findViewById设置控件状态 下面我们想在完成这个基础上将getView()方法大部分的逻辑写到ViewHolder类里 这个ViewHolder要做的事
定义一个查找控件的方法我们的思路是通过暴露公共的方法调用方法时传递过来 控件id以及设置的内容比如TextView设置文本 public ViewHolder setText(int id, CharSequence text){文本设置}将convertView复用部分搬到这里那就需要传递一个context对象了我们把需要获取 的部分都写到构造方法中写一堆设置方法(public)比如设置文字大小颜色图片背景等
好的接下来我们就来一步步改造我们的ViewHolder类
1相关参数与构造方法
public static class ViewHolder {private SparseArrayView mViews; //存储ListView 的 item中的Viewprivate View item; //存放convertViewprivate int position; //游标private Context context; //Context上下文//构造方法完成相关初始化private ViewHolder(Context context, ViewGroup parent, int layoutRes) {mViews new SparseArray();this.context context;View convertView LayoutInflater.from(context).inflate(layoutRes, parent,false);convertView.setTag(this);item convertView;}ImageView img_icon;TextView txt_content;
}2绑定ViewHolder与Item 在上面的基础上我们再添加一个绑定的方法
//绑定ViewHolder与item
public static ViewHolder bind(Context context, View convertView, ViewGroup parent,int layoutRes, int position) {ViewHolder holder;if(convertView null) {holder new ViewHolder(context, parent, layoutRes);} else {holder (ViewHolder) convertView.getTag();holder.item convertView;}holder.position position;return holder;
}3根据id获取集合中保存的控件
public T extends View T getView(int id) {T t (T) mViews.get(id);if(t null) {t (T) item.findViewById(id);mViews.put(id, t);}return t;
}接着我们再定义一堆暴露出来的方法
/*** 获取当前条目*/
public View getItemView() {return item;
}/*** 获取条目位置*/
public int getItemPosition() {return position;
}/*** 设置文字*/
public ViewHolder setText(int id, CharSequence text) {View view getView(id);if(view instanceof TextView) {((TextView) view).setText(text);}return this;
}/*** 设置图片*/
public ViewHolder setImageResource(int id, int drawableRes) {View view getView(id);if(view instanceof ImageView) {((ImageView) view).setImageResource(drawableRes);} else {view.setBackgroundResource(drawableRes);}return this;
}/*** 设置点击监听*/
public ViewHolder setOnClickListener(int id, View.OnClickListener listener) {getView(id).setOnClickListener(listener);return this;
}/*** 设置可见*/
public ViewHolder setVisibility(int id, int visible) {getView(id).setVisibility(visible);return this;
}/*** 设置标签*/
public ViewHolder setTag(int id, Object obj) {getView(id).setTag(obj);return this;
}//其他方法可自行扩展好的ViewHolder的改造升级完成~
升级3定义一个抽象方法完成ViewHolder与Data数据集的绑定 public abstract void bindView(ViewHolder holder, T obj); 我们创建新的BaseAdapter的时候实现这个方法就好另外别忘了把我们自定义 的BaseAdapter改成abstact抽象的
升级4修改getView()部分的内容 Override public View getView(int position, View convertView, ViewGroup parent) { ViewHolder holder ViewHolder.bind(parent.getContext(), convertView, parent, mLayoutRes , position); bindView(holder,getItem(position)); return holder.getItemView(); }
2.升级完毕我们写代码来体验下
我们要实现的效果图 就是上面有两个列表布局不一样但是我只使用一个BaseAdapter类来完成上述效果
关键代码如下
MainActivity.java
public class MainActivity extends AppCompatActivity {private Context mContext;private ListView list_book;private ListView list_app;private MyAdapterApp myAdapter1 null;private MyAdapterBook myAdapter2 null;private ListApp mData1 null;private ListBook mData2 null;Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);mContext MainActivity.this;init();}private void init() {list_book (ListView) findViewById(R.id.list_book);list_app (ListView) findViewById(R.id.list_app);//数据初始化mData1 new ArrayListApp();mData1.add(new App(R.mipmap.iv_icon_baidu,百度));mData1.add(new App(R.mipmap.iv_icon_douban,豆瓣));mData1.add(new App(R.mipmap.iv_icon_zhifubao,支付宝));mData2 new ArrayListBook();mData2.add(new Book(《第一行代码Android》,郭霖));mData2.add(new Book(《Android群英传》,徐宜生));mData2.add(new Book(《Android开发艺术探索》,任玉刚));//Adapter初始化myAdapter1 new MyAdapterApp((ArrayList)mData1,R.layout.item_one) {Overridepublic void bindView(ViewHolder holder, App obj) {holder.setImageResource(R.id.img_icon,obj.getaIcon());holder.setText(R.id.txt_aname,obj.getaName());}};myAdapter2 new MyAdapterBook((ArrayList)mData2,R.layout.item_two) {Overridepublic void bindView(ViewHolder holder, Book obj) {holder.setText(R.id.txt_bname,obj.getbName());holder.setText(R.id.txt_bauthor,obj.getbAuthor());}};//ListView设置下Adapterlist_book.setAdapter(myAdapter2);list_app.setAdapter(myAdapter1);}
}
我们写的可复用的BaseAdapter的使用就如上面所述~
最后写好的MyAdapter类吧可根据自己的需求进行扩展
MyAdapter.java
/*** Created by Jay on 2015/9/22 0022.*/
public abstract class MyAdapterT extends BaseAdapter {private ArrayListT mData;private int mLayoutRes; //布局idpublic MyAdapter() {}public MyAdapter(ArrayListT mData, int mLayoutRes) {this.mData mData;this.mLayoutRes mLayoutRes;}Overridepublic int getCount() {return mData ! null ? mData.size() : 0;}Overridepublic T getItem(int position) {return mData.get(position);}Overridepublic long getItemId(int position) {return position;}Overridepublic View getView(int position, View convertView, ViewGroup parent) {ViewHolder holder ViewHolder.bind(parent.getContext(), convertView, parent, mLayoutRes, position);bindView(holder, getItem(position));return holder.getItemView();}public abstract void bindView(ViewHolder holder, T obj);//添加一个元素public void add(T data) {if (mData null) {mData new ArrayList();}mData.add(data);notifyDataSetChanged();}//往特定位置添加一个元素public void add(int position, T data) {if (mData null) {mData new ArrayList();}mData.add(position, data);notifyDataSetChanged();}public void remove(T data) {if (mData ! null) {mData.remove(data);}notifyDataSetChanged();}public void remove(int position) {if (mData ! null) {mData.remove(position);}notifyDataSetChanged();}public void clear() {if (mData ! null) {mData.clear();}notifyDataSetChanged();}public static class ViewHolder {private SparseArrayView mViews; //存储ListView 的 item中的Viewprivate View item; //存放convertViewprivate int position; //游标private Context context; //Context上下文//构造方法完成相关初始化private ViewHolder(Context context, ViewGroup parent, int layoutRes) {mViews new SparseArray();this.context context;View convertView LayoutInflater.from(context).inflate(layoutRes, parent, false);convertView.setTag(this);item convertView;}//绑定ViewHolder与itempublic static ViewHolder bind(Context context, View convertView, ViewGroup parent,int layoutRes, int position) {ViewHolder holder;if (convertView null) {holder new ViewHolder(context, parent, layoutRes);} else {holder (ViewHolder) convertView.getTag();holder.item convertView;}holder.position position;return holder;}SuppressWarnings(unchecked)public T extends View T getView(int id) {T t (T) mViews.get(id);if (t null) {t (T) item.findViewById(id);mViews.put(id, t);}return t;}/*** 获取当前条目*/public View getItemView() {return item;}/*** 获取条目位置*/public int getItemPosition() {return position;}/*** 设置文字*/public ViewHolder setText(int id, CharSequence text) {View view getView(id);if (view instanceof TextView) {((TextView) view).setText(text);}return this;}/*** 设置图片*/public ViewHolder setImageResource(int id, int drawableRes) {View view getView(id);if (view instanceof ImageView) {((ImageView) view).setImageResource(drawableRes);} else {view.setBackgroundResource(drawableRes);}return this;}/*** 设置点击监听*/public ViewHolder setOnClickListener(int id, View.OnClickListener listener) {getView(id).setOnClickListener(listener);return this;}/*** 设置可见*/public ViewHolder setVisibility(int id, int visible) {getView(id).setVisibility(visible);return this;}/*** 设置标签*/public ViewHolder setTag(int id, Object obj) {getView(id).setTag(obj);return this;}//其他方法可自行扩展}}