Android关于listView的BaseAdapter以及getView的三级优化
1、4个重写方法的含义
自定义Adapter继承自BaseAdapter(通用适配器)
getCount();
getItem();
getItemId();
getViewTypaCount();
2:getView的三级缓存优化写法
一级优化:使用converView进行view的复用
二级优化:将convertView的所有findviewById操作的控件缓存起来--ViewHolder
三级优化:一次适配的数据源list集合是有限的(分批加载...)
3:ListView中convertView和ViewHolder的工作原理
参考:
http://blog.csdn.net/bill_ming/article/details/8817172
4:常用优化技巧
使用viewHolder模式提高效率
设置项目分隔线
隐藏ListView的滚动条
取消ListView的Item点击效果
------当点击Listview中的某一项时,系统默认会出现一个点击效果,在5.0上是一个波纹效果,5.0下则是一个
改变背景颜色的效果,通常情况下,我们会选择取消点击后的回馈效果 listSelector=“#00000000”
设置Listview需要显示在第几项
-------Listview是以Item为单位进行显示,默认显示在第一个Item,当需要指定具体显示的item时,setSelection(N)....
这个方法是瞬间完成的移动,除此之外,还可以使用如下代码来完成平滑移动。
mListview.smoothScrollBy(distance,duration);
mListView.smoothScrollByOffset(offset);
mListView.smoothScrollToPosition(index);
遍历ListView中的所有Item
getChildCount()
getChildAt()
5:listView滑动监听(下拉刷新,上拉加载)
ListView的滑动监听,是ListView中最重要的技巧,很多重写的ListView,基本都是在滑动事件的处理上下功夫:
这里介绍2种监听ListView滑动事件的方法:
(1)、onTouchListener:View中的监听事件,通过监听ACTION_DOWN,ACTION_MOVE,ACTION_UP这3个事件发生时的坐标,
就可以根据坐标判断 用户滑动的方向,并在不同的事件中进行相应的处理;
(2)、onScrollListener:是AbsListView中的监听事件,它封装了很多与ListView相关的信息,使用起来更加灵活。
OnscrollListener.SCROLL_STATE_IDLE: 滚动停止时;
OnScrollListener.SCROLL_STATE_TOUCH_SCROLL: 正在滚动
OnScrollListener.SCROLL_STATE_FLING: 猛的一滑,在 手指离开后,由于惯性继续滑动
onScroll方法:
firstVisbleItem: 当前能看见的第一个Item的ID;
visbleItemCount: 当前能看见的Item总数,包括没有显示完整的Item;
totalItemCount: 整个ListView的Item总数;
--->应用: 判断是否滚动到最后一行,进行分批数据加载并自动刷新数据;
--->判断滚动到最后一行:firstVisbleItem+visbleItemCount == totalItemCount ;
Eg:
public class InforAdapter extends BaseAdapter {
List<Infor> inforlist = new ArrayList<>();
Context context;
public InforAdapter(List<Infor> inforlist,Context context) {
this.context=context;
this.inforlist = inforlist;
}
@Override
public int getCount() {
return inforlist == null ? 0 : inforlist.size();
}
public void fluhData(List<Infor> inforlist) {
this.inforlist = inforlist;
//通知adapter刷新数据
this.notifyDataSetChanged();
}
@Override
public Object getItem(int position) {
return inforlist.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public int getViewTypeCount() {
return 2;
}
@Override
public int getItemViewType(int position) {
Infor infor = inforlist.get(position);
int infortype = infor.getType();
return infortype;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
final IvViewHolder ivViewHolder;
final TvViewHolder tvViewHolder;
final Infor infor = inforlist.get(position);
int ViewType = getItemViewType(position);
if (ViewType == 0) {
// 只显示图片的item;
if (convertView == null) {
convertView = View.inflate(parent.getContext(), R.layout.iv_infor, null);
ivViewHolder = new IvViewHolder();
ivViewHolder.iv = (ImageView) convertView.findViewById(R.id.iv_content);
ivViewHolder.title = (TextView) convertView.findViewById(R.id.title);
ivViewHolder.iv_icon = (ImageView) convertView.findViewById(R.id.title_icon);
ivViewHolder.source = (TextView) convertView.findViewById(R.id.source);
ivViewHolder.guanzhu = (TextView) convertView.findViewById(R.id.guanzhu);
ivViewHolder.guanzhu.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if(ivViewHolder.guanzhu.getText().equals("关注")){
ivViewHolder.guanzhu.setText("已关注");
ivViewHolder.guanzhu.setTextColor(Color.parseColor("#EA2000"));
}else if(ivViewHolder.guanzhu.getText().equals("已关注")) {
ivViewHolder.guanzhu.setText("关注");
ivViewHolder.guanzhu.setTextColor(Color.parseColor("#000000"));
Toast.makeText(context,"已取消关注",Toast.LENGTH_SHORT).show();
}
}
});
convertView.setTag(ivViewHolder);
} else {
ivViewHolder = (IvViewHolder) convertView.getTag();
}
ivViewHolder.title.setText(infor.getTitle());
ivViewHolder.iv.setImageResource(infor.getImgid());
ivViewHolder.guanzhu.setText("关注");
ivViewHolder.guanzhu.setTextColor(Color.parseColor("#000000"));
ivViewHolder.source.setText(infor.getSource());
ivViewHolder.iv_icon.setImageResource(infor.getIconid());
} else if (ViewType == 1) {
// 只显示文字的Item;
if (convertView == null) {
convertView = View.inflate(parent.getContext(), R.layout.tv_infor, null);
tvViewHolder = new TvViewHolder();
tvViewHolder.tv = (TextView) convertView.findViewById(R.id.tv_content);
tvViewHolder.title = (TextView) convertView.findViewById(R.id.title);
tvViewHolder.iv_icon = (ImageView) convertView.findViewById(R.id.title_icon);
tvViewHolder.source = (TextView) convertView.findViewById(R.id.source);
tvViewHolder.guanzhu = (TextView) convertView.findViewById(R.id.guanzhu);
tvViewHolder.guanzhu.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
if(tvViewHolder.guanzhu.getText().equals("关注")){
tvViewHolder.guanzhu.setText("已关注");
tvViewHolder.guanzhu.setTextColor(Color.parseColor("#EA2000"));
}else if(tvViewHolder.guanzhu.getText().equals("已关注")){
tvViewHolder.guanzhu.setText("关注");
tvViewHolder.guanzhu.setTextColor(Color.parseColor("#000000"));
Toast.makeText(context,"已取消关注",Toast.LENGTH_SHORT).show();
}
}
});
convertView.setTag(tvViewHolder);
} else {
tvViewHolder = (TvViewHolder) convertView.getTag();
}
tvViewHolder.guanzhu.setText("关注");
tvViewHolder.guanzhu.setTextColor(Color.parseColor("#000000"));
tvViewHolder.title.setText(infor.getTitle());
tvViewHolder.tv.setText(infor.getContent());
tvViewHolder.iv_icon.setImageResource(infor.getIconid());
tvViewHolder.source.setText(infor.getSource());
}
return convertView;
}
static class IvViewHolder {
ImageView iv;
ImageView iv_icon;
TextView source;
TextView title;
TextView guanzhu;
}
static class TvViewHolder {
TextView title;
ImageView iv_icon;
TextView source;
TextView guanzhu;
TextView tv;
}
Android关于listView的BaseAdapter以及getView的三级优化的更多相关文章
- 43.Android之ListView中BaseAdapter学习
实际开发中个人觉得用的比较多是BaseAdapter,尽管使用起来比其他适配器有些麻烦,但是使用它却能实现很多自己喜欢的列表布局,比如ListView.GridView.Gallery.Spinner ...
- Android杂谈--ListView之BaseAdapter的使用
话说开发用了各种Adapter之后感觉用的最舒服的还是BaseAdapter,尽管使用起来比其他适配器有些麻烦,但是使用它却能实现很多自己喜欢的列表布局,比如ListView.GridView.Gal ...
- android 分享一个处理BaseAdapter,getView()多次加载的方法
一:BaseAdapter介绍 BaseAdapter是listview,gridview等列表,使用的数据适配器,它的主要用途是将一组数据传到ListView.Spinner.Gallery及Gri ...
- Android 杂谈---ListView 之BaseAdapter
前言 几种适配器里面相对来说比较简单的一种适配器,在使用时需要实现几个方法,并且也需要对convertView进行优化 此篇文章以使用listView与BaseAdapter来实现表格样式的布局举例( ...
- [转]Android杂谈--ListView之BaseAdapter的使用
本文转自:http://blog.csdn.net/tianshuguang/article/details/7344315 话说开发用了各种Adapter之后感觉用的最舒服的还是BaseAdapte ...
- android 中listview之BaseAdapter的使用
Listview控件不像其他安卓控件那种直接拖拽到界面上就能用,而是采用类似J2EE中的MVC模型的方式使用,需要通过适配器将某种样式的数据或控件添加到其上而使用. MVC模型实现原理是 数据模型M( ...
- Android中ListView通过BaseAdapter实现数据的绑定
1. public class ListFiles extends Activity { ListView Listview=null; protected void onCreate(Bundle ...
- Android使用listView,BaseAdapter实现列表页
参考: 1.讲解很详细: blog.csdn.net/psuaije/article/details/7447391 总结: 代码:
- 转--Android实现ListView过滤功能,继承于BaseAdapter,非ArrayAdapter。
其实实现ListView过滤功能最方便的便是使用ArrayAdapter,里面自带的getFilter()方法能很方便的实现此功能,但是在实际的开发中,一般都是继承于BaseAdapter.还有一种是 ...
随机推荐
- POJ1743 Musical Theme [后缀数组]
Musical Theme Time Limit: 1000MS Memory Limit: 30000K Total Submissions: 27539 Accepted: 9290 De ...
- Unity3D新手引导开发手记
最近开始接手新手引导的开发,记录下这块相关的心得 首先客户端是Unity,在接手前,前面的同学已经初步完成了新手引导框架的搭建,这套框架比较简单,有优点也有缺点,稍后一一点评 我们的新手引导是由一个个 ...
- Angular2学习笔记——在子组件中拿到路由参数
工作中碰到的问题,特此记录一下. Angular2中允许我们以`path\:id\childPath`的形式来定义路由,比如: export const appRoutes: RouterConfig ...
- 使用自定义 classloader 的正确姿势
详细的原理就不多说了,网上一大把, 但是, 看了很多很多, 即使看了jdk 源码, 说了罗里吧嗦, 还是不很明白: 到底如何正确自定义ClassLoader, 需要注意什么 ExtClassLoade ...
- Android开发学习之路-使用annotationProcessor配置Butterknife
Apt工具的作者宣布了不再维护该工具了,而且Android Studio也有了自己的插件,并且可以通过gradle来简单的配置. 其实用Butterknife的都知道,没有apt,onClick绑定不 ...
- 从Fiddler抓包到Jmeter接口测试(简单的思路)
备注:本文为博主的同事总结的文章,未经博主允许不得转载. Fiddler下载和配置安装 从网上下载fiddler的安装包即可,直接默认,一直点击下一步,直至安装完成. 安装完成后直接打开Fiddler ...
- TODO List - 任务表
TODO List - 任务表 Angular1 --> Ionic1 --> Vue --> Weex Python --> Django --> Tornado -- ...
- HTTP权威指南-基础知识
1.URL,URI 统一资源标识符?统一标识定位符? 2.http,https,ftp http://<host>:<port>/<path>/?<que ...
- 跨域之URL
在介绍怎么跨域之前,先来弄清楚一个概念:URL.以下内容摘自维基百科. 统一资源定位符(或称统一资源定位器/定位地址.URL地址等,英语:Uniform / Universal Resource Lo ...
- 用SignalR 2.0开发客服系统[系列5:使用SignalR的中文简体语言包和其他技术点]
前言 交流群:195866844 目录: 用SignalR 2.0开发客服系统[系列1:实现群发通讯] 用SignalR 2.0开发客服系统[系列2:实现聊天室] 用SignalR 2.0开发客服系统 ...