Android SwipeRefreshLayout 下拉刷新布局

发布于 2024-03-18 23:58:41 字数 2702 浏览 29 评论 0

今天在 Google+上看到了 SwipeRefreshLayout 这个名词,遂搜索了下,发现竟然是刚刚 google 更新 sdk 新增加的一个 widget,于是赶紧抢先体验学习下。

SwipeRefreshLayout

SwipeRefreshLayout 字面意思就是下拉刷新的布局,继承自 ViewGroup,在 support v4 兼容包下,但必须把你的 support library 的版本升级到 19.1。 提到下拉刷新大家一定对 ActionBarPullToRefresh 比较熟悉,而如今 google 推出了更官方的下拉刷新组件,这无疑是对开发者来说比较好的消息。利用这个组件可以很方便的实现 Google Now 的刷新效果,见下图:

主要方法

  • setOnRefreshListener(OnRefreshListener): 为布局添加一个 Listener
  • setRefreshing(boolean): 显示或隐藏刷新进度条
  • isRefreshing(): 检查是否处于刷新状态
  • setColorScheme(): 设置进度条的颜色主题,最多能设置四种

xml 布局文件

布局文件很简单,只需要在最外层加上 SwipeRefreshLayout,然后他的 child 是可滚动的 view 即可,如 ScrollView 或者 ListView。如:

<android.support.v4.widget.SwipeRefreshLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/swipe_container"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
 
    <ScrollView
        android:layout_width="match_parent"
        android:layout_height="match_parent">
 
        <TextView
            android:text="@string/hello_world"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_marginTop="16dp"
            android:gravity="center"/>
    </ScrollView>
 
</android.support.v4.widget.SwipeRefreshLayout>

Activity 代码

protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
 
    swipeLayout = (SwipeRefreshLayout) findViewById(R.id.swipe_container);
    swipeLayout.setOnRefreshListener(this);
    swipeLayout.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);
}
 
public void onRefresh() {
    new Handler().postDelayed(new Runnable() {
        @Override public void run() {
            swipeLayout.setRefreshing(false);
        }
    }, 5000);
}

上面的代码很简单,只需要给 SwipeRefreshLayout 添加一个 listener,值得说明的是 setColorScheme 方法是设置刷新进度条的颜色,最多只能设置 4 种循环显示,默认第一个是随用户手势加载的颜色进度条。

源码

写了的小 demo 在 github 上,地址在: SwipeRefreshLayoutDemo

总结

google 在不断完善自己的 sdk,推出越来越多的组件,其目的是让开发更简单,设计上更统一,这可能是 google 未来的方向,不管怎样,这对开发者来说无疑是非常好的消息。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

雨巷深深

暂无简介

0 文章
0 评论
22 人气
更多

推荐作者

内心激荡

文章 0 评论 0

JSmiles

文章 0 评论 0

左秋

文章 0 评论 0

迪街小绵羊

文章 0 评论 0

瞳孔里扚悲伤

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文