目前在写项目的过程中,虽然 RecyclerView 已经出来很久了,但是仍有一部分朋友(包括我)再继续使用着 ListView,GridView .
在使用的过程中,使用 ViewHolder 进行 ListView,GridView 的优化,是必不可少的,所以,我们每次在 getView 的方法中 都会去利用 ViewHolder 去进行 View 的复用。
写法如下:
@Overridepublic View getView(int position, View convertView, ViewGroup parent) { //ViewHolder ViewHolder viewHolder=null; //绘制每一项的时候先判断convertView是否为空,不为空,则else里面去复用,为空,则重新赋予item布局 if (convertView == null) { //new出ViewHolder ,初始化布局文件 viewHolder = new ViewHolder(); convertView = LayoutInflater.from(mContext).inflate(R.layout.item_test, null); viewHolder.tv_name= (TextView) convertView.findViewById(R.id.tv_name); //调用convertView的setTag方法,将viewHolder放入进去,用于下次复用 convertView.setTag(viewHolder); } else { //复用已经存在的item的项 viewHolder = (ViewHolder) convertView.getTag(); } viewHolder.tv_name.setText(listBeans.get(position)); return convertView; } class ViewHolder { TextView tv_name; }
我这里整理出一个简化使用 ViewHolder 的方法,相对于创建上面的 getTag() setTag(), 要优雅许多,并且在使用上,也避免了做一些重复性的工作。
这里直接写为一个工具类:
public class ViewHolder { public static <T extends View> T get(View view, int id) { SparseArray<View> viewHolder = (SparseArray<View>) view.getTag(); if (viewHolder == null) { viewHolder = new SparseArray<View>(); view.setTag(viewHolder); } View childView = viewHolder.get(id); if (childView == null) { childView = view.findViewById(id); viewHolder.put(id, childView); } return (T) childView; }}
然后在 getView 中使用方式为:
@Overridepublic View getView(int position, View convertView, ViewGroup parent) { if (convertView == null) { convertView = LayoutInflater.from(mContext).inflate(R.layout.item_test, null); } TextView tv_name = ViewHolder.get(convertView , R.id.tv_name); tv_name.setText(listBeans.get(position)); return convertView; }
相对于上面的第一种写法,是不是更加的简洁,优雅~
这里作为平时的积累,希望能给一些朋友带来帮助~