Android开发之SwipeRefreshLayout实现下拉

作者: YungFan | 来源:发表于2016-04-23 20:45 被阅读10157次

    简介

    SwipeRefreshLayout是Google官方推出的一款下拉刷新组件,位于v4兼容包下,android.support.v4.widget.SwipeRefreshLayout,Support Library 必须19.1以上。使用起来很简单,只要在需要刷新的控件最外层加上SwipeRefreshLayout,其child必须是可滚动的view,如ScrollView、GridView或者ListView,这里就测试最常用的ListView。

    布局

    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:paddingBottom="@dimen/activity_vertical_margin"
        android:paddingLeft="@dimen/activity_horizontal_margin"
        android:paddingRight="@dimen/activity_horizontal_margin"
        android:paddingTop="@dimen/activity_vertical_margin"
        tools:context=".MainActivity">
    
        <android.support.v4.widget.SwipeRefreshLayout
            android:id="@+id/swipeLayout"
            android:layout_width="match_parent"
            android:layout_height="match_parent">
    
            <ListView
                android:id="@+id/listview"
                android:layout_width="match_parent"
                android:layout_height="match_parent"></ListView>
    
        </android.support.v4.widget.SwipeRefreshLayout>
    
    </RelativeLayout>
    
    

    Activity

    public class MainActivity extends AppCompatActivity implements SwipeRefreshLayout.OnRefreshListener {
    
        private SwipeRefreshLayout mSwipeLayout;
        private ListView mListView;
        private ArrayAdapter<String> mAdapter;
        private ArrayList<String> data;
        private boolean isRefresh = false;//是否刷新中
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_main);
    
            init();
    
    
            //设置SwipeRefreshLayout
            mSwipeLayout = (SwipeRefreshLayout) findViewById(R.id.swipeLayout);
    
            //设置进度条的颜色主题,最多能设置四种 加载颜色是循环播放的,只要没有完成刷新就会一直循环,holo_blue_bright>holo_green_light>holo_orange_light>holo_red_light
           // mSwipeLayout.setColorScheme(android.R.color.holo_blue_bright,
           //         android.R.color.holo_green_light,
           //         android.R.color.holo_orange_light,
           //         android.R.color.holo_red_light);
    
            //上面的方法已经废弃
            mSwipeLayout.setColorSchemeColors(Color.BLUE,
                    Color.GREEN,
                    Color.YELLOW,
                    Color.RED);
    
    
            // 设置手指在屏幕下拉多少距离会触发下拉刷新
            mSwipeLayout.setDistanceToTriggerSync(300);
            // 设定下拉圆圈的背景
            mSwipeLayout.setProgressBackgroundColorSchemeColor(Color.WHITE);
            // 设置圆圈的大小
            mSwipeLayout.setSize(SwipeRefreshLayout.LARGE); 
    
            //设置下拉刷新的监听
            mSwipeLayout.setOnRefreshListener(this);
        }
    
        /*
         * 初始化  设置ListView
         */
        private void init() {
            mListView = (ListView) findViewById(R.id.listview);
    
            data = new ArrayList<String>();
    
            for (int i = 1; i < 10; i++) {
                data.add("这是第" + i + "个数据");
            }
    
            //初始化adapter
            mAdapter = new ArrayAdapter<String>(MainActivity.this, android.R.layout.simple_list_item_1, data);
    
            mListView.setAdapter(mAdapter);
        }
    
        /*
         * 监听器SwipeRefreshLayout.OnRefreshListener中的方法,当下拉刷新后触发
         */
        public void onRefresh() {
            //检查是否处于刷新状态
            if (!isRefresh) {
                isRefresh = true;
                //模拟加载网络数据,这里设置4秒,正好能看到4色进度条
                new Handler().postDelayed(new Runnable() {
                    public void run() {
    
                        //显示或隐藏刷新进度条
                        mSwipeLayout.setRefreshing(false);
                        //修改adapter的数据
                        data.add("这是新添加的数据");
                        mAdapter.notifyDataSetChanged();
                        isRefresh = false;
                    }
                }, 4000);
            }
        }
    }
    
    

    测试

    SwipeRefreshLayout.gif

    问题

    细心的读者肯定发现,代码中 setColorSchemeColors 设置颜色时候并未按如下设置

    mSwipeLayout.setColorSchemeColors(android.R.color.holo_blue_bright,
                    android.R.color.holo_green_light,
                    android.R.color.holo_orange_light,
                    android.R.color.holo_red_light);
    

    那是因为,经过测试,如果按照如上设置颜色,进度条不会有颜色循环的效果,不知道为何?难道是bug吗?知道的告知,感谢~~~

    代码地址

    https://github.com/yungfan/SwipeRefreshLayout

    相关文章

      网友评论

      • Spur2:写的不错 一看就明白啦 谢谢:+1:
        YungFan:@Spur2 谢谢 必须做到通俗易懂
      • MisterT:有帮助
        YungFan:@RamMin 那就好
      • Fi7z:用setColorSchemeColorsResoures()这个方法设置颜色才会发生变化。
        YungFan:@Torment_1252 这个在现在已经废弃的方法设置中是可行的 也就是说 它肯定是颜色资源
        0c2dcb45e17a:@YungFan 因为android.R.color.holo_green_light...是一个资源引用,而不是一个可以直接使用的十六进制颜色值。
        查看R文件也可以看到引用也是一个0xXXXXXXXX格式的值,所以系统就把这个误认为是颜色,你要是仔细观察SwipeRefreshLayout刷新效果的话可以看出并不是纯黑色,而是有一些其他颜色。
        而使用setColorSchemeColorsResoures()可以显示颜色的原因就是,告诉系统找到Android XML中定义的内个颜色,而不是自身生成的引用。
        YungFan:@NicholasYang 为什么文中那样不行?
      • Fi7z:用setColorSchemeColorsResoures()这个方法设置颜色才会发生变化。

      本文标题:Android开发之SwipeRefreshLayout实现下拉

      本文链接:https://www.haomeiwen.com/subject/udpzlttx.html