美文网首页
使用SwipeRefreshLayout做下拉刷新

使用SwipeRefreshLayout做下拉刷新

作者: 码圣 | 来源:发表于2016-08-27 22:48 被阅读150次

刚刚开通简书,趁热打铁来一篇博客

在Android中,下拉刷新非常常见,谷歌官方也提供了控件方便我们做刷新,就是SwipeRefreshLayout。现在我就来做一个ListView的下拉刷新

  • 这是主布局
<?xml version="1.0" encoding="utf-8"?>
<android.support.v4.widget.SwipeRefreshLayout xmlns:android="http://schemas.android.com/apk/res/android"
    
    android:id="@+id/swp"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <ListView
        android:id="@+id/lv"
        android:layout_width="match_parent"
        android:layout_height="match_parent">

    </ListView>
</android.support.v4.widget.SwipeRefreshLayout>

ListView的条目布局非常地简单,就是一个TextView。

  • 这是MainActivity的代码,非常简单
public class MainActivity extends AppCompatActivity implements SwipeRefreshLayout.OnRefreshListener {

    private ListView lv;
    private SwipeRefreshLayout swp;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        lv = (ListView) findViewById(R.id.lv);
        lv.setAdapter(new MyAdapter());

        swp = (SwipeRefreshLayout) findViewById(R.id.swp);
        swp.setColorSchemeResources(android.R.color.holo_blue_bright,
                android.R.color.holo_green_light,
                android.R.color.holo_orange_light,
                android.R.color.holo_red_light);//设置圆圈旋转的颜色(随机)
//        swp.setDistanceToTriggerSync(400);// 设置手指在屏幕下拉多少距离会触发下拉刷新
//        swp.setProgressBackgroundColor(R.color.red); // 设定下拉圆圈的背景
//        swp.setSize(SwipeRefreshLayout.LARGE); // 设置圆圈的大小
        swp.setOnRefreshListener(this);//设置刷新监听
    }

    @Override
    public void onRefresh() {
        Log.d("alan", "刷新");
        new Handler().postDelayed(new Runnable() {
            @Override
            public void run() {
                // 停止刷新
                swp.setRefreshing(false);
            }
        },3000); // 5秒后发送消息,停止刷新
    }

    class MyAdapter extends BaseAdapter {

        @Override
        public int getCount() {
            return 20;
        }

        @Override
        public Object getItem(int position) {
            return null;
        }

        @Override
        public long getItemId(int position) {
            return 0;
        }

        @Override
        public View getView(int position, View convertView, ViewGroup parent) {
            View view = View.inflate(getApplicationContext(), R.layout.item, null);
            return view;
        }
    }
}

结果图如下

下拉刷新

以上就是SwipeRefreshLayout的基本使用

相关文章

网友评论

      本文标题:使用SwipeRefreshLayout做下拉刷新

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