`
qq986945193
  • 浏览: 93578 次
  • 性别: Icon_minigender_2
  • 来自: 深圳
文章分类
社区版块
存档分类
最新评论

【Android】SwipeRefreshLayout的简单使用教程。下拉刷新控件炫酷效果。

 
阅读更多

作者:程序员小冰,GitHub主页:https://github.com/QQ986945193
新浪微博:http://weibo.com/mcxiaobing
首先给大家看一下我们今天这个最终实现的效果图:
这里写图片描述

好了,简单的介绍一下,SwipeRefreshLayout是android系统自带的一个控件,
可以看到现在App好多刷新都有这样类似的效果。其实它的使用还是比较
简单的,就是在我们的listview的控件上面加上就行了,然后再在java代码
中设置它的颜色,以及监听它的刷新事件。我这里随便用了一个list集合。
还有刷新结束后没有操作什么内容,但是实际项目中大家按例套进去即可。
首先SwipeRefreshLayout是V4包下的,我们xml引用它的时候可以是这样:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <android.support.v4.widget.SwipeRefreshLayout
        android:id="@+id/swipe_container"
        android:layout_width="match_parent"
        android:layout_height="match_parent">

        <ListView
            android:id="@+id/listview"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:padding="16dp" />

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

然后,我们再在java代码中进行监听事件,以及设置刷新颜色:

package davidswiperefreshlayout.qq986945193.davidswiperefreshlayout;

import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.support.v4.widget.SwipeRefreshLayout;
import android.widget.ArrayAdapter;
import android.widget.ListView;

import java.util.ArrayList;

/**
 * @author :程序员小冰
 * @新浪微博 :http://weibo.com/mcxiaobing
 * @GitHub: https://github.com/QQ986945193
 * @CSDN博客: http://blog.csdn.net/qq_21376985
 * @码云OsChina :http://git.oschina.net/MCXIAOBING
 */
public class MainActivity extends Activity implements SwipeRefreshLayout.OnRefreshListener {

    private SwipeRefreshLayout mSwipeLayout;
    private ListView mListView;
    private ArrayList<String> list = new ArrayList<String>();
    private ArrayAdapter<String> adapter;

    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        mListView = (ListView) findViewById(R.id.listview);
        /**
         * listview绑定adapter
         */
        adapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, getData());
        mListView.setAdapter(adapter);

        mSwipeLayout = (SwipeRefreshLayout) findViewById(R.id.swipe_container);
        //绑定刷新时间
        mSwipeLayout.setOnRefreshListener(this);
        //设置颜色
        mSwipeLayout.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);
    }

    private ArrayList<String> getData() {
        list.add("Hello world!");
        list.add("CSDN:程序员小冰");
        list.add("An Android Developer");
        list.add("http://weibo.com/mcxiaobing");
        list.add("http://git.oschina.net/MCXIAOBING");
        list.add("https://github.com/QQ986945193");
        list.add("An Android Developer");
        list.add("http://weibo.com/mcxiaobing");
        list.add("http://git.oschina.net/MCXIAOBING");
        list.add("https://github.com/QQ986945193");
        list.add("An Android Developer");
        list.add("http://weibo.com/mcxiaobing");
        list.add("http://git.oschina.net/MCXIAOBING");
        list.add("https://github.com/QQ986945193");
        return list;
    }

    public void onRefresh() {
        new Handler().postDelayed(new Runnable() {
            @Override
            public void run() {
                //停止刷新 
                mSwipeLayout.setRefreshing(false);

            }
        }, 3000);
    }
}

好了,教程到此结束。如果此文章帮到了你,欢迎点赞。
源代码需要的可以去
(AndroidStudio版)github下载地址:
https://github.com/QQ986945193/DavidSwipeRefreshLayout
(AndroidStudio版)Git开源中国下载地址:
http://git.oschina.net/MCXIAOBING/DavidSwipeRefreshLayout

<script type="text/javascript"> $(function () { $('pre.prettyprint code').each(function () { var lines = $(this).text().split('\n').length; var $numbering = $('<ul/>').addClass('pre-numbering').hide(); $(this).addClass('has-numbering').parent().append($numbering); for (i = 1; i <= lines; i++) { $numbering.append($('<li/>').text(i)); }; $numbering.fadeIn(1700); }); }); </script>
分享到:
评论

相关推荐

    android listview 下拉回弹刷新效果

    1. **SwipeRefreshLayout**:Google官方提供了一个名为SwipeRefreshLayout的组件,专门用于实现这种下拉刷新效果。它是一个可以包裹其他布局,如ListView、RecyclerView等的容器。添加SwipeRefreshLayout到布局文件...

    SwipeRefreshLayout 下拉刷新

    这个资源是关于SwipeRefreshLayout控件的demo实现。SwipeRefreshLayout是android自带的下拉刷新组件,第一次接触,觉得非常炫酷(原谅我的APP一直做的很朴素)。记录下来也分享给大家~

    一个很好的掌握各种android控件的demo

    在ListView或RecyclerView上方添加SwipeRefreshLayout,可以实现下拉刷新的功能,常见于新闻列表等更新频繁的应用。 10. **RecyclerView**: RecyclerView是ListView的替代品,更高效且更灵活。它可以显示列表、...

    java餐饮管理源码-SmartRefreshLayout-master:各种刷新控件

    Android智能下拉刷新框架-SmartRefreshLayout #借用别人的项目 | 中文 正如名字所说,SmartRefreshLayout是一个“聪明”或者“智能”的下拉刷新布局,由于它的“智能”,它不只是支持所有的View,还支持多层嵌套的...

    酷炫的表格

    本项目利用了现有的开源库并进行了改造,以实现下拉刷新和上拉加载的功能,使得数据的加载更加灵活和便捷。以下是关于这个主题的详细知识点: 1. **表格组件**:表格是一种常见的UI控件,用于展示结构化的数据,如...

    仿qq页面的listview

    8. **下拉刷新和上拉加载**:为了增强交互性,可以集成SwipeRefreshLayout,实现下拉刷新功能,同时使用LoadMoreView或RecyclerView的addOnScrollListener实现上拉加载更多数据。 9. **性能优化**:在处理大量数据...

    Android listview gridview

    - 动态加载更多:结合下拉刷新库(如SwipeRefreshLayout)实现上拉加载更多功能。 **GridView** GridView则是一个二维的网格视图,它可以水平或垂直滚动,常用于图片墙、应用图标等场景。与ListView类似,GridView...

    awesome-github-android-ui:安卓UI相关开源项目库汇总

    7. **下拉刷新和上拉加载**:`SwipeRefreshLayout`是官方提供的下拉刷新组件,`PullToRefresh`库提供了更多的定制选项。 8. **图片处理**:`Glide`和`Picasso`是两个常用的图片加载和缓存库,可以高效地处理网络和...

Global site tag (gtag.js) - Google Analytics