码迷,mamicode.com
首页 > 移动开发 > 详细

[Android Pro] 精确记录和恢复ListView滑动位置

时间:2016-11-28 20:52:53      阅读:258      评论:0      收藏:0      [点我收藏+]

标签:blog   on()   开始   osi   flow   体验   state   csdn   pos   

reference to : http://blog.csdn.net/welovesunflower/article/details/7926512

工作中遇到一个需求,对ListView某一项操作后刷新ListView,但是如果直接刷新,界面上ListView从第一列开始显示,用户体验不好,于是在网上搜了一些恢复LIstView滑动位置的方法。解决办法如下:

1 :

// 设置ListView到记录的位置  
mListView.setSelection(mPosition);  
mListView.setOnScrollListener(new OnScrollListener() {  
    // 滚动状态改变时调用 
    @Override  
    public void onScrollStateChanged(AbsListView view, int scrollState) {  
        // 不滚动时保存当前滚动到的位置  
        if (scrollState == OnScrollListener.SCROLL_STATE_IDLE) {  
            mPosition = mListView.getFirstVisiblePosition();  
        }  
    }  
 // 滚动时调用 
    @Override  
    public void onScroll(AbsListView view, int firstVisibleItem,  
            int visibleItemCount, int totalItemCount) {  
    }  
});

2:

//给ListView设置监听器
backgroundList.setOnScrollListener(scrollListener);
private OnScrollListener scrollListener = new OnScrollListener() {
 
                @Override
                public void onScroll(AbsListView arg0, int arg1, int arg2, int arg3) {
                }
 
                @Override
                public void onScrollStateChanged(AbsListView view, int scrollState) {
                        if (scrollState == OnScrollListener.SCROLL_STATE_IDLE) {
                                // scrollPos记录当前可见的List顶端的一行的位置 
                               scrollPos = myList.getFirstVisiblePosition(); 
                        }
                        if (arrayList != null) {  
              View v=myList .getChildAt(0);
              scrollTop=(v==null)?0:v.getTop();
            }  
         }
        };

调用setAdapter之后恢复位置:
myList .setSelectionFromTop(scrollPos, scrollTop);

 

[Android Pro] 精确记录和恢复ListView滑动位置

标签:blog   on()   开始   osi   flow   体验   state   csdn   pos   

原文地址:http://www.cnblogs.com/0616--ataozhijia/p/6110837.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!