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的三级优化的更多相关文章

  1. 43.Android之ListView中BaseAdapter学习

    实际开发中个人觉得用的比较多是BaseAdapter,尽管使用起来比其他适配器有些麻烦,但是使用它却能实现很多自己喜欢的列表布局,比如ListView.GridView.Gallery.Spinner ...

  2. Android杂谈--ListView之BaseAdapter的使用

    话说开发用了各种Adapter之后感觉用的最舒服的还是BaseAdapter,尽管使用起来比其他适配器有些麻烦,但是使用它却能实现很多自己喜欢的列表布局,比如ListView.GridView.Gal ...

  3. android 分享一个处理BaseAdapter,getView()多次加载的方法

    一:BaseAdapter介绍 BaseAdapter是listview,gridview等列表,使用的数据适配器,它的主要用途是将一组数据传到ListView.Spinner.Gallery及Gri ...

  4. Android 杂谈---ListView 之BaseAdapter

    前言 几种适配器里面相对来说比较简单的一种适配器,在使用时需要实现几个方法,并且也需要对convertView进行优化 此篇文章以使用listView与BaseAdapter来实现表格样式的布局举例( ...

  5. [转]Android杂谈--ListView之BaseAdapter的使用

    本文转自:http://blog.csdn.net/tianshuguang/article/details/7344315 话说开发用了各种Adapter之后感觉用的最舒服的还是BaseAdapte ...

  6. android 中listview之BaseAdapter的使用

    Listview控件不像其他安卓控件那种直接拖拽到界面上就能用,而是采用类似J2EE中的MVC模型的方式使用,需要通过适配器将某种样式的数据或控件添加到其上而使用. MVC模型实现原理是 数据模型M( ...

  7. Android中ListView通过BaseAdapter实现数据的绑定

    1. public class ListFiles extends Activity { ListView Listview=null; protected void onCreate(Bundle ...

  8. Android使用listView,BaseAdapter实现列表页

    参考: 1.讲解很详细: blog.csdn.net/psuaije/article/details/7447391 总结: 代码:

  9. 转--Android实现ListView过滤功能,继承于BaseAdapter,非ArrayAdapter。

    其实实现ListView过滤功能最方便的便是使用ArrayAdapter,里面自带的getFilter()方法能很方便的实现此功能,但是在实际的开发中,一般都是继承于BaseAdapter.还有一种是 ...

随机推荐

  1. SCNU ACM 2016新生赛决赛 解题报告

    新生初赛题目.解题思路.参考代码一览 A. 拒绝虐狗 Problem Description CZJ 去排队打饭的时候看到前面有几对情侣秀恩爱,作为单身狗的 CZJ 表示很难受. 现在给出一个字符串代 ...

  2. MongoDB基础

    1.概念及特点 说明:由于部分语句中$ 符号无法正常显示,使用¥代表 概念 MongoDB是一个基于文档的分布式的开源的NoSQL数据库,文档的结构为BSON形式,每一个文档都有一个唯一的Object ...

  3. css样式让input垂直居中

    css样式让input垂直居中 css代码: .div1{ border: 1px solid #CCC; width:1120px; height:40px; margin:auto; displa ...

  4. 基于虎书实现LALR(1)分析并生成GLSL编译器前端代码(C#)

    基于虎书实现LALR(1)分析并生成GLSL编译器前端代码(C#) 为了完美解析GLSL源码,获取其中的信息(都有哪些in/out/uniform等),我决定做个GLSL编译器的前端(以后简称编译器或 ...

  5. 敏捷团队中的QA由来

    QA,全称为Quality Analyst,即质量分析师(有些称为Quality Assurance,即质量保证师).为什么它总跟质量扯在一块?感觉这个角色明明做的都是测试的事情,为什么不直接叫做te ...

  6. Web网站中利用JavaScript中ActiveXObject对象获取硬件信息(显示器数量、分辨率)从而进行单双屏跳转

    前言:最近这两天工作上,要实现一个功能,在好友阿聪的帮助下,算是比较好的解决了这个需求. B/S的Web网站,需要实现点击按钮时,根据客户端连接的显示屏(监视器)数量进行,单双屏跳转显示新页面. 由于 ...

  7. 遍历dynamic的方式

    一.遍历ExpandoObject /// <summary> /// 遍历ExpandoObject /// </summary> [TestMethod] public v ...

  8. MSSQLSERVER执行计划详解

    序言 本篇主要目的有二: 1.看懂t-sql的执行计划,明白执行计划中的一些常识. 2.能够分析执行计划,找到优化sql性能的思路或方案. 如果你对sql查询优化的理解或常识不是很深入,那么推荐几骗博 ...

  9. [OAuth]基于DotNetOpenAuth实现Client Credentials Grant

    Client Credentials Grant是指直接由Client向Authorization Server请求access token,无需用户(Resource Owner)的授权.比如我们提 ...

  10. 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(12)-系统日志和异常的处理②

    系列目录 上一讲我们做了日志与异常的结果显示列表,这一节我们讲要把他应用系统中来. 首先我们在App.Common类库中创建一个通用类ResultHelper,这个类里面写了,获取一个GUID,获取当 ...