Android屏幕页面的滑动切换和抽取父类_html/css_WEB-ITnose

WBOY
풀어 주다: 2016-06-24 11:47:07
원래의
1104명이 탐색했습니다.

因为页面的滑动效果在整个应用中使用较多,所有抽取成父类来介绍,看代码注释

import android.app.Activity;import android.content.SharedPreferences;import android.os.Bundle;import android.view.GestureDetector;import android.view.MotionEvent;import android.view.View;import android.view.GestureDetector.SimpleOnGestureListener;import android.widget.Toast;//定义抽象方法showNext,由基类根据需要实现,其注意功能就是滑动切换,可以按123步骤学习public abstract class BaseSetupActivity extends Activity {	//1.定义一个手势识别器		private GestureDetector detector;				protected SharedPreferences sp;		@Override		protected void onCreate(Bundle savedInstanceState) {			// TODO Auto-generated method stub			super.onCreate(savedInstanceState);			sp = getSharedPreferences("config", MODE_PRIVATE);			//2.实例化这个手势识别器,GestureDetector.SimpleOnGestureListener需要单独引用			detector = new GestureDetector(this, new SimpleOnGestureListener(){				/**				 * 当我们的手指在上面滑动的时候回调				 */				@Override				public boolean onFling(MotionEvent e1, MotionEvent e2,						float velocityX, float velocityY) {										//屏蔽在X滑动很慢的情形					if(Math.abs(velocityX) 100){						Toast.makeText(getApplicationContext(), "不能这样滑", 0).show();												return true;					}										if((e2.getRawX() - e1.getRawX())> 200 ){						//显示上一个页面:从左往右滑动						System.out.println("显示上一个页面:从左往右滑动");						showPre();						return true;											}										if((e1.getRawX()-e2.getRawX()) > 200 ){						//显示下一个页面:从右往左滑动						System.out.println("显示下一个页面:从右往左滑动");						showNext();						return true;					}										return super.onFling(e1, e2, velocityX, velocityY);				}							});		}				public abstract void showNext();		public abstract void showPre();		/**		 * 下一步的点击事件		 * @param view		 */		public void next(View view){			showNext();					}				/**		 *   上一步		 * @param view		 */		public void pre(View view){			showPre();					}					//3.使用手势识别器		@Override		public boolean onTouchEvent(MotionEvent event) {			detector.onTouchEvent(event);			return super.onTouchEvent(event);		}}
로그인 후 복사

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿