Android 随手势滑动销毁(finish)Activity

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

         首先看实现的最终效果:

wKiom1Wd5YaiPahBAAS6hzkZW1o097.gif

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

1、主页面Activity

package 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"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" >
    <translate
        android:duration="300"
        android:fromXDelta="100.0%"
        android:interpolator="@android:anim/decelerate_interpolator"
        android:toXDelta="0.0%" />
</set>

   base_slide_right_out.xml

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" >

    <translate
        android:duration="300"
        android:fromXDelta="0.0%"
        android:interpolator="@android:anim/accelerate_interpolator"
        android:toXDelta="100.0%" />
</set>


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

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

你可能感兴趣的:(android)