成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

android之官方下拉刷新組件SwipeRefreshLayout

移動開發 Android

一、問題描述

在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. <?xml version="1.0" encoding="utf-8"?> 
  2. <android.support.v4.widget.SwipeRefreshLayout  
  3.     xmlns:android="http://schemas.android.com/apk/res/android" 
  4.     android:layout_width="match_parent" 
  5.     android:layout_height="match_parent" 
  6.     android:orientation="vertical" 
  7.     android:id="@+id/swipeLayout" > 
  8.       
  9.     <ListView  
  10.         android:id="@+id/mylist" 
  11.         android:layout_width="match_parent" 
  12.         android:layout_height="wrap_content"/> 
  13.      
  14. </android.support.v4.widget.SwipeRefreshLayout> 

#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(true100); 
  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方法中完成的,在此我就不在將具體代碼貼出來了,大家可自行查看。

責任編輯:chenqingxiang 來源: 博客園
相關推薦

2017-03-20 19:40:29

AndroidSwipeRefres下拉刷新

2021-09-02 10:00:42

鴻蒙HarmonyOS應用

2015-03-19 10:12:36

下拉刷新開源組件

2011-03-17 08:58:09

數據儲存Data StoragAndroid API

2015-03-23 18:11:39

UITableViewswift下拉刷新

2016-08-05 17:01:09

AndroidRecyclerVie下拉刷新

2015-05-13 09:36:18

js模擬手機下拉刷新

2024-07-02 10:00:55

2021-12-01 10:02:57

鴻蒙HarmonyOS應用

2016-12-09 09:23:50

android組件Service

2011-09-07 14:20:42

Android Wid組件

2011-09-08 15:29:50

Android Wid界面GridView

2010-08-04 10:17:17

Android開發WebView組件

2012-03-28 22:16:54

蘋果

2011-10-26 10:21:40

Sencha Touc組件

2013-07-17 16:33:02

下拉刷新listvie滾動到底部加載Android開發學習

2013-01-10 14:21:24

Android開發組件Activities

2011-05-31 15:09:02

Android SDK 官方下載

2016-12-13 17:02:49

androidjava移動應用開發

2011-07-13 14:28:09

STL算法
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产成人精品一区二区三区网站观看 | 日韩三区在线 | 男女爱爱福利视频 | 91麻豆精品国产91久久久久久 | 亚洲福利在线观看 | 麻豆精品一区二区三区在线观看 | 亚洲网站在线观看 | 黄色大片免费网站 | 国产精品视频一区二区三区 | 99久久精品免费看国产四区 | 精品国产一区二区三区性色av | 国产精品久久久久一区二区 | 精品中文字幕一区 | 亚洲一区视频在线 | 久久久免费精品 | 亚洲综合在线一区 | 精品熟人一区二区三区四区 | 国产精品久久久久久婷婷天堂 | 久久成人久久 | 亚洲视频在线一区 | 国产资源在线视频 | 国产精品免费大片 | 青青久在线视频 | 国产综合久久 | 99久久久久| 久久中文字幕电影 | 一区二区福利视频 | 免费在线观看黄网站 | 欧美精品在线播放 | 国产农村妇女毛片精品久久麻豆 | 日韩精品1区2区 | 一区中文字幕 | 日韩av免费在线观看 | 日本免费视频在线观看 | av在线播放网址 | 91色视频在线观看 | 性一爱一乱一交一视频 | 美女久久久久久久 | 一区二区三区四区在线免费观看 | 国产中文视频 | 综合精品久久久 |