zoukankan      html  css  js  c++  java
  • Android记录和恢复listView滚动位置

    有时在view切换时,需要恢复listView之前滚动到的位置,常用的三种方法如下:

    1、记录listView滚动到的位置的坐标,然后利用listView.scrollTo精确的进行恢复

    listView.setOnScrollListener(new OnScrollListener() {
                @Override
                public void onScrollStateChanged(AbsListView view, int scrollState) {
                   
                    if (scrollState == OnScrollListener.SCROLL_STATE_IDLE) {
                        if (currentMenuInfo!=null)         {
                            scrolledX = listView.getScrollX();
                            scrolledY = listView.getScrollY();
                        }
                    }
                }

                @Override
                public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
                   
                }
            });
    在恢复位置时调用:
    listView.scrollTo(scrolledX, scrolledY);

    2、记录listView显示在屏幕上的第一个item的位置,然后利用listView.setSelection恢复

    listView.setOnScrollListener(new OnScrollListener() {

                @Override
                public void onScrollStateChanged(AbsListView view, int scrollState) {
                    if (scrollState == OnScrollListener.SCROLL_STATE_IDLE) {
                        position = listView.getFirstVisiblePosition();
                    }
                }

                @Override
                public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
                }
            });


    在恢复位置时调用:

    listView.setSelection(position);
    

    3、通知listView的适配器数据变更

    这种适用于listView追加数据的情况,严格说不是恢复listView滚动的位置,只是保持滚动位置不错

    listDataAdapter.getDataList.addAll(newDataList());
    
    listDataAdapter.notifyDataSetChanged();
  • 相关阅读:
    1.Math函数对象
    1.日期与时间
    使用object literal替换switch
    Array数组去重
    flexbox弹性布局
    web移动端一些常用知识
    解决网页ICON图标无法显示的问题
    观察者模式和发布订阅模式的区别
    JS延迟加载的几种方式
    前端 api 请求缓存方案
  • 原文地址:https://www.cnblogs.com/crane13/p/3150162.html
Copyright © 2011-2022 走看看