用代碼實例詳解Android如何使用下拉刷新PtrFrameLayout

小編這次要給大家分享的是用代碼實例詳解Android如何使用下拉刷新PtrFrameLayout,文章內(nèi)容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。

創(chuàng)新互聯(lián)擁有網(wǎng)站維護技術(shù)和項目管理團隊,建立的售前、實施和售后服務體系,為客戶提供定制化的網(wǎng)站設計制作、成都網(wǎng)站制作、網(wǎng)站維護、成都移動機房托管解決方案。為客戶網(wǎng)站安全和日常運維提供整體管家式外包優(yōu)質(zhì)服務。我們的網(wǎng)站維護服務覆蓋集團企業(yè)、上市公司、外企網(wǎng)站、商城網(wǎng)站制作、政府網(wǎng)站等各類型客戶群體,為全球1000多家企業(yè)提供全方位網(wǎng)站維護、服務器維護解決方案。

1.介紹:

  1. 可以包含所有的控件 :ListView, GridView, ScrollView, FrameLayout, 甚至 TextView.
  2. 可以自定義刷新頭(這點非常實用)
  3. 使用簡單方便

不足就是不支持上拉加載.

2.使用

首先添加依賴到項目

compile 'in.srain.cube:ultra-ptr:1.0.11'

在Xml中使用

<in.srain.cube.views.ptr.PtrFrameLayout
 xmlns:android="http://schemas.android.com/apk/res/android"
 xmlns:tools="http://schemas.android.com/tools"
 xmlns:app="http://schemas.android.com/apk/res-auto"
 android:id="@+id/food_refreshLayout"
 android:layout_width="match_parent"
 android:layout_height="match_parent"
 app:ptr_resistance="1.7"       //設置下拉的阻尼系數(shù),值越大感覺越難下拉
 app:ptr_ratio_of_header_height_to_refresh="1.2"  //設置超過頭部的多少時,釋放可以執(zhí)行刷新操作
 app:ptr_duration_to_close="200"        //:設置下拉回彈的時間
 app:ptr_duration_to_close_header="300"  //設刷新完成,頭部回彈時間,注意和前一個進行區(qū)別
 app:ptr_keep_header_when_refresh="true"  //設置刷新的時候是否保持頭部
 app:ptr_pull_to_fresh="false">    //設置下拉過程中執(zhí)行刷新,我們一般設置為false

 <ScrollView
   android:layout_width="match_parent"
   android:layout_height="match_parent"
  >
  </ScrollView>

</in.srain.cube.views.ptr.PtrFrameLayout>

在代碼中使用

在代碼中使用非常簡單,簡單幾部搞定:

1.找到控件,添加頭部刷新布局

mFoodRefreshLayout = (PtrFrameLayout) findViewById(R.id.food_refreshLayout);
//這里是一個自定義的頭部刷新布局,自帶的也有一個布局  new PtrDefaultHandler(); 
PtrClassicHeader header = new PtrClassicHeader(this); 
//將頭布局添加
mFoodRefreshLayout.addPtrUIHandler(header);

2.不僅僅是添加頭布局,還需要設置到控件中 注:特別重要,不然沒顯示

mFoodRefreshLayout.setHeaderView(header); //設置刷新頭布局

3.給刷新控件設置下拉監(jiān)聽

mFoodRefreshLayout.setPtrHandler(new PtrHandler() {
 @Override
 public void onRefreshBegin(PtrFrameLayout frame) {
  //在這里寫自己下拉刷新數(shù)據(jù)的請求
  //需要結(jié)束刷新頭
   mFoodRefreshLayout.refreshComplete();
 }

 @Override
 public boolean checkCanDoRefresh(PtrFrameLayout frame, View content, View header) {
   // 默認實現(xiàn),根據(jù)實際情況做改動
   return PtrDefaultHandler.checkContentCanBePulledDown(frame, content, header);
 }
});

3.自定義請求頭

上面是對基本使用進行了介紹,相信大家在使用下拉刷新時都需要用到自定義布局,其實也很簡單,在上面代碼添加刷新頭時就創(chuàng)建自定義的頭部即可,下面對自定義頭部的幾個方法做簡單介紹:

public class PtrClassicHeader extends FrameLayout implements PtrUIHandler{ //實現(xiàn)接口
  private ImageView mPush;
  //在代碼創(chuàng)建對象
  public PtrClassicHeader(Context context) {
    super(context);
    initView();  
  }
  public PtrClassicHeader(Context context, AttributeSet attrs) {
    super(context, attrs);
    initView();
  }
  public PtrClassicHeader(Context context, AttributeSet attrs, int defStyleAttr) {
    super(context, attrs, defStyleAttr);
    initView();
  }

  //初始化自定義布局文件
  private void initView() {
  //這里加載自定義的布局文件
  View header =  LayoutInflater.from(getContext()).inflate(R.layout.item_push_header_layout, this);
  //找到布局內(nèi)部的控件
    mPush = (ImageView) header.findViewById(R.id.header_iv);
  }

  //定義一個動畫,方便下面的調(diào)用
  public void initAnim(){
    ObjectAnimator anim = ObjectAnimator.ofFloat(mPush, "rotation", 0f, 180f);
    anim.setDuration(500);
    anim.start();

  }
  //初始化狀態(tài)
  @Override
  public void onUIReset(PtrFrameLayout frame) {
    //這個方法可以不用管  也可以在這里關(guān)閉動畫
  }

  //開始向下拉的時候調(diào)用
  @Override
  public void onUIRefreshPrepare(PtrFrameLayout frame) {
      initAnim(); //這里可以執(zhí)行動畫效果
  }

  //刷新過程時調(diào)用
  @Override
  public void onUIRefreshBegin(PtrFrameLayout frame) {
      //可以不斷的改變動畫效果以及切換顯示的控件
      //判斷是否可以刷新 
    if (frame.isPullToRefresh()) {
      mTitleTextView.setText("釋放刷新");
    } else {
      mTitleTextView.setText("下拉加載");
    }
  }

  //刷新完成后調(diào)用,向上移動時調(diào)用
  @Override
  public void onUIRefreshComplete(PtrFrameLayout frame) {
    //可以不斷的改變動畫效果以及切換顯示的控件
     mTitleTextView.setText("加載中...");
    animationDrawable.stop(); //模擬動畫
    animationDrawable.start();
  }

  //重復下拉
  @Override
  public void onUIPositionChange(PtrFrameLayout frame, boolean isUnderTouch, byte status, PtrIndicator ptrIndicator) {
    //在同一次下拉中不斷向上向下移動,這里可以不斷改變顯示效果
    //示例代碼: 可以當模板使用 
    final int mOffsetToRefresh = frame.getOffsetToRefresh();
    final int currentPos = ptrIndicator.getCurrentPosY(); //獲取到下拉的高度
    final int lastPos = ptrIndicator.getLastPosY();   //最大下拉的高度
    //根據(jù)下拉的位置進行控件的顯示
    if (currentPos < mOffsetToRefresh && lastPos >= mOffsetToRefresh) {
      if (isUnderTouch && status == PtrFrameLayout.PTR_STATUS_PREPARE) {
        crossRotateLineFromBottomUnderTouch(frame); //調(diào)用方法
      }
    } else if (currentPos > mOffsetToRefresh && lastPos <= mOffsetToRefresh) {
      if (isUnderTouch && status == PtrFrameLayout.PTR_STATUS_PREPARE) {
        crossRotateLineFromTopUnderTouch(frame); //調(diào)用方法
      }
    }
  }
  //下拉到可以刷新時顯示
  private void crossRotateLineFromTopUnderTouch(PtrFrameLayout frame) {
    if (!frame.isPullToRefresh()) {
      mTitleTextView.setText("釋放刷新");
    }
  }
  //動態(tài)改變文字
  private void crossRotateLineFromBottomUnderTouch(PtrFrameLayout frame) {
    if (frame.isPullToRefresh()) {
      mTitleTextView.setText("釋放刷新");
    } else {
      mTitleTextView.setText("下拉加載");
    }
  }
  }
}

4.解決沖突

ViewPager滑動沖突: 直接調(diào)用: disableWhenHorizontalMove()

看完這篇關(guān)于用代碼實例詳解Android如何使用下拉刷新PtrFrameLayout的文章,如果覺得文章內(nèi)容寫得不錯的話,可以把它分享出去給更多人看到。

分享標題:用代碼實例詳解Android如何使用下拉刷新PtrFrameLayout
鏈接地址:http://bm7419.com/article42/iihjhc.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)頁設計公司、微信公眾號網(wǎng)站制作、移動網(wǎng)站建設網(wǎng)站策劃、全網(wǎng)營銷推廣

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設公司