android之官方下拉刷新组件SwipeRefreshLayout

一、问题描述

公司主营业务:成都网站建设、做网站、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。成都创新互联公司是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。成都创新互联公司推出蒸湘免费做网站回馈大家。

在Android开发中,使用最多的数据刷新方式就是下拉刷新了,而完成此功能我们使用最多的就是第三方的开源库PullToRefresh。现如今,google也忍不住推出了自己的下拉组件SwipeRefreshLayout,下面我们通过api文档和源码来分析学习如何使用SwipeRefreshLayout。

先看效果图:

二、SwipeRefreshLayout的具体用法

下面我们来看SwipeRefreshLayout的具体用法,顾名思义此组件就是一个布局,只不过要注意的是此布局内只能有一个直接子View。其实通过文档我们可以知道SwipeRefreshLayout只不过是继承了ViewGroup。

查看文档,我们可以知道,在SwipRefreshLayout中存在一个接口,通过此接口我们可以监听滑动手势,其实使用此组件最重要的步骤就是实现此接口的onRefresh方法,在此方法中实现数据的更新操作。如下:

接口中的方法:

1、setOnRefreshListener(SwipeRefreshLayout.OnRefreshListener listener):设置手势滑动监听器。

2、setProgressBackgroundColor(int colorRes):设置进度圈的背景色。

3、setColorSchemeResources(int… colorResIds):设置进度动画的颜色。

4、setRefreshing(Boolean refreshing):设置组件的刷洗状态。

5、setSize(int size):设置进度圈的大小,只有两个值:DEFAULT、LARGE

弄清楚API后,我们下面进行实际编码,首先先做布局,具体内容如下:

 
 
 
 
  1.  
  2.     xmlns:android="http://schemas.android.com/apk/res/android" 
  3.     android:layout_width="match_parent" 
  4.     android:layout_height="match_parent" 
  5.     android:orientation="vertical" 
  6.     android:id="@+id/swipeLayout" > 
  7.       
  8.     
  9.         android:id="@+id/mylist" 
  10.         android:layout_width="match_parent" 
  11.         android:layout_height="wrap_content"/> 
  12.      
  13.  

#p#

Activity核心代码如下:

 
 
 
 
  1. swipeRefreshLayout = (SwipeRefreshLayout)findViewById(R.id.swipeLayout); 
  2.  
  3.         swipeRefreshLayout.setColorSchemeResources(R.color.swipe_color_1, 
  4.                 R.color.swipe_color_2, 
  5.                 R.color.swipe_color_3, 
  6.                 R.color.swipe_color_4); 
  7.         swipeRefreshLayout.setSize(SwipeRefreshLayout.LARGE);; 
  8.         swipeRefreshLayout.setProgressBackgroundColor(R.color.swipe_background_color); 
  9.         //swipeRefreshLayout.setPadding(20, 20, 20, 20); 
  10.         //swipeRefreshLayout.setProgressViewOffset(true, 100, 200); 
  11.         //swipeRefreshLayout.setDistanceToTriggerSync(50); 
  12.         swipeRefreshLayout.setProgressViewEndTarget(true, 100); 
  13.         swipeRefreshLayout.setOnRefreshListener(new OnRefreshListener() { 
  14.             @Override 
  15.             public void onRefresh() { 
  16.                 new Thread(new Runnable() { 
  17.                     @Override 
  18.                     public void run() { 
  19.                         data.clear(); 
  20.                         for(int i=0;i<20;i++){ 
  21.                             data.add("SwipeRefreshLayout下拉刷新"+i); 
  22.                         } 
  23.                         try { 
  24.                             Thread.sleep(5000); 
  25.                         } catch (InterruptedException e) { 
  26.                             e.printStackTrace(); 
  27.                         } 
  28.                         mHandler.sendEmptyMessage(1); 
  29.                     } 
  30.                 }).start(); 
  31.             } 
  32.         }); 
  33.     //handler 
  34.     private Handler mHandler = new Handler(){ 
  35.         @Override 
  36.         public void handleMessage(Message msg) { 
  37.             super.handleMessage(msg); 
  38.             switch (msg.what) { 
  39.             case 1: 
  40.                  
  41.                 swipeRefreshLayout.setRefreshing(false); 
  42.                 adapter.notifyDataSetChanged(); 
  43.                 //swipeRefreshLayout.setEnabled(false); 
  44.                 break; 
  45.             default: 
  46.                 break; 
  47.             } 
  48.         } 
  49.     }; 

通过如上步骤,我们就实现了一个简单的下拉刷新操作,在此基础上,我们可以分析研究一下SwipeRefreshLayout是如何实现的。

通过源码我们发现SwipeRefreshLayout中的两个重要的属性:

private MaterialProgressDrawable mProgress;

private CircleImageView mCircleView;
这两个属性正是用于实现进度动画效果的,在方法createProgressView中,我们看到mCircleView最终加入到了SwipeRefreshLayout中。

private void createProgressView() {
mCircleView = new CircleImageView(getContext(), CIRCLE_BG_LIGHT, CIRCLE_DIAMETER/2);
mProgress = new MaterialProgressDrawable(getContext(), this);
mProgress.setBackgroundColor(CIRCLE_BG_LIGHT);
mCircleView.setImageDrawable(mProgress);
mCircleView.setVisibility(View.GONE);
addView(mCircleView);
}

同时我们也可以查看到CirlceImageView继承了ImageView,MaterialProgressDrawabel继承了Drawable,至此我们也就明白了下来进度动画是如何实现的了,具体的细节在不做过多赘述,可自行查看源码

lass CircleImageView extends ImageView

class MaterialProgressDrawable extends Drawable implements Animatable

具体的下拉功能实现主要是在onInterceptTouchEvent、onTouchEvent方法中完成的,在此我就不在将具体代码贴出来了,大家可自行查看。

当前名称:android之官方下拉刷新组件SwipeRefreshLayout
文章出自:http://www.csdahua.cn/qtweb/news49/118199.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网