手势分两种
- 手势监听器(手势检测)(GestureDetector,手势检测器)
- 添加手势
类
- GestureDetector
- GestureDetector.OnGestureListener
- 有6个方法
使用手势检测步骤
- 创建一个GestureDetector对象,创建对象的同时要实现一个GestureDetector.OnGestureListener监听器实例
- 为应用程序的Activity(也可是其他组件)的TouchEvent事件绑定监听器,在事件处理中指定Activity上的TouchEvent事件交给GestureDetector处理
Activity(其他)上的TouchEvent事件交给GestureDetector处理,GestureDetector可以检测是否触发了特定的手势动作
package shj;
import android.app.Activity;
import android.os.Bundle;
import android.view.GestureDetector;
import android.view.MotionEvent;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
import android.widget.Toast;
import com.loopj.android.http.AsyncHttpClient;
import com.loopj.android.http.AsyncHttpResponseHandler;
import com.obdpay.obdpay.R;
import cz.msebera.android.httpclient.Header;
/**
* Created by shj on 2016/2/29 0029.
*/
public class MyHttpTest extends Activity implements GestureDetector.OnGestureListener{
private GestureDetector detector;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.myhttptest);
//创建手势检测器
//参数:Context,OnGestureListener,因为actiivty实现了这个监听器,所以将activity当作了监听器
detector = new GestureDetector(this,this);
}
@Override
public boolean onTouchEvent(MotionEvent event) {
//将activity的onTouchEvent事件交给detector处理
return detector.onTouchEvent(event);
}
@Override
public boolean onDown(MotionEvent e) {
Toast.makeText(this,"onDown",Toast.LENGTH_SHORT).show();
//什么意思?
return false;
}
@Override
public void onShowPress(MotionEvent e) {
Toast.makeText(this,"onShowPress",Toast.LENGTH_SHORT).show();
//这里没有return,当然,void类型好吗
}
@Override
public boolean onSingleTapUp(MotionEvent e) {
Toast.makeText(this,"onSingleTapUp",Toast.LENGTH_SHORT).show();
return false;
}
@Override
public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) {
Toast.makeText(this,"onScroll",Toast.LENGTH_SHORT).show();
return false;
}
@Override
public void onLongPress(MotionEvent e) {
Toast.makeText(this,"onLongPress",Toast.LENGTH_SHORT).show();
}
@Override
public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {
Toast.makeText(this,"onFling",Toast.LENGTH_SHORT).show();
return false;
}
}
总结:
每次都会触发onDown,
轻点与长按很容易区分
onShowPress有点难
onScroll会持续很长时间
ViewFlipper
ViewFlipper可以通过动画来控制多个组件之间的切换效果
用手势来控制ViewFlipper包含的View的组件的切换