Android - Gesten

Android bietet spezielle Arten von Touchscreen-Ereignissen wie Kneifen, doppeltes Tippen, Scrollen, langes Drücken und Zucken. Dies sind alles als Gesten bekannt.

Android bietet die GestureDetector-Klasse, um Bewegungsereignisse zu empfangen und uns mitzuteilen, ob diese Ereignisse Gesten entsprechen oder nicht. Um es zu verwenden, müssen Sie ein Objekt von GestureDetector erstellen und dann eine weitere Klasse mit erweiternGestureDetector.SimpleOnGestureListenerals Zuhörer zu fungieren und einige Methoden zu überschreiben. Die Syntax ist unten angegeben -

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) {
   }
}

Umgang mit Prise Geste

Android bietet ScaleGestureDetectorKlasse, um Gesten wie Quetschen usw. zu handhaben Um sie zu verwenden, müssen Sie ein Objekt dieser Klasse instanziieren. Die Syntax lautet wie folgt:

ScaleGestureDetector SGD;
SGD = new ScaleGestureDetector(this,new ScaleListener());

Der erste Parameter ist der Kontext und der zweite Parameter ist der Ereignis-Listener. Wir müssen den Ereignis-Listener definieren und eine Funktion überschreibenOnTouchEventdamit es funktioniert. Die Syntax ist unten angegeben -

public boolean onTouchEvent(MotionEvent ev) {
   SGD.onTouchEvent(ev);
   return true;
}

private class ScaleListener extends ScaleGestureDetector.SimpleOnScaleGestureListener {
   @Override
   public boolean onScale(ScaleGestureDetector detector) {
      float scale = detector.getScaleFactor();
      return true;
   }
}

Neben den Quetschgesten stehen noch andere Methoden zur Verfügung, die mehr über Berührungsereignisse informieren. Sie sind unten aufgeführt -

Sr.Nr. Methode & Beschreibung
1

getEventTime()

Diese Methode ermittelt die Ereigniszeit des aktuellen Ereignisses, das verarbeitet wird.

2

getFocusX()

Diese Methode ermittelt die X-Koordinate des Brennpunkts der aktuellen Geste.

3

getFocusY()

Diese Methode ermittelt die Y-Koordinate des Brennpunkts der aktuellen Geste.

4

getTimeDelta()

Diese Methode gibt die Zeitdifferenz in Millisekunden zwischen dem zuvor akzeptierten Skalierungsereignis und dem aktuellen Skalierungsereignis zurück.

5

isInProgress()

Diese Methode gibt true zurück, wenn eine Skalierungsgeste ausgeführt wird.

6

onTouchEvent(MotionEvent event)

Diese Methode akzeptiert MotionEvents und löst gegebenenfalls Ereignisse aus.

Beispiel

Hier ist ein Beispiel, das die Verwendung der ScaleGestureDetector-Klasse demonstriert. Es wird eine Basisanwendung erstellt, mit der Sie durch Prise hinein- und herauszoomen können.

Um mit diesem Beispiel zu experimentieren, können Sie dies auf einem tatsächlichen Gerät oder in einem Emulator mit aktiviertem Touchscreen ausführen.

Schritte Beschreibung
1 Sie werden Android Studio verwenden, um eine Android-Anwendung unter einem Paket com.example.sairamkrishna.myapplication zu erstellen.
2 Ändern Sie die Datei src / MainActivity.java, um den erforderlichen Code hinzuzufügen.
3 Ändern Sie res / layout / activity_main, um entsprechende XML-Komponenten hinzuzufügen
4 Führen Sie die Anwendung aus und wählen Sie ein laufendes Android-Gerät aus. Installieren Sie die Anwendung darauf und überprüfen Sie die Ergebnisse

Es folgt der Inhalt der geänderten Hauptaktivitätsdatei src/MainActivity.java.

package com.example.sairamkrishna.myapplication;

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 iv;
   private Matrix matrix = new Matrix();
   private float scale = 1f;
   private ScaleGestureDetector SGD;

   @Override
   protected void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.activity_main);

      iv=(ImageView)findViewById(R.id.imageView);
      SGD = new ScaleGestureDetector(this,new ScaleListener());
   }

   public boolean onTouchEvent(MotionEvent ev) {
      SGD.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);
         iv.setImageMatrix(matrix);
         return true;
      }
   }
}

Es folgt der geänderte Inhalt der XML res/layout/activity_main.xml.

Hier zeigt abc das Logo von tutorialspoint an
<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:paddingLeft="@dimen/activity_horizontal_margin"
   android:paddingRight="@dimen/activity_horizontal_margin"
   android:paddingTop="@dimen/activity_vertical_margin"
   android:paddingBottom="@dimen/activity_vertical_margin" 
   tools:context=".MainActivity" >
   
   <TextView android:text="Gestures  
      Example" android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:id="@+id/textview"
      android:textSize="35dp"
      android:layout_alignParentTop="true"
      android:layout_centerHorizontal="true" />
      
   <TextView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="Tutorials point"
      android:id="@+id/textView"
      android:layout_below="@+id/textview"
      android:layout_centerHorizontal="true"
      android:textColor="#ff7aff24"
      android:textSize="35dp" />
      
   <ImageView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:id="@+id/imageView"
      android:src="@drawable/abc"
      android:scaleType="matrix"
      android:layout_below="@+id/textView"
      android:layout_alignParentLeft="true"
      android:layout_alignParentStart="true"
      android:layout_alignParentBottom="true"
      android:layout_alignParentRight="true"
      android:layout_alignParentEnd="true" />
      
</RelativeLayout>

Es folgt der Inhalt der res/values/string.xml.

<resources>
   <string name="app_name>My Application</string>
</resources>

Es folgt der Inhalt von AndroidManifest.xml Datei.

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
   package="com.example.sairamkrishna.myapplication" >

   <application
      android:allowBackup="true"
      android:icon="@drawable/ic_launcher"
      android:label="@string/app_name"
      android:theme="@style/AppTheme" >
      
      <activity
         android:name="com.example.sairamkrishna.myapplicationMainActivity"
         android:label="@string/app_name" >
         
         <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
         </intent-filter>
         
      </activity>
   
   </application>
</manifest>

Versuchen wir, Ihre Anwendung auszuführen. Ich gehe davon aus, dass Sie Ihr aktuelles Android Mobile-Gerät mit Ihrem Computer verbunden haben. Um die App von Android Studio aus auszuführen, öffnen Sie eine der Aktivitätsdateien Ihres Projekts und klicken Sie in

der Symbolleiste auf das Symbol Ausführen. Die Beispielausgabe sollte folgendermaßen aussehen:

Legen Sie nun einfach zwei Finger über den Android-Bildschirm und trennen Sie sie von einem Teil. Sie werden sehen, dass das Android-Bild zoomt. Es ist im Bild unten gezeigt -

Legen Sie nun wieder zwei Finger über den Android-Bildschirm und versuchen Sie, sie zu schließen. Sie werden sehen, dass das Android-Bild jetzt kleiner wird. Es ist im Bild unten gezeigt -