ListView有多种Item View的优化
1个回答
2015-10-26 · 知道合伙人软件行家
关注
展开全部
对于ListView 的优化,网上已经被讲解过很多,ListView的优化一般优化如下几点:
(1)Item View重用优化(防内存溢出)
(2)View查找优化(减少执行时间)
(3)滑动优化,在滑动的时候加载图片数据等(防滑动卡顿)
以上基本上是对应单ItemView进行的优化,对于多种ItemView的优化一般使用BaseAdapter给
提供的两个方法
getItemViewType():返回View类型,默认返回0
getViewTypeCount(): 返回有多少种类型的itemView,默认返回1
只有一种类型item view的话,是不需要重写这两个方法的。
如果有多个的时候,就需要重写这个方法了,并且返回的必须满足一下要求:
(1)getItemViewType()返回值必须大于等于0,并且小于类型的个数。为什么是这个范围,是因为
在ListView里有一个数据,用来缓存已经使用过的Item View,详细信息自己看源码
(2)getViewTypeCount()这个方法的返回值就是你可能遇到的Item view类型的最大个数,ListView会根据这个返回值
去创建缓存数组
如果有两种View类型的话,直接在Adapter里面重写getView()方法就可以了,根据getItemViewType()返回值创建相应的View既可。
但是,如果有六个,七个怎么办?那么Adapter的getView()方法得写多少代码,到时候维护起来会多么麻烦,自己看自己写的还好,
如果换做别人呢?非常非常的痛苦.....
我在做我们的app的时候,就遇到了这样的问题,订单列表,每种订单所对应的Item View会有很大的区别,操作起来极为不方便,如有小的
改动都会耽误很长时间。新增类型也不好处理。
我针对遇到的问题进行了一个点点的优化,可以能不是最优秀的,但是至少能解决以上问题,如果您能有更好的方式,也欢迎交流。
设计:
使用提供者的设计方式提供每种Item View,不同的ItemView会有不同的提供者,提供者需要实现一个接口:
public interface IViewProvider { public abstract View getItemView(View convertView, LayoutInflater inflater, Object data); }
提供者只需要实现此接口,然后实现getItemView()方法,实现方式和Adapter的getView()的方式完全一样,减少了学习成本。
我还继承BaseAdapter专门实现了一个Adapter,名字叫MiltilViewListAdapter.java,实现了前面说的两个方法,和getView()方法
提供者只需要配置给MiltilViewListAdapter的实例即可。
一般情况下,都要传递给Adapter一个Bean集合,我的设计是,让这里面的bean都实现一个接口,用来标示它对应的哪个提供者。
使用方法:
[mw_shl_code=java,true]private ListView mListView; private List<IItemBean> mList = new ArrayList<IItemBean>(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); createData(); mListView = (ListView) findViewById(R.id.my_listview); //不同之处在于多了一个provider集合,提供所有期望显示类型的provider class //getView的实现在provider中实现,和在adapter中用法一样 List<Class<? extends IViewProvider>> providers = new ArrayList<Class<? extends IViewProvider>>(); providers.add(FlightOrderViewProvider.class); providers.add(SticketOrderViewProvider.class); MiltilViewListAdapter adpater = new MiltilViewListAdapter(getApplication(), mList, providers); mListView.setAdapter(adpater); }[/mw_shl_code]
(1)Item View重用优化(防内存溢出)
(2)View查找优化(减少执行时间)
(3)滑动优化,在滑动的时候加载图片数据等(防滑动卡顿)
以上基本上是对应单ItemView进行的优化,对于多种ItemView的优化一般使用BaseAdapter给
提供的两个方法
getItemViewType():返回View类型,默认返回0
getViewTypeCount(): 返回有多少种类型的itemView,默认返回1
只有一种类型item view的话,是不需要重写这两个方法的。
如果有多个的时候,就需要重写这个方法了,并且返回的必须满足一下要求:
(1)getItemViewType()返回值必须大于等于0,并且小于类型的个数。为什么是这个范围,是因为
在ListView里有一个数据,用来缓存已经使用过的Item View,详细信息自己看源码
(2)getViewTypeCount()这个方法的返回值就是你可能遇到的Item view类型的最大个数,ListView会根据这个返回值
去创建缓存数组
如果有两种View类型的话,直接在Adapter里面重写getView()方法就可以了,根据getItemViewType()返回值创建相应的View既可。
但是,如果有六个,七个怎么办?那么Adapter的getView()方法得写多少代码,到时候维护起来会多么麻烦,自己看自己写的还好,
如果换做别人呢?非常非常的痛苦.....
我在做我们的app的时候,就遇到了这样的问题,订单列表,每种订单所对应的Item View会有很大的区别,操作起来极为不方便,如有小的
改动都会耽误很长时间。新增类型也不好处理。
我针对遇到的问题进行了一个点点的优化,可以能不是最优秀的,但是至少能解决以上问题,如果您能有更好的方式,也欢迎交流。
设计:
使用提供者的设计方式提供每种Item View,不同的ItemView会有不同的提供者,提供者需要实现一个接口:
public interface IViewProvider { public abstract View getItemView(View convertView, LayoutInflater inflater, Object data); }
提供者只需要实现此接口,然后实现getItemView()方法,实现方式和Adapter的getView()的方式完全一样,减少了学习成本。
我还继承BaseAdapter专门实现了一个Adapter,名字叫MiltilViewListAdapter.java,实现了前面说的两个方法,和getView()方法
提供者只需要配置给MiltilViewListAdapter的实例即可。
一般情况下,都要传递给Adapter一个Bean集合,我的设计是,让这里面的bean都实现一个接口,用来标示它对应的哪个提供者。
使用方法:
[mw_shl_code=java,true]private ListView mListView; private List<IItemBean> mList = new ArrayList<IItemBean>(); @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); createData(); mListView = (ListView) findViewById(R.id.my_listview); //不同之处在于多了一个provider集合,提供所有期望显示类型的provider class //getView的实现在provider中实现,和在adapter中用法一样 List<Class<? extends IViewProvider>> providers = new ArrayList<Class<? extends IViewProvider>>(); providers.add(FlightOrderViewProvider.class); providers.add(SticketOrderViewProvider.class); MiltilViewListAdapter adpater = new MiltilViewListAdapter(getApplication(), mList, providers); mListView.setAdapter(adpater); }[/mw_shl_code]
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询