Voici le fichier xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/activity_theme_sel_ll_main"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical">
<!--Add your content here for texview and whatever -->
</LinearLayout>
utilisent maintenant cette classe
import android.content.Context;
import android.view.GestureDetector;
import android.view.GestureDetector.SimpleOnGestureListener;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnTouchListener;
/**
* This TouchListener is Using for very First time ThemeSelection Screen with SwipeLeft Finger
*/
public class OnSwipeTouchListener implements OnTouchListener {
private final GestureDetector gestureDetector;
public OnSwipeTouchListener(Context ctx) {
gestureDetector = new GestureDetector(ctx, new GestureListener());
}
@Override
public boolean onTouch(View v, MotionEvent event) {
return gestureDetector.onTouchEvent(event);
}
private final class GestureListener extends SimpleOnGestureListener {
private static final int SWIPE_THRESHOLD = 1;
private static final int SWIPE_VELOCITY_THRESHOLD = 1;
@Override
public boolean onDown(MotionEvent e) {
return true;
}
@Override
public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {
boolean result = false;
try {
float diffY = e2.getY() - e1.getY();
float diffX = e2.getX() - e1.getX();
if (Math.abs(diffX) > Math.abs(diffY)) {
if (Math.abs(diffX) > SWIPE_THRESHOLD && Math.abs(velocityX) > SWIPE_VELOCITY_THRESHOLD) {
if (diffX > 0) {
onSwipeRight();
} else {
onSwipeLeft();
}
}
result = true;
} else if (Math.abs(diffY) > SWIPE_THRESHOLD && Math.abs(velocityY) > SWIPE_VELOCITY_THRESHOLD) {
if (diffY > 0) {
onSwipeBottom();
} else {
onSwipeTop();
}
}
result = true;
} catch (Exception exception) {
exception.printStackTrace();
}
return result;
}
}
public void onSwipeRight() {
}
public void onSwipeLeft() {
}
public void onSwipeTop() {
}
public void onSwipeBottom() {
}
}
Dans votre utilisation de classe MainActivity.java ci-dessous le code
//llMain is the root layout of your xml where you want to perform swipe
llMain.setOnTouchListener(new OnSwipeTouchListener(ThemeSelectionActivity.this) {
@Override
public void onSwipeLeft() {
super.onSwipeLeft();
}
}
@Override
public void onSwipeRight() {
super.onSwipeRight();
// Put your logic here for text visibility and for timer like progress bar for 5 second and setText
}
});
Faites-les l'une sur l'autre et Google et recherche ceci: GestureDetector, Android animation – Gudin
pour développer ce que @gudin a écrit. placez-les tous les deux dans un framelayout avec le dégradé en haut, lorsqu'un geste est détecté sur le widget dégradé orange, animez une animation diapositive droite (lorsque l'animation est terminée, définissez le dégradé orange INVISIBLE avec un écouteur d'animation). Créez un nouveau gestionnaire postdelayed pendant cinq secondes et lorsque cela est terminé, faites glisser le dégradé orange ou le rendre visible à nouveau. –
@BradleyWilson: pouvez-vous me donner un exemple, s'il vous plaît? si le geste x pos est au centre, comment puis-je mettre en pause l'animation à la moitié de la largeur du widget dégradé orange? – wdyz