通过DecorView实现app全局activity右滑退出

在公司项目中使用了一个侧滑的开源项目com.jeremyfeinstein.slidingmenu.lib,一直没有时间研究,只是知道大概的用法。但“会用”一直不是我最终的追求!于是趁着项目刚上线的空档期,好好的看了下它的源码。搞懂了它的原理,为我对app全局activity右滑退出的实现提供了一个很好的思路。

1 侧滑项目的源码

1.1 创建过程

public SlidingMenu(Activity activity, int slideStyle) {
    this(activity, null);
    this.attachToActivity(activity, slideStyle);
}

1.2 attachToActivity

switch (slideStyle) {
    case SLIDING_WINDOW:
        mActionbarOverlay = false;
        ViewGroup decor = (ViewGroup) activity.getWindow().getDecorView();
        ViewGroup decorChild = (ViewGroup) decor.getChildAt(0);
        // save ActionBar themes that have transparent assets
        decorChild.setBackgroundResource(background);
        decor.removeView(decorChild);
        decor.addView(this);
            setContent(decorChild);
        break;
    case SLIDING_CONTENT:
        mActionbarOverlay = actionbarOverlay;
        // take the above view out of
        ViewGroup contentParent = (ViewGroup)activity.findViewById(android.R.id.content);
        View content = contentParent.getChildAt(0);
        contentParent.removeView(content);
        contentParent.addView(this);
        setContent(content);
        // save people from having transparent backgrounds
        if (content.getBackground() == null)
            content.setBackgroundResource(background);
        break;
}

分析上边代码

1.2.1 获取装载activity视图的根view:DecorView

1.2.2 获取activity的视图并保存在decorChild:decor.getChildAt(0)

1.2.3 DecorView移除activity的视图

1.2.4 DecorView添加SlidingMenu

1.2.5 SlidingMenu再将activity的视图

整体的思路就是:对activity的视图再添加了一层父view,将侧滑的实现都放在了SlidingMenu中

2 activity右滑退出实现思路

2.1 首先,为了让所有的activity都支持该特性,需要定义一个BaseActivity,让需要该特性的activity都继承该类

2.2 实现一个支持手势右滑消失的SlideView

2.3 参照侧滑的整体思路,将activity的视图添加到Slid中

3 具体实现

3.1 BaseActivity的实现

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    ViewGroup decorView = (ViewGroup)getWindow().getDecorView();
    View contentView = decorView.getChildAt(0);
    decorView.removeViewAt(0);
    SlideView slideView = new SlideView(this,contentView);
    decorView.addView(slideView,0);
}

主要就是在oncreate中将Slideview添加到根view中去

3.2 SlideView的实现

这里主要又回到了自定义view的范畴

3.2.1 在onInterceptTouchEvent()中,假如为水平滑动,并且滑动的距离到达一定数值,就拦截该事件

3.2.2 在onTouchEvent()中处理ACTION_MOVE和ACTION_UP事件

3.2.2.1 ACTION_MOVE:主要是根据滑动的距离,调用setTranslationX移动视图

3.2.2.2 ACTION_UP:有两种情况:

当滑动的距离小于一定的值(可根据自己的需要设置)时,让slideview向左移动回到正常位置

当滑动的距离大于一定的值时,让slideview向右移动直到消失,这个可通过属性动画完成。我们可以通过addListener对动画进行监听,当slideview刚好完全消失时,调用activity的finish()方法关闭activity

3 其他的联想

现在市面很多公司都会规范整个app的风格,要求整体统一。这就会有一个需求,需要大部分的activity采用统一的titlebar。其实,这个也可以通过本篇文章的思路实现。这次就先这样吧,有机会再一起研究下activity统一titlebar的实现

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值