您好,登錄后才能下訂單哦!
小編這次要給大家分享的是用代碼實例詳解Android如何使用下拉刷新PtrFrameLayout,文章內容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。
1.介紹:
不足就是不支持上拉加載.
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" //設置下拉的阻尼系數,值越大感覺越難下拉 app:ptr_ratio_of_header_height_to_refresh="1.2" //設置超過頭部的多少時,釋放可以執行刷新操作 app:ptr_duration_to_close="200" //:設置下拉回彈的時間 app:ptr_duration_to_close_header="300" //設刷新完成,頭部回彈時間,注意和前一個進行區別 app:ptr_keep_header_when_refresh="true" //設置刷新的時候是否保持頭部 app:ptr_pull_to_fresh="false"> //設置下拉過程中執行刷新,我們一般設置為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.給刷新控件設置下拉監聽
mFoodRefreshLayout.setPtrHandler(new PtrHandler() { @Override public void onRefreshBegin(PtrFrameLayout frame) { //在這里寫自己下拉刷新數據的請求 //需要結束刷新頭 mFoodRefreshLayout.refreshComplete(); } @Override public boolean checkCanDoRefresh(PtrFrameLayout frame, View content, View header) { // 默認實現,根據實際情況做改動 return PtrDefaultHandler.checkContentCanBePulledDown(frame, content, header); } });
3.自定義請求頭
上面是對基本使用進行了介紹,相信大家在使用下拉刷新時都需要用到自定義布局,其實也很簡單,在上面代碼添加刷新頭時就創建自定義的頭部即可,下面對自定義頭部的幾個方法做簡單介紹:
public class PtrClassicHeader extends FrameLayout implements PtrUIHandler{ //實現接口 private ImageView mPush; //在代碼創建對象 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); //找到布局內部的控件 mPush = (ImageView) header.findViewById(R.id.header_iv); } //定義一個動畫,方便下面的調用 public void initAnim(){ ObjectAnimator anim = ObjectAnimator.ofFloat(mPush, "rotation", 0f, 180f); anim.setDuration(500); anim.start(); } //初始化狀態 @Override public void onUIReset(PtrFrameLayout frame) { //這個方法可以不用管 也可以在這里關閉動畫 } //開始向下拉的時候調用 @Override public void onUIRefreshPrepare(PtrFrameLayout frame) { initAnim(); //這里可以執行動畫效果 } //刷新過程時調用 @Override public void onUIRefreshBegin(PtrFrameLayout frame) { //可以不斷的改變動畫效果以及切換顯示的控件 //判斷是否可以刷新 if (frame.isPullToRefresh()) { mTitleTextView.setText("釋放刷新"); } else { mTitleTextView.setText("下拉加載"); } } //刷新完成后調用,向上移動時調用 @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(); //最大下拉的高度 //根據下拉的位置進行控件的顯示 if (currentPos < mOffsetToRefresh && lastPos >= mOffsetToRefresh) { if (isUnderTouch && status == PtrFrameLayout.PTR_STATUS_PREPARE) { crossRotateLineFromBottomUnderTouch(frame); //調用方法 } } else if (currentPos > mOffsetToRefresh && lastPos <= mOffsetToRefresh) { if (isUnderTouch && status == PtrFrameLayout.PTR_STATUS_PREPARE) { crossRotateLineFromTopUnderTouch(frame); //調用方法 } } } //下拉到可以刷新時顯示 private void crossRotateLineFromTopUnderTouch(PtrFrameLayout frame) { if (!frame.isPullToRefresh()) { mTitleTextView.setText("釋放刷新"); } } //動態改變文字 private void crossRotateLineFromBottomUnderTouch(PtrFrameLayout frame) { if (frame.isPullToRefresh()) { mTitleTextView.setText("釋放刷新"); } else { mTitleTextView.setText("下拉加載"); } } } }
4.解決沖突
ViewPager滑動沖突: 直接調用: disableWhenHorizontalMove()
看完這篇關于用代碼實例詳解Android如何使用下拉刷新PtrFrameLayout的文章,如果覺得文章內容寫得不錯的話,可以把它分享出去給更多人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。