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. REGEX例子

    作为REGEX的例子,代码9.3显示了一个给定的文件有多少行,具有给定的模式,通过命令行输入(注:有更有效率的方式来实现这个功能,如Unix下的grep命令,在这里只是给出了另一种方式).这个程序像下 ...

  2. 如何让spring mvc web应用启动时就执行特定处理

    Asp.Net的应用中通过根目录下的Global.asax,在Application_Start方法中做一些初始化操作,比如:预先加载缓存项对网站热点数据进行预热,获取一些远程的配置信息等等. Spr ...

  3. Aop动态生成代理类时支持带参数构造函数

    一.背景 在某些情况下,我们需要植入AOP代码的类并没有默认构造函数.那么此时动态生成的代理类也需要相同签名的构造函数,并且内部调用原始类的构造函数.自己折腾了1晚上没搞定,现在搞定了发出来供大家一起 ...

  4. ASP.NET MVC 使用 Petapoco 微型ORM框架+NpgSql驱动连接 PostgreSQL数据库

    前段时间在园子里看到了小蝶惊鸿 发布的有关绿色版的Linux.NET——“Jws.Mono”.由于我对.Net程序跑在Linux上非常感兴趣,自己也看了一些有关mono的资料,但是一直没有时间抽出时间 ...

  5. DTO – 服务实现中的核心数据

    在一个Web服务的实现中,我们常常需要访问数据库,并将从数据库中所取得的数据显示在用户页面中.这样做的一个问题是:用于在用户页面上展示的数据和从数据库中取得的数据常常具有较大区别.在这种情况下,我们常 ...

  6. Hadoop学习笔记系列文章导航

    一.为何要学习Hadoop? 这是一个信息爆炸的时代.经过数十年的积累,很多企业都聚集了大量的数据.这些数据也是企业的核心财富之一,怎样从累积的数据里寻找价值,变废为宝炼数成金成为当务之急.但数据增长 ...

  7. 应用Grunt自动化地优化你的项目前端

    在不久前我曾写了一篇 应用r.js来优化你的前端 的文章,为大家介绍了r.js这个实用工具,它可以很好地压缩.合并前端文件并打包整个项目.但是如果将r.js放到项目中,我们不得不顾及到一个问题——项目 ...

  8. ABP框架 - 实体

    文档目录 本节内容: 实体类 聚合根类 领域事件 约定的接口 审计 软删除 活跃/消极 实体 实体变化事件 IEntity 接口 实体是DDD一个核心的概念.Eric Evans是这么描述的:“一个对 ...

  9. [转]Linux下g++编译与使用静态库(.a)和动态库(.os) (+修正与解释)

    在windows环境下,我们通常在IDE如VS的工程中开发C++项目,对于生成和使用静态库(*.lib)与动态库(*.dll)可能都已经比较熟悉,但是,在linux环境下,则是另一套模式,对应的静态库 ...

  10. 常用的Webpack配置

    官方文档: http://webpack.github.io/docs/ 1. 安装python2. 安装node.js msi3. npm自动打包在最新的node.js安装包里 被封的包用国内镜像下 ...