Skip to content Skip to sidebar Skip to footer

Android - Show/hide Textview Using Swipe Left To Right

I'm trying to show/hide TextView. So if the user swipe left-to-right, it will show TextView from behind the 'orange gradient view'. And after the text shown, after 5 seconds, it wi

Solution 1:

Here is the xml file

<LinearLayoutxmlns: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>

Now use this class

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
 */publicclassOnSwipeTouchListenerimplementsOnTouchListener {

    private final GestureDetector gestureDetector;

    publicOnSwipeTouchListener(Context ctx) {
        gestureDetector = newGestureDetector(ctx, newGestureListener());
    }

    @OverridepublicbooleanonTouch(View v, MotionEvent event) {
        return gestureDetector.onTouchEvent(event);
    }

    private final classGestureListenerextendsSimpleOnGestureListener {

        privatestatic final int SWIPE_THRESHOLD = 1;
        privatestatic final int SWIPE_VELOCITY_THRESHOLD = 1;

        @OverridepublicbooleanonDown(MotionEvent e) {
            returntrue;
        }

        @OverridepublicbooleanonFling(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;
                } elseif (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;
        }
    }

    publicvoidonSwipeRight() {
    }

    publicvoidonSwipeLeft() {
    }

    publicvoidonSwipeTop() {
    }

    publicvoidonSwipeBottom() {
    }
}

In your MainActivity.java class use below code

//llMain is the root layout of your xml where you want to perform swipe 
        llMain.setOnTouchListener(newOnSwipeTouchListener(ThemeSelectionActivity.this) {
            @OverridepublicvoidonSwipeLeft() {
                super.onSwipeLeft();

                }
            }

            @OverridepublicvoidonSwipeRight() {
                super.onSwipeRight();

    // Put your logic here for text visibility and for timer like progress bar for 5 second and setText 
            }
        });

Solution 2:

Create a directory anim inside the res directory and put this as slide.xml

<?xml version="1.0" encoding="utf-8"?><setxmlns:android="http://schemas.android.com/apk/res/android"android:interpolator="@android:anim/linear_interpolator"android:fillAfter="true"><translateandroid:fromXDelta="0%p"android:toXDelta="75%p"android:duration="800" /></set>

Use below method for animation

/**
     * Animate the swipe rightto left
     *
     * @param context context of the activity or fragment
     */privatevoidanimImage(final Context context) {
        // Load the animation like thisfinalAnimationanimRightToLeft= AnimationUtils.loadAnimation(context, R.anim.anim_move_right_to_left);
        textViewObject.setLayerType(View.LAYER_TYPE_HARDWARE, null);
        // Start the animation like this
        textViewObject.startAnimation(animRightToLeft);
    }

// Now on MainActivity 
llMain.setOnTouchListener(newOnSwipeTouchListener(ThemeSelectionActivity.this) {
            @OverridepublicvoidonSwipeLeft() {
                super.onSwipeLeft();

                }
            }

            @OverridepublicvoidonSwipeRight() {
                super.onSwipeRight();
animImage(getApplicationContext());
            }
        });

Post a Comment for "Android - Show/hide Textview Using Swipe Left To Right"