HTML、CSS、JavaScriptを使用してAndroidアプリケーションを開発しています。私のアプリケーションは Phonegap フレームワークに依存しています。アプリケーションは、かなりの数のローカル ページで構成されています。アプリケーションでは、Android モバイルでスワイプ ジェスチャ イベントを処理し、スワイプの方向に応じてページを移動しようとしています。つまり、ユーザーが左にスワイプした場合、アプリケーションは前のページを呼び出す必要があり、ユーザーが右にスワイプした場合、アプリケーションはユーザーを次のページに転送します。
Android用のネイティブJavaを使用してそれを行うことができます。しかし、問題は、ページの呼び出し中に、要求されたページのスライド効果を実行していることです。しかし、何が起こるかは、現在のページが要求されたページではなくスライド効果を取ることです.アニメーションの長さを遅らせてみましたが、遅くなりすぎて退屈になり、ところでそれを達成できませんでした。
この問題で私を助けてくれること、またはその効果を達成するためのアプローチやメカニズムを私に提案してくれることを願っています.
これが私のコードです:
public class App extends DroidGap {
/** Called when the activity is first created. */
private static final int SWIPE_MIN_DISTANCE = 120;
private static final int SWIPE_MAX_OFF_PATH = 250;
private static final int SWIPE_THRESHOLD_VELOCITY = 200;
private GestureDetector gestureDetector;
View.OnTouchListener gestureListener;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
gestureDetector = new GestureDetector(new MyGestureDetector());
gestureListener = new View.OnTouchListener() {
public boolean onTouch(View v, MotionEvent event) {
if (gestureDetector.onTouchEvent(event)) {
return true;
}
return false;
}
};
super.loadUrl("file:///android_asset/www/index.html");
}
class MyGestureDetector extends SimpleOnGestureListener {
@Override
public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {
try {
if (Math.abs(e1.getY() - e2.getY()) > SWIPE_MAX_OFF_PATH)
return false;
// right to left swipe
if(e1.getX() - e2.getX() > SWIPE_MIN_DISTANCE && Math.abs(velocityX) > SWIPE_THRESHOLD_VELOCITY) {
appView.startAnimation(AnimationUtils.loadAnimation(getApplicationContext(), R.anim.slide_left));
appView.goBack();
} else if (e2.getX() - e1.getX() > SWIPE_MIN_DISTANCE && Math.abs(velocityX) > SWIPE_THRESHOLD_VELOCITY) {
appView.startAnimation(AnimationUtils.loadAnimation(getApplicationContext(), R.anim.slide_right_in));
appView.goForward();
}
} catch (Exception e) {
// nothing
}
return false;
}
}
@Override
public boolean dispatchTouchEvent(MotionEvent e){
super.dispatchTouchEvent(e);
return gestureDetector.onTouchEvent(e);
}
}