Android實現Activity的滑動返回效果
介紹
在知乎客戶端上看到了這種效果,左滑Activity可以返回到上一介面,非常適合單手操作。
找了很久,終於在github上看到了SwipeBackLayout這個開源專案,地址:
實現
需要使用到的類:
SwipeBackActivity.java SwipeBackLayout.java ViewDragHelper.java
使當前的Activity繼承SwipeBackActivity
public class BaseActivity extends SwipeBackActivity { private SwipeBackLayout mSwipeBackLayout; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); mSwipeBackLayout = getSwipeBackLayout(); //設定滑動方向,可設定EDGE_LEFT, EDGE_RIGHT, EDGE_ALL, EDGE_BOTTOM mSwipeBackLayout.setEdgeTrackingEnabled(SwipeBackLayout.EDGE_LEFT); } }
在使用的主題中新增下面的屬性,否則滑動時activity的下層是黑色的
<item name="android:windowIsTranslucent">true</item>
當使用BaseActivity時,為了使首頁不會滑動刪除,只需如下設定即可
setSwipeBackEnable(false); //禁止滑動刪除
- 另外,這個滑動刪除的效果只能從邊界滑動才有效果,如果要擴大touch的範圍,可以呼叫
mSwipeBackLayout.setEdgeSize(int size);
但是上面這個方法不太好用,效果不明顯,推薦修改ViewDragHelper.java這個類原始碼中的getEdgeTouched(int x, int y)方法,如下
private int getEdgeTouched(int x, int y) { int result = 0; result = EDGE_LEFT;//這樣每次都是全屏左滑刪除 //解決只有點選螢幕左邊才有響應的問題 /*if (x < mParentView.getLeft() + mEdgeSize) result = EDGE_LEFT; if (y < mParentView.getTop() + mEdgeSize) result = EDGE_TOP; if (x > mParentView.getRight() - mEdgeSize) result = EDGE_RIGHT; if (y > mParentView.getBottom() - mEdgeSize) result = EDGE_BOTTOM;*/ return result; }
經過上面步驟,應該就能如期實現效果了。
下面放上我的Demo截圖:
這是Demo原始碼
開發工具:Android Studio
相關文章
- Activity側滑返回的實現原理
- android 全域性頁面滑動返回聯動效果的實現Android
- 考拉Android全域性滑動返回及聯動效果的實現Android
- Android 進出activity的滑動動畫效果Android動畫
- Android左右滑動效果的程式碼實現Android
- 仿 “即刻APP” 滑動返回的效果APP
- iOS6下實現滑動返回iOS
- Android滑動返回-swipebacklayout解析Android
- jquery實現滑動門效果詳解jQuery
- Android側滑返回分析和實現(不高仿微信)Android
- iOS 實現UINavigation全屏滑動返回(二)iOSUINavigation
- 微信小程式實現卡片左右滑動效果微信小程式
- (十)如果實現滑動展示選單效果
- Android 設定TextView滑動滾動條和滑動效果AndroidTextView
- CSS實現頁面切換時的滑動效果CSS
- jquery實現的滑動軸效果程式碼例項jQuery
- android: slide 滑動動畫效果AndroidIDE動畫
- 用Activity的onTouchEvent方法實現監聽手指上下左右滑動
- 純CSS3實現滑動開關效果CSSS3
- activity切換無動畫效果的實現動畫
- Android 的滑動分析以及各種實現Android
- Android右滑關閉Activity介面功能-自定義控制元件實現Android控制元件
- Swift全屏滑動返回Swift
- ListView 實現帶有Filpper效果的左右滑動刪除 ItemView
- Flutter 仿iOS側滑返回案例實現FlutteriOS
- Android可滑動Tab的3種實現方法Android
- jQuery 效果 – 滑動jQuery
- Android切換Activity的動畫效果Android動畫
- css實現的滑鼠滑過星星高亮效果CSS
- 短視訊平臺搭建,實現banner自動滑動展示效果
- iOS7滑動返回iOS
- 手機直播原始碼,實現圖片瀑布流式滑動效果原始碼
- 直播app開發,實現輪播圖上下自動滑動展示效果APP
- Android側滑(右滑、下拉)返回控制元件 - SwipeBackLayoutAndroid控制元件
- android 自定義ImageView實現圖片手勢滑動,多點觸控放大縮小效果AndroidView
- Flutter 實現類似美團外賣店鋪頁面滑動效果Flutter
- 小程式 — 實現左滑刪除效果(列表)③
- 登入頁Activity從下向上的彈出效果實現