Touch gesture in Android with source code By Zoranin Tutorials - February 3, 2022 Comments: 0 Views: 693 ObjectiveThe main objective of this blog post is to give you an idea about Android Gestures in Android Studio.We are making a simple pinch zoom application hereTouch gesture: It is when a user places one or more fingers on the touch screen, and the application understands that as a signal or GESTURE. It has mainly two phases: Detect and Track data about touch events. Interpretation of that data as certain gesture by the application.Android provides some of the common touch events such as a pinch, double tap, scrolls, flinch, long presses etc. known as gestures.Android provides GestureDetector class to detect some of the basic motion events like Single Tap up, Long Press etc. It gathers data and tells us whether it is a gesture or not. To use it, you need to create an object of GestureDetector and then extend another class with GestureDetector.SimpleOnGestureListener to act as a listener and override some methods.Syntax:GestureDetector myG; myG = new GestureDetector(this,new Gesture()); class Gesture extends GestureDetector.SimpleOnGestureListener{ public boolean onSingleTapUp(MotionEvent ev) { } public void onLongPress(MotionEvent ev) { } public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX, float distanceY) { } public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) { } } }Now, to handle some gestures like pinch zoom you need to use ScaleGestureDetector class.We will make a simple application for pinch zoom.If you are new in Android Studio and don’t know how to create a new project then you should checkout our blog:Create New Project in Android StudioStep 1 activity_main.xmlTake imageview and set scaletype as matrix.<span style="font-family: Lato, sans-serif;"><span style="font-size: 16px; line-height: 24px; white-space: normal;"> </span></span><RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" > <ImageView android:id="@+id/ivDemo" android:layout_width="match_parent" android:layout_height="match_parent" android:scaleType="matrix" android:src="@drawable/ic_launcher" /> </RelativeLayout>Step 2 Create a ScaleGestureDetector class object.scaleGestureDetector = new ScaleGestureDetector(this, new ScaleListener());Here you can see we are passing ScaleListner class. It is extended by ScaleGestureDetector.SimpleOnScaleGestureListenerprivate class ScaleListener extends ScaleGestureDetector.SimpleOnScaleGestureListener { @Override public boolean onScale(ScaleGestureDetector detector) { return false; } }To learn more about ScaleGestureDetector please refer following link:http://developer.android.com/reference/android/view/ScaleGestureDetector.htmlTo learn more about ScaleGestureDetector.SimpleOnScaleGestureListener please refer following link:http://developer.android.com/reference/android/view/ScaleGestureDetector.SimpleOnScaleGestureListener.htmlStep 3 Register ScaleGestureDetector class to TouchEvent method.Here we are Overriding TouchEvent method so that TouchEvent of pinch can be detected by ScaleGestureDetector.@Override public boolean onTouchEvent(MotionEvent ev) { scaleGestureDetector.onTouchEvent(ev); return true; }Step 4 MainActivity.java filePaste the following code in MainActivity.javapackage com.tag.blog.androidgesturesdemo; import android.app.Activity; import android.graphics.Matrix; import android.os.Bundle; import android.view.MotionEvent; import android.view.ScaleGestureDetector; import android.widget.ImageView; public class MainActivity extends Activity { private ImageView img; private Matrix matrix = new Matrix(); private float scale = 1f; private ScaleGestureDetector scaleGestureDetector; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); img = (ImageView) findViewById(R.id.ivDemo); scaleGestureDetector = new ScaleGestureDetector(this, new ScaleListener()); } @Override public boolean onTouchEvent(MotionEvent ev) { scaleGestureDetector.onTouchEvent(ev); return true; } private class ScaleListener extends ScaleGestureDetector.SimpleOnScaleGestureListener { @Override public boolean onScale(ScaleGestureDetector detector) { scale *= detector.getScaleFactor(); scale = Math.max(0.1f, Math.min(scale, 5.0f)); matrix.setScale(scale, scale); img.setImageMatrix(matrix); return true; } } }Step 5 Run ApplicationLaunch the application in any real device. Now, use pinch zoom and see that the image zooms and shrinks as per the gesture.ScreenshotsLet me know in comment if you have any questions regarding Android App Development. I will reply you ASAP.
How to develop your first app with React Native I want to talk a little about what React Native is, why it is important and popular now, and January 24, 2022 Tutorials
Important little things when developing mobile applications Probably, you have repeatedly searched the markets for a mobile application for some keyword, January 13, 2022 Blog
How to quickly write an Android game with Unity At the present time, anyone can become a successful mobile game or application developer without January 9, 2022 Tutorials