中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android開發之使用150行代碼實現滑動返回效果

發布時間:2020-08-27 02:13:20 來源:腳本之家 閱讀:130 作者:程序亦非猿 欄目:移動開發

今天帶大家實現滑動返回效果.,具體內容如下所示:

先看看效果圖:

Android開發之使用150行代碼實現滑動返回效果

因為沒有具體內容,也沒有簡書的圖片資源,所以稍微簡陋了點.
但是依然不妨礙我們的效果展示~
OK,接下來慣例,通過閱讀本文你能學習到:

ViewDragHelper的使用(如果你想學習自定義View,那么ViewDragHelper你絕對不能錯過)

好像也沒有什么了....

這個效果,難度不大,會ViewDragHelper的同學應該10分鐘就能寫出來了吧~

如果不會也沒關系~

1. 我們自定義一個SwipeBackFrameLayout繼承自FrameLayout

1.1 因為看到左邊黃色的View是被遮住的,而另外一個View的寬度是MatchParent的,所以FrameLayout是不錯的選擇.
順便增加一個回調,通知activity去finish

public void setCallback(Callback mCallback){
 this.mCallback = mCallback;
}
private Callback mCallback;
public interface Callback{
 void onShouldFinish();
}

1.2 Xml布局,非常簡單:

<yifeiyuan.practice.practicedemos.drager.SwipeBackFrameLayout 
xmlns:android="http://schemas.android.com/apk/res/android" 
xmlns:tools="http://schemas.android.com/tools" 
android:id="@+id/swipe_back"
android:layout_width="match_parent" 
android:layout_height="match_parent" 
tools:context="yifeiyuan.practice.practicedemos.drager.SwipeBackActivity">
 <TextView
  android:layout_width="40dp"  
  android:layout_height="match_parent"  
  android:text="@string/hello_world"
  android:gravity="center"
  android:background="#ffff00"
  />
 <View
  android:layout_width="match_parent"  
  android:layout_height="match_parent"
  android:background="#ff00ff"
  />
</yifeiyuan.practice.practicedemos.drager.SwipeBackFrameLayout>

1.3 實例化一個ViewDragHelper

//1f代表靈敏度 
mDragHelper = ViewDragHelper.create(this, 1f,new ViewDragHelper.Callback() {
 @Override
 public boolean tryCaptureView(View child, int pointerId) {
  return false;
 }
}
//因為我們是從左向右滑動 所以設置EDGE_LEFT
mDragHelper.setEdgeTrackingEnabled(ViewDragHelper.EDGE_LEFT);

1.4 在SwipeBackFrameLayout里實例化xml里的子View

private View mDividerView;
private View mContentView;
@Override
protected void onFinishInflate() {
 super.onFinishInflate(); 
 mDividerView = getChildAt(0);
 mDividerView.setAlpha(0f);
 mContentView = getChildAt(1);
}

1.5 讓ViewDragHelper處理touch事件

@Override
public boolean onInterceptTouchEvent(MotionEvent ev) {
 return mDragHelper.shouldInterceptTouchEvent(ev);
}

@Override
public boolean onTouchEvent(MotionEvent event) { 
 mDragHelper.processTouchEvent(event);
 return true;
}

1.6重寫ViewDragHelper的一些處理方法

已附上詳細注釋

@Override
public void onEdgeTouched(int edgeFlags, int pointerId) { 
 super.onEdgeTouched(edgeFlags, pointerId); 
 //觸摸到左邊界的時候 我們capture住mContentView   
 mDragHelper.captureChildView(mContentView, pointerId); 
}   
@Override   
public int getViewHorizontalDragRange(View child) {
  return 1;  
}
   
@Override 
public void onViewPositionChanged(View changedView, int left, int top, int dx, int dy) {
  super.onViewPositionChanged(changedView, left, top, dx, dy);
  Log.d(TAG, "onViewPositionChanged() called with left = [" + left + "], top = [" + top + "], dx = [" + dx + "], dy = [" + dy + "]"); 
  //0.0 - 1.0
  //Notice 這邊可以給個接口回調出去,就可以做各種炫酷的效果了      
  float alpha = (float) (left*1.0/mDividerWidth); 
  mDividerView.setAlpha(alpha);   
} 
  @Override
  public int clampViewPositionHorizontal(View child, int left, int dx) {
//    Log.d(TAG, "clampViewPositionHorizontal() called with dx = [" + dx + "]");
  // 計算left 我們的目標范圍是0-dividerwidth的寬度
  mLastdx = dx; 
  int newLeft = Math.min(mDividerWidth, Math.max(left,0));       
  return newLeft; 
}   
  @Override   
  public void onViewReleased(View releasedChild, float xvel, float yvel) {    
  //>0代表用戶想關閉    
  if (mLastdx>0){
  // 還不到關閉條件,我們讓view滑動過去,再關閉     
  if (mDividerWidth != releasedChild.getLeft()) { 
  mDragHelper.settleCapturedViewAt(mDividerWidth,releasedChild.getTop();
  invalidate(); 
} else { 
  if (mCallback != null) { 
   mCallback.onShouldFinish(); 
  }  
} 
}else{   
  //用戶不想關閉 ,則滑動到最左邊
  if (mDividerWidth != 0) { 
   mDragHelper.settleCapturedViewAt(0, releasedChild.getTop()); 
   invalidate(); 
  }
}   
}   
  @Override   
  public void onViewDragStateChanged(int state) { 
    super.onViewDragStateChanged(state); 
//滑動停止,并且到達了滑動的判斷條件 則回調關閉
if(mDragHelper.getViewDragState()==ViewDragHelper.STATE_IDLE&&mCallback != null&&mDividerWidth==mContentView.getLeft()&&mLastdx>0) {     
mCallback.onShouldFinish(); 
    }
   }
  });

1.7 增加對view滑動事件處理,對于以上mDividerWidth我們在onLayout里獲取

private int mDividerWidth;
@Override
protected void onLayout(boolean changed, int left, int top, int right, int bottom) {
 super.onLayout(changed, left, top, right, bottom);
 mDividerWidth = mDividerView.getWidth();
}
//Notice view 剛初始化的時候就會被調用一次
 @Override
 public void computeScroll() {
  super.computeScroll();
  //  Log.d(TAG, "computeScroll() called with " + ""); 
 if (mDragHelper.continueSettling(true)) {
  invalidate();
  }
}

我們寫完自定義view后還需要自定義一下activity的退出動畫~

2.定義activity的finish動畫

2.1 在anim目錄下,創建兩個動畫xml:

//no_anim
<alpha
android:duration="300" 
xmlns:android="http://schemas.android.com/apk/res/android" 
android:fromAlpha="1.0"
android:toAlpha="1.0"
></alpha>

//out_to_right
<translate 
xmlns:android="http://schemas.android.com/apk/res/android" 
android:duration="300" 
android:fromXDelta="0%" 
android:toXDelta="100%" 
></translate>

2.2 在activity里設置callback監聽,并運用動畫

mSwipeBack.setCallback(new SwipeBackFrameLayout.Callback() { 
 @Override
 public void onShouldFinish() {
  finish();
  overridePendingTransition(R.anim.no_anim, R.anim.out_to_right);
 }
});

好了!!代碼量非常少!就是這么簡單~

吐槽一下,簡書對代碼塊的支持太差了,代碼復制過來全是亂的!!
同學們還是去看源碼吧:

源碼在我的Github上

總結

以上所述是小編給大家介紹的教你150行代碼實現滑動返回效果的代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對億速云網站的支持!
如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

仁寿县| 柳林县| 永定县| 遂昌县| 精河县| 团风县| 诸城市| 吴旗县| 吴堡县| 龙海市| 神池县| 都兰县| 滁州市| 陵川县| 兴国县| 永平县| 慈利县| 鞍山市| 文登市| 昌吉市| 河北区| 保德县| 鹤岗市| 云和县| 龙泉市| 确山县| 东莞市| 永德县| 绵阳市| 华坪县| 紫金县| 新建县| 浑源县| 昌吉市| 长泰县| 保德县| 什邡市| 抚州市| 拉萨市| 金华市| 英超|