Android 高仿最新版微信 6.2 手势滑动返回(带阴影)
在很多Demo中,通过手势返回的的Activity 一般侧边不带阴影以及底下的Activity没有随之偏移。
Features
- 和 Activity 的 theme 并无关系
- 不影响 activity 的生命周期
- 只需继承 BaseActivity
isSupportSwipeBack
唯一 API 方法,简单实用- 无需设置
<item name="android:windowIsTranslucent">true</item>
- 支持 Dialog 的滑动返回
Usage
主要思想
Application 在 Api14 之后添加了新的 Callback 方法
public void registerActivityLifecycleCallbacks(ActivityLifecycleCallbacks callback) {}
这样就可以根据 activity 的生命周期缓存所有 Activity,通过 list 获取上一个 activity 的实例,从而获取 id 为 content 的 ContentView 的子 View(即 setContentView 中的 View),并进行滑动展示。
包括以下 6 中状态
private static final int MSG_ACTION_DOWN = 1; //点击事件
private static final int MSG_ACTION_MOVE = 2; //滑动事件
private static final int MSG_ACTION_UP = 3; //点击结束
private static final int MSG_SLIDE_CANCEL = 4; //开始滑动,不返回前一个页面
private static final int MSG_SLIDE_CANCELED = 5; //结束滑动,不返回前一个页面
private static final int MSG_SLIDE_PROCEED = 6; //开始滑动,返回前一个页面
private static final int MSG_SLIDE_FINISHED = 7;//结束滑动,返回前一个页面
- 在 Down 手势发生时,只要将上一个 Activity 的 ContentView 从 parentView 中剥离,并加入到当前 View 的 ContentView 中;
- 在滑动手势发生时,加上阴影 View,并进行滑动;同时滑动的有当前 Activity 的 ContentView、上一个 Activity 的 ContentView 和自定义的阴影 View;
- 在 Up 手势发生时,判断滑动是否超过半屏,触发返回操作,并展示滑动动画;
- 滑动取消或滑动返回发生时,需要将上个 Activity 的 ContentView 从新加入到上一个 Acitivity 的布局中。
自定义方法
默认 activity 是支持滑动返回的,不需要返回的则需要复写 Baseactivity 的以下方法
public class BaseActivity extends AppCompatActivity {
private static final String TAG = "BaseActivity";
private SwipeWindowHelper mSwipeWindowHelper;
@Override
public boolean dispatchTouchEvent(MotionEvent ev) {
if(!supportSlideBack()) {
return super.dispatchTouchEvent(ev);
}
if(mSwipeWindowHelper == null) {
mSwipeWindowHelper = new SwipeWindowHelper(getWindow());
}
return mSwipeWindowHelper.processTouchEvent(ev) || super.dispatchTouchEvent(ev);
}
/**
* 是否支持滑动返回
*
* @return
*/
protected boolean supportSlideBack() {
return true;
}
}
demo:
http://download.csdn.net/detail/gjy_it/9716844