今天给大家带来一个向右滑动销毁Activity的效果,Activtiy随着手指的移动而销毁,滑动销毁Activity主要使用GestureDetector来实现这个效果,当手势在屏幕上面滑动的时候 ,会掉用onFling方法,所以,在这个方法里面做判断和操作即可实现我们想要的效果。
首先看实现的最终效果:
好了直接上代码,相信你会看懂的
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
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。