您好,登錄后才能下訂單哦!
Android 側滑關閉Activity的實例
實現原因
其實側滑關閉activity在網上也有大量的文章去介紹他,我也有去看,要么是代碼實在太多看不下去,要么就是跑了項目沒有反應的。唯一的方法還是自己隨手魯一個~,側滑這個東西在Android中是比較少見的,iOS是最常見不過了,因為畢竟他們沒有物理返回鍵。還有UIScrollView那些。然而我們用的最多的QQ也只是有個功能,并沒有真正的滑動效果。至于微信的,我記得N久以前滑出了一個bug。也沒什么印象了。估計也是極小的概率事件。于是,當初我就強行的魯了一個。下面我們一步步分析實現的思路以及代碼。
百行代碼解決側滑關閉
首先來看下我們一些簡單的定義:
private Activity activity; private Scroller scroller; //上次ACTION_MOVE時的X坐標 private int last_X; //屏幕寬度 private int width; //可滑動的最小X坐標,小于該坐標的滑動不處理 private int min_X; // 頁面邊緣的陰影圖 private Drawable left_shodow; //頁面邊緣陰影的寬度默認值 private static final int SHADOW_WIDTH = 16; // 頁面邊緣陰影的寬度 private int shadow_width; // Activity finish標識符 private boolean isFinish;
這邊我已經注釋過了,就不做過多就寫了。接下來,我們看下我們的一些初始化已經外部調用方法:
private void initView(Activity activity) { this.activity = activity; scroller = new Scroller(activity); left_shodow = getResources().getDrawable(R.drawable.left_shadow); int density = (int) activity.getResources().getDisplayMetrics().density; shadow_width = SHADOW_WIDTH * density; // 這里你一定要設置成透明背景,不然會影響你看到底層布局 setBackgroundColor(Color.argb(0, 0, 0, 0)); } public void bindActivity(Activity activity) { ViewGroup decorView = (ViewGroup) activity.getWindow().getDecorView(); View child = decorView.getChildAt(0); decorView.removeView(child); addView(child); decorView.addView(this);
我們主要看下bindactivity這個方法。這個是我們用來綁定一個activity的。這個activity你們可以基于baseactivity實現一個backactivity。為什么要這么做,因為你每個activity都要寫這么一句話,我感覺就是浪費時間,一個基類直接解決。這個activity我們可以這么寫:
public abstract class SWBackActivity extends Activity { protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); SWBackLayout layout = new SWBackLayout(this); layout.bindActivity(this); } protected abstract void afterInject(); protected abstract void afterInitView(); }
那么接下來我們看下,如果對手勢的處理讓他側滑關閉呢?
public boolean onTouchEvent(MotionEvent event) { switch (event.getAction()) { case MotionEvent.ACTION_DOWN: last_X = (int) event.getX(); width = getWidth(); min_X = width / 10; break; case MotionEvent.ACTION_MOVE: int rightMovedX = last_X - (int) event.getX(); if (getScrollX() + rightMovedX >= 0) {// 左側即將滑出屏幕 scrollTo(0, 0); } else if ((int) event.getX() > min_X) {// 手指處于屏幕邊緣時不處理滑動 scrollBy(rightMovedX, 0); } last_X = (int) event.getX(); break; case MotionEvent.ACTION_UP: if (-getScrollX() < width / 3) { scrollBack(); isFinish = false; } else { scrollClose(); isFinish = true; } break; } return true; } private void scrollBack() { int startX = getScrollX(); int dx = -getScrollX(); scroller.startScroll(startX, 0, dx, 0, 300); invalidate(); } private void scrollClose() { int startX = getScrollX(); int dx = -getScrollX() - width; scroller.startScroll(startX, 0, dx, 0, 300); invalidate(); } public void computeScroll() { if (scroller.computeScrollOffset()) { scrollTo(scroller.getCurrX(), 0); postInvalidate(); } else if (isFinish) { activity.finish(); } super.computeScroll(); } protected void dispatchDraw(Canvas canvas) { super.dispatchDraw(canvas); drawShadow(canvas); } private void drawShadow(Canvas canvas) { // 保存畫布當前的狀態 canvas.save(); // 設置drawable的大小范圍 left_shodow.setBounds(0, 0, shadow_width, getHeight()); // 讓畫布平移一定距離 canvas.translate(-shadow_width, 0); // 繪制Drawable left_shodow.draw(canvas); // 恢復畫布的狀態 canvas.restore(); }
首先我們在ACTION_DOWN記錄按下點的X坐標
然后在ACTION_MOVE中判斷,如果我們getScrollX() + rightMovedX是否是大于0的,如果大于0,表示Activity處于滑動狀態,并且是向左滑動,同時我們進行了判斷,手指處于屏幕邊緣時不可以滑動。
最后在ACTION_UP中判斷如果手指滑動的距離大于布局寬度的1/3,表示將Activity滑出界面,否則滑動到起始位置,我們利用Scroller類的startScroll()方法設置好開始位置,滑動距離和時間,然后調用postInvalidate()刷新界面,之后就到computeScroll()方法中,我們利用scrollTo()方法對該布局的父布局進行滾動,滾動結束之后,我們判斷界面是否滑出界面,如果是那就劃出頁面讓activity finish掉。否則,布局就歸位。
使用方法
其實使用方法很簡單,直接繼承SWBackActivity就可以了。那么我們最后來看下效果圖:
以上就是實現Android 側滑關閉Activity 的實例,如有疑問請留言或者到本站社區交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。