android仿微信右滑finish窗口实现

很久以前就对微信的这个改进大呼惊艳(今天发现ios系统上几乎每个应用都有这样的设定,果然人的眼界需要放高放远,是时候买个iphone压压惊),也想在android上实现一番,这几天恰好有个机会来实践一波。

最终目标:

  • 界面左侧100dp内右滑finish窗口操作的实现

参考资料:

  1. Android-通过SlidingPaneLayout高仿微信6.2最新版手势滑动返回(一)

    参看:demo

    android仿微信右滑finish窗口实现_第1张图片
  2. Android-通过SlidingMenu高仿微信6.2最新版手势滑动返回(二)

    参看:demo

    SlidingMenu与SlidingPanelLayout的区别:

    其实实现的原理都一样,只不过是把SlidingPaneLayout换成SlidingMenu而已,不过SlidingMenu本身的功能比官方自带的强大,不仅可以实现像微信一样的边缘滑动返回,还支持全屏幕滑动返回。你还可以添加动画效果

  3. android仿微信6.2右滑返回

    参看:demo

    作者做出的demo比较有些缺憾,一旦在界面上ACTION_DOWN,整个界面的最左侧就直接移动到了手指按下的位置。原理是使用onTouchListener建了一个继承于LinearLayout的TouchLinearLayout,作为页面的根布局。

实践过程:

一开始使用了第三项资料中的方式,它的实现需要与布局文件相关而且完成得不好,调试了几遍没有结果,应该是我的View的事件分发机制没有学好,带我看完《Android开发艺术探索》相关章节,应该会有更深的理解,暂时还是放弃了。
接着改用资料二中的SlidingPanelLayout,只需要改写我现有的BaseActivity,主要步骤如下:

  1. 在manifest为执行这一操作的Activity加上android:theme
    "@style/JK.SwipeBack.Transparent.Theme"
    具体看这里:styles.xml
  2. 在BaseActivity的onCreate()中添加initSwipeBackFinish()
    代码看这里:BaseActivity.java
  3. implements SlidingPaneLayout .PanelSlideListener 共三个方法——
    onPanelClosed:进行过一次右滑但是最终弹回远处 onPanelOpened:进行过一次右滑且最终关闭了界面
    onPanelSlide:界面滑动中
  4. 要实现这个滑动finish操作的始末两个Activity都必须继承BaseActivity

目前的结果:

  • 尚未达到最终目标,但在整个界面内可以实现右滑finish,怎样限定在界面左侧100dp内还需要进一步考虑。

你可能感兴趣的:(android仿微信右滑finish窗口实现)