Android,在Tabhost中具有手势检测器的ViewFlipper
我想制作一个tabhost,我想在一个活动中添加一个viewflipper。 此活动适用于tabhost。 我已经写了,但什么不起作用。有人知道我该怎么做吗?我希望他们明白我想要什么 我想在这个动作中使用手势检测器。我可以用按钮更改图片,但用手指无法更改。我以前做过。(AimToActivity.java)Android,在Tabhost中具有手势检测器的ViewFlipper,android,viewflipper,android-tabhost,gesturedetector,Android,Viewflipper,Android Tabhost,Gesturedetector,我想制作一个tabhost,我想在一个活动中添加一个viewflipper。 此活动适用于tabhost。 我已经写了,但什么不起作用。有人知道我该怎么做吗?我希望他们明白我想要什么 我想在这个动作中使用手势检测器。我可以用按钮更改图片,但用手指无法更改。我以前做过。(AimToActivity.java) 只需实现您自己的手势检测器,然后在选项卡活动中注册一个ontouch监听器 顺便说一下,我还使用TabHost中的ViewFlipper实现了幻灯片动画 myTabHostActivity
只需实现您自己的
手势检测器
,然后在选项卡活动中注册一个ontouch监听器
顺便说一下,我还使用TabHost
中的ViewFlipper
实现了幻灯片动画
myTabHostActivity
private static final int SWIPE_MIN_DISTANCE = 180;
private static final int SWIPE_MAX_OFF_PATH = 250;
private static final int SWIPE_THRESHOLD_VELOCITY = 200;
private GestureDetector gestureDetector;
View.OnTouchListener gestureListener;
public void onCreate(Bundle savedInstanceState) {
....
gestureDetector = new GestureDetector(new MyGestureDetector());
gestureListener = new View.OnTouchListener() {
public boolean onTouch(View v, MotionEvent event) {
if (gestureDetector.onTouchEvent(event)) {
return true;
}
return false;
}
};
class MyGestureDetector extends SimpleOnGestureListener {
@Override
public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,
float velocityY) {
TabHost tabHost = getTabHost();
try {
if (Math.abs(e1.getY() - e2.getY()) > SWIPE_MAX_OFF_PATH)
return false;
// right to left swipe, tab change to right
if (e1.getX() - e2.getX() > SWIPE_MIN_DISTANCE
&& Math.abs(velocityX) > SWIPE_THRESHOLD_VELOCITY) {
Log.i("Gesture ", "right");
if (currentView == maxTabIndex) {
currentView = 0;
} else {
currentView++;
}
viewFlipperBody.setInAnimation(slideLeftIn);
viewFlipperBody.setOutAnimation(slideLeftOut);
viewFlipperBody.setDisplayedChild(currentView);
} else if (e2.getX() - e1.getX() > SWIPE_MIN_DISTANCE
&& Math.abs(velocityX) > SWIPE_THRESHOLD_VELOCITY) {
Log.i("Gesture ", "left");
if (currentView == 0) {
currentView = maxTabIndex;
} else {
currentView--;
}
viewFlipperBody.setInAnimation(slideRightIn);
viewFlipperBody.setOutAnimation(slideRightOut);
viewFlipperBody.setDisplayedChild(currentView);
}
} catch (Exception e) {
// nothing
e.printStackTrace();
}
tabHost.setCurrentTab(currentView);
return false;
}
}
@Override
public boolean dispatchTouchEvent(MotionEvent event) {
if (gestureDetector.onTouchEvent(event)) {
event.setAction(MotionEvent.ACTION_CANCEL);
}
return super.dispatchTouchEvent(event);
}