zoukankan      html  css  js  c++  java
  • Android ListView 单条刷新方法实践及原理解析

    对于使用listView配合adapter进行刷新的方法大家都不陌生,先刷新adapter里的数据,然后调用notifydatasetchange通知listView刷新界面。

    方法虽然简单,但这里面涉及到一个效率的问题,调用notifydatasetchange其实会导致adpter的getView方法被多次调用 (画面上能显示多少就会被调用多少次),如果是很明确的知道只更新了list中的某一个项的数据(比如用户点击list某一项后更新该项的显示状态,或者 后台回调更新list某一项,等等),应该尽量避免getView被无辜的多次调用,特别是当后台线程特别多,回调的频率特别高,并且界面的布局优化得不是特别好的时候,使用notityDataSetChaned()方法来更新界面就会显得列表卡顿,用户体验不佳。

    下面我们来介绍一下如何对listView进行单条刷新:

    首先我们看一下adapter的getView方法,我们要进行单条刷新就要手动调用这个方法。

    public View getView(int position, View convertView, ViewGroup parent)

    那么这三个参数是如何确定的呢,第三个参数很好确定,就是你的listview。

    为了确定另外两个参数position和converView,这里介绍几个lisView的新方法:

    getFirstVisiblePosition(),该方法获取当前状态下list的第一个可见item的position。

    getLastVisiblePosition(),该方法获取当前状态下list的最后一个可见item的position。

    getItemAtPosition(int position),该方法返回当前状态下position位置上listView的convertView

    ps:这里的convertView是复用的,也就是说不管position的值是多大(这个要看你整个list有多大),converView的个数应该始终是屏幕上能显示的list的条数那么多。

    所 以,我们通过从getFirstVisiblePosition的值到getLastVisiblePosition的值之间的listitem和需要进 行更新的条件(比如id)进行比较确定哪一个是要更新的(如果不在当前可是范围内也就没有必要更新了,等list拉动的时候自然就会更新出来)

     

    代码如下,其实这个方法是google 2011年开发者大会上提出的方法——ListView单条更新:

    private void updateSingleRow(ListView listView, long id) { 
       
            if (listView != null) { 
                int start = listView.getFirstVisiblePosition(); 
                for (int i = start, j = listView.getLastVisiblePosition(); i <= j; i++) 
                    if (id == ((Messages) listView.getItemAtPosition(i)).getId()) { 
                        View view = listView.getChildAt(i - start); 
                        getView(i, view, listView); 
                        break
                    
            
        }
     


    来自:http://blog.csdn.net/yuyuanhuang/article/details/43198107

  • 相关阅读:
    Mac 远程连接 Windows
    更优雅的方式: JavaScript 中顺序执行异步函数
    Node.js 上传文件
    win10 系统右键菜单不显示文字(只有小图标)修复方法
    JavaScript 排序算法(JavaScript sorting algorithms)
    JavaScript addEventListener 第三个参数
    前端小白之每天学习记录----angula2--(1)
    H5如何与Native通信Hybrid交互--(1)
    vuex学习--(1)
    前端小白之每天学习记录----php(9)简单的api
  • 原文地址:https://www.cnblogs.com/Free-Thinker/p/4789838.html
Copyright © 2011-2022 走看看