Android - Drag & Drop

Mit dem Android Drag & Drop-Framework können Ihre Benutzer Daten mithilfe einer grafischen Drag & Drop-Geste von einer Ansicht in eine andere Ansicht im aktuellen Layout verschieben. AbAPI 11 Das Ziehen und Ablegen von Ansichten auf andere Ansichten oder Ansichtsgruppen wird unterstützt. Das Framework enthält die folgenden drei wichtigen Komponenten zur Unterstützung der Drag & Drop-Funktionalität:

  • Drag event class.

  • Drag listeners.

  • Helper methods and classes.

Der Drag / Drop-Prozess

Grundsätzlich gibt es vier Schritte oder Zustände beim Ziehen und Ablegen -

  • Started - Dieses Ereignis tritt auf, wenn Sie ein Element in ein Layout ziehen. Ihre Anwendung ruft die Methode startDrag () auf, um das System anzuweisen , ein Ziehen zu starten. Die Argumente in der startDrag () -Methode enthalten die zu ziehenden Daten, Metadaten für diese Daten und einen Rückruf zum Zeichnen des Ziehschattens.

    Das System ruft zunächst Ihre Anwendung auf, um einen Drag Shadow zu erhalten. Anschließend wird der Ziehschatten auf dem Gerät angezeigt.

    Als Nächstes sendet das System ein Drag-Ereignis mit dem Aktionstyp ACTION_DRAG_STARTED an die registrierten Listener für Drag-Ereignisse für alle View-Objekte im aktuellen Layout.

    Um weiterhin Drag-Ereignisse zu empfangen, einschließlich eines möglichen Drop-Ereignisses, muss ein Listener für Drag-Ereignisse zurückkehren true, Wenn der Listener für Drag-Ereignisse false zurückgibt, empfängt er keine Drag-Ereignisse für die aktuelle Operation, bis das System ein Drag-Ereignis mit dem Aktionstyp ACTION_DRAG_ENDED sendet.

  • Continuing- Der Benutzer setzt das Ziehen fort. Das System sendet die Aktion ACTION_DRAG_ENTERED, gefolgt von der Aktion ACTION_DRAG_LOCATION, an den registrierten Listener für Ziehereignisse für die Ansicht, in die der Ziehpunkt eingegeben wird. Der Listener kann das Erscheinungsbild seines View-Objekts als Reaktion auf das Ereignis ändern oder durch Hervorheben seiner Ansicht reagieren.

    Der Listener für Ziehereignisse erhält eine Aktion ACTION_DRAG_EXITED, nachdem der Benutzer den Ziehschatten außerhalb des Begrenzungsrahmens der Ansicht verschoben hat.

  • Dropped- Der Benutzer gibt das gezogene Element im Begrenzungsrahmen einer Ansicht frei. Das System sendet dem Listener des View-Objekts ein Drag-Ereignis mit dem Aktionstyp ACTION_DROP.

  • Ended - Unmittelbar nach dem Aktionstyp ACTION_DROP sendet das System ein Ziehereignis mit dem Aktionstyp ACTION_DRAG_ENDED, um anzuzeigen, dass die Ziehoperation beendet ist.

Die DragEvent-Klasse

Das DragEventstellt ein Ereignis dar, das vom System zu verschiedenen Zeiten während eines Drag & Drop-Vorgangs gesendet wird. Diese Klasse enthält einige Konstanten und wichtige Methoden, die wir beim Ziehen / Ablegen verwenden.

Konstanten

Im Folgenden sind alle Konstanten-Ganzzahlen aufgeführt, die als Teil der DragEvent-Klasse verfügbar sind.

Sr.Nr. Konstanten & Beschreibung
1

ACTION_DRAG_STARTED

Signalisiert den Start eines Drag & Drop-Vorgangs.

2

ACTION_DRAG_ENTERED

Signalisiert einer Ansicht, dass der Ziehpunkt in den Begrenzungsrahmen der Ansicht eingegeben wurde.

3

ACTION_DRAG_LOCATION

Wird nach ACTION_DRAG_ENTERED an eine Ansicht gesendet, wenn sich der Ziehschatten noch im Begrenzungsrahmen des Ansichtsobjekts befindet.

4

ACTION_DRAG_EXITED

Signalisiert, dass der Benutzer den Ziehschatten außerhalb des Begrenzungsrahmens der Ansicht verschoben hat.

5

ACTION_DROP

Signalisiert einer Ansicht, dass der Benutzer den Ziehschatten freigegeben hat und sich der Ziehpunkt innerhalb des Begrenzungsrahmens der Ansicht befindet.

6

ACTION_DRAG_ENDED

Signalisiert einer Ansicht, dass der Drag & Drop-Vorgang abgeschlossen wurde.

Methoden

Im Folgenden sind einige wichtige und am häufigsten verwendete Methoden aufgeführt, die als Teil der DragEvent-Klasse verfügbar sind.

Sr.Nr. Konstanten & Beschreibung
1

int getAction()

Überprüfen Sie den Aktionswert dieses Ereignisses.

2

ClipData getClipData()

Gibt das ClipData-Objekt zurück, das als Teil des Aufrufs von startDrag () an das System gesendet wurde.

3

ClipDescription getClipDescription()

Gibt das in den ClipData enthaltene ClipDescription-Objekt zurück.

4

boolean getResult()

Gibt eine Anzeige des Ergebnisses der Drag & Drop-Operation zurück.

5

float getX()

Ruft die X-Koordinate des Ziehpunkts ab.

6

float getY()

Ruft die Y-Koordinate des Ziehpunkts ab.

7

String toString()

Gibt eine Zeichenfolgendarstellung dieses DragEvent-Objekts zurück.

Auf Drag Event warten

Wenn Sie möchten, dass eine Ihrer Ansichten in einem Layout auf ein Drag-Ereignis reagiert, wird Ihre Ansicht entweder implementiert View.OnDragListener oder einrichten onDragEvent(DragEvent)Rückrufmethode. Wenn das System die Methode oder den Listener aufruft, übergibt es ihnen ein oben erläutertes DragEvent-Objekt. Sie können sowohl einen Listener als auch eine Rückrufmethode für das View-Objekt verwenden. In diesem Fall ruft das System zuerst den Listener auf und definiert dann den Rückruf, solange der Listener true zurückgibt.

Die Kombination der onDragEvent (DragEvent) -Methode und View.OnDragListener ist analog zur Kombination vononTouchEvent() und View.OnTouchListener Wird mit Touch-Ereignissen in alten Android-Versionen verwendet.

Starten eines Drag-Ereignisses

Sie beginnen mit dem Erstellen eines ClipData und ClipData.Itemfür die Daten, die verschoben werden. Geben Sie als Teil des ClipData- Objekts Metadaten an, die in a gespeichert sindClipDescriptionObjekt in den ClipData. Für einen Drag & Drop-Vorgang, der keine Datenbewegung darstellt, möchten Sie möglicherweise verwendennull anstelle eines tatsächlichen Objekts.

Als nächstes können Sie entweder verlängern erweitern View.DragShadowBuilderUm einen Ziehschatten zum Ziehen der Ansicht zu erstellen, können Sie einfach View.DragShadowBuilder (Ansicht) verwenden , um einen Standard- Ziehschatten zu erstellen, der dieselbe Größe wie das an ihn übergebene View-Argument hat und dessen Berührungspunkt im Ziehschatten zentriert ist.

Beispiel

Das folgende Beispiel zeigt die Funktionalität eines einfachen Drag & Drop mit View.setOnLongClickListener(), View.setOnTouchListener()und View.OnDragEventListener().

Schritt Beschreibung
1 Mit der Android Studio-IDE erstellen Sie eine Android-Anwendung und benennen sie unter dem Paket com.example.saira_000.myapplication als Meine Anwendung .
2 Ändern src / MainActivity.java Datei und fügen Sie den Code Ereignis - Listener sowie einen Rückruf Methoden für das Logo - Bild verwendet , im Beispiel zu definieren.
3 Kopieren Sie das Bild abc.png in die Ordner res / drawable- * . Sie können Bilder mit unterschiedlicher Auflösung verwenden, wenn Sie sie für verschiedene Geräte bereitstellen möchten.
4 Ändern Sie die Layout-XML-Datei res / layout / activity_main.xml , um die Standardansicht der Logo-Bilder zu definieren.
5 Führen Sie die Anwendung aus, um den Android-Emulator zu starten, und überprüfen Sie das Ergebnis der in der Anwendung vorgenommenen Änderungen.

Es folgt der Inhalt der geänderten Hauptaktivitätsdatei src/MainActivity.java. Diese Datei kann jede der grundlegenden Lebenszyklusmethoden enthalten.

package com.example.saira_000.myapplication;

import android.app.Activity;

import android.content.ClipData;
import android.content.ClipDescription;

import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.util.Log;

import android.view.DragEvent;
import android.view.Menu;
import android.view.MenuItem;
import android.view.MotionEvent;
import android.view.View;

import android.widget.ImageView;
import android.widget.RelativeLayout;


public class MainActivity extends Activity {
   ImageView img;
   String msg;
   private android.widget.RelativeLayout.LayoutParams layoutParams;
   
   @Override
   protected void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.activity_main);
      img=(ImageView)findViewById(R.id.imageView);
      
      img.setOnLongClickListener(new View.OnLongClickListener() {
         @Override
         public boolean onLongClick(View v) {
            ClipData.Item item = new ClipData.Item((CharSequence)v.getTag());
            String[] mimeTypes = {ClipDescription.MIMETYPE_TEXT_PLAIN};
            
            ClipData dragData = new ClipData(v.getTag().toString(),mimeTypes, item);
            View.DragShadowBuilder myShadow = new View.DragShadowBuilder(img);
            
            v.startDrag(dragData,myShadow,null,0);
            return true;
         }
      });
      
      img.setOnDragListener(new View.OnDragListener() {
         @Override
         public boolean onDrag(View v, DragEvent event) {
            switch(event.getAction()) {
               case DragEvent.ACTION_DRAG_STARTED:
               layoutParams = (RelativeLayout.LayoutParams)v.getLayoutParams();
               Log.d(msg, "Action is DragEvent.ACTION_DRAG_STARTED");
               
               // Do nothing
               break;
               
               case DragEvent.ACTION_DRAG_ENTERED:
               Log.d(msg, "Action is DragEvent.ACTION_DRAG_ENTERED");
               int x_cord = (int) event.getX();
               int y_cord = (int) event.getY();
               break;
               
               case DragEvent.ACTION_DRAG_EXITED :
               Log.d(msg, "Action is DragEvent.ACTION_DRAG_EXITED");
               x_cord = (int) event.getX();
               y_cord = (int) event.getY();
               layoutParams.leftMargin = x_cord;
               layoutParams.topMargin = y_cord;
               v.setLayoutParams(layoutParams);
               break;
               
               case DragEvent.ACTION_DRAG_LOCATION  :
               Log.d(msg, "Action is DragEvent.ACTION_DRAG_LOCATION");
               x_cord = (int) event.getX();
               y_cord = (int) event.getY();
               break;
               
               case DragEvent.ACTION_DRAG_ENDED   :
               Log.d(msg, "Action is DragEvent.ACTION_DRAG_ENDED");
               
               // Do nothing
               break;
               
               case DragEvent.ACTION_DROP:
               Log.d(msg, "ACTION_DROP event");
               
               // Do nothing
               break;
               default: break;
            }
            return true;
         }
      });
      
      img.setOnTouchListener(new View.OnTouchListener() {
         @Override
         public boolean onTouch(View v, MotionEvent event) {
            if (event.getAction() == MotionEvent.ACTION_DOWN) {
               ClipData data = ClipData.newPlainText("", "");
               View.DragShadowBuilder shadowBuilder = new View.DragShadowBuilder(img);
               
               img.startDrag(data, shadowBuilder, img, 0);
               img.setVisibility(View.INVISIBLE);
               return true;
            } else {
               return false;
            }
         }
      });
   }
}

Es folgt der Inhalt von res/layout/activity_main.xml Datei -

Im folgenden Code gibt abc das Logo von tutorialspoint.com 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:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="Drag and Drop Example"
      android:id="@+id/textView"
      android:layout_alignParentTop="true"
      android:layout_centerHorizontal="true"
      android:textSize="30dp" />
      
   <TextView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="Tutorials Point"
      android:id="@+id/textView2"
      android:layout_below="@+id/textView"
      android:layout_centerHorizontal="true"
      android:textSize="30dp"
      android:textColor="#ff14be3c" />>
      
   <ImageView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:id="@+id/imageView"
      android:src="@drawable/abc"
      android:layout_below="@+id/textView2"
      android:layout_alignRight="@+id/textView2"
      android:layout_alignEnd="@+id/textView2"
      android:layout_alignLeft="@+id/textView2"
      android:layout_alignStart="@+id/textView2" />

</RelativeLayout>

Es folgt der Inhalt von res/values/strings.xml zwei neue Konstanten definieren -

<?xml version="1.0" encoding="utf-8"?>
<resources>
   <string name="app_name">My Application</string>
</resources>

Es folgt der Standardinhalt von AndroidManifest.xml - -

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
   package="com.example.saira_000.myapplication" >
      
   <application
      android:allowBackup="true"
      android:icon="@drawable/ic_launcher"
      android:label="@string/app_name"
      android:theme="@style/AppTheme" >
      
      <activity
         android:name=".MainActivity"
         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>

Lassen Sie uns versuchen, Ihre auszuführen My ApplicationAnwendung. Ich nehme an, Sie hatten Ihre erstelltAVDwährend der Einrichtung der Umgebung. Um die App in Android Studio auszuführen, öffnen Sie eine der Aktivitätsdateien Ihres Projekts und klicken Sie in

der Symbolleiste auf das Symbol Ausführen . Android Studio installiert die App auf Ihrer AVD und startet sie. Wenn mit Ihrem Setup und Ihrer Anwendung alles in Ordnung ist, wird das folgende Emulatorfenster angezeigt:

Klicken Sie nun lange auf das angezeigte TutorialsPoint-Logo und Sie werden sehen, dass sich das Logo-Bild ein wenig nach 1 Sekunden langem Klicken von seiner Stelle bewegt. Dies ist die Zeit, zu der Sie mit dem Ziehen des Bildes beginnen sollten. Sie können es über den Bildschirm ziehen und an einer neuen Stelle ablegen.