页面销毁清除动画android,Android 随手势滑动销毁(finish)Activity

本文介绍了如何在Android应用中使用GestureDetector实现Activity的向右滑动销毁效果,通过重写onFling方法,结合动画过渡,让Activity随着手指滑动自然关闭。关键代码和动画文件也一并分享。
摘要由CSDN通过智能技术生成

今天给大家带来一个向右滑动销毁Activity的效果,Activtiy随着手指的移动而销毁,滑动销毁Activity主要使用GestureDetector来实现这个效果,当手势在屏幕上面滑动的时候 ,会掉用onFling方法,所以,在这个方法里面做判断和操作即可实现我们想要的效果。

首先看实现的最终效果:

2a52480656ca5f4ef0e350cdd85a7dd1.gif

好了直接上代码,相信你会看懂的

1、主页面Activitypackage com.sunny.slidingfinish;

import android.os.Bundle;

import android.view.GestureDetector;

import android.view.MotionEvent;

import android.view.View;

import android.view.View.OnClickListener;

import android.widget.Button;

import android.app.Activity;

import android.content.Intent;

public class MainActivity extends Activity {

private Button mButton;

private GestureDetector mGestureDetector;

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

setContentView(R.layout.activity_main);

mButton = (Button) findViewById(R.id.btn1);

mButton.setOnClickListener(new OnClickListener() {

@Override

public void onClick(View arg0) {

// TODO 自动生成的方法存根

startActivity(new Intent(MainActivity.this,Aty1.class));

}

});

//1.重写 GestureDetector的onFling方法

mGestureDetector = new GestureDetector(this, new GestureDetector.SimpleOnGestureListener() {

@Override

public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {

/**

* 当手势滑动的时候,关闭页面的效果,具体需求具体对待

* 向下滑动,向上滑动,向右滑动(常用使用该方式)

*/

// 手势向下 down

if ((e2.getRawY() - e1.getRawY()) > 200) {

//finish();//在此处控制关闭

return true;

}

// 手势向上 up

if ((e1.getRawY() - e2.getRawY()) > 200) {

//finish();//在此处控制关闭

return true;

}

// 控制只右滑

if (e2.getX() - e1.getX() > 0

&& (e1.getX() >= 0 && e1.getX() <= 100)) {

if (Math.abs(e2.getX() - e1.getX()) > Math.abs(e2.getY() - e1.getY())

&& Math.abs(velocityX) > 1000) {

overridePendingTransition(R.anim.base_slide_right_in,

R.anim.base_slide_right_out);

finish();

onBackPressed();

}

}

return super.onFling(e1, e2, velocityX, velocityY);

}

});

}

//2.让手势识别器 工作起来,当activity被触摸的时候调用的方法.

@Override

public boolean onTouchEvent(MotionEvent event) {

mGestureDetector.onTouchEvent(event);

return super.onTouchEvent(event);

}

@Override

public void onBackPressed() {

// TODO 自动生成的方法存根

super.onBackPressed();

overridePendingTransition(0, R.anim.base_slide_right_out);

}

}

2、实现右滑动画效果

动画效果实现,重写右滑动画效果,可以使用Android自带的一个方法,在finish()方法之前进行调用:

overridePendingTransition(R.anim.slide_up_in, R.anim.slide_up_out);

base_slide_right_in.xml<?xml  version="1.0" encoding="utf-8"?>

android:duration="300"

android:fromXDelta="100.0%"

android:interpolator="@android:anim/decelerate_interpolator"

android:toXDelta="0.0%" />

base_slide_right_out.xml<?xml  version="1.0" encoding="utf-8"?>

android:duration="300"

android:fromXDelta="0.0%"

android:interpolator="@android:anim/accelerate_interpolator"

android:toXDelta="100.0%" />

以上就是实现Activity手势滑动效果的具体实现,代码已详细注释,不做太多解释,相信你可以看懂的,欢迎大家一块学习交流~~

下载地址:http://down.51cto.com/data/2066383

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值