温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Android 侧滑关闭Activity的实例

发布时间:2020-10-20 13:43:32 来源:脚本之家 阅读:325 作者:我就是马云飞 栏目:移动开发

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的实例

以上就是实现Android 侧滑关闭Activity 的实例,如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI