Gesto en el interior de ListView – Android

Soy un novato en Android. Tengo un tutorial sobre cómo poner en práctica la `listView aquí:

Me implementado y se está trabajando muy bien. Necesito implementar un ViewSwitcher para el mismo. Como cuando se me pase el dedo por la canción, necesito algunas opciones como jugar, añadir a la cola etc.,

Pls ir a través de ese tutorial y pls ayuda. Estoy luchando por casi 3 semanas.

Espero que alguien me ayude.

Editar 1:
El código a continuación es la Actividad principal:

import java.util.ArrayList;
import java.util.HashMap;

import org.w3c.dom.Document;
import org.w3c.dom.Element;
import org.w3c.dom.NodeList;

import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemClickListener;
import android.widget.ListView;

import android.view.GestureDetector;
import android.view.GestureDetector.OnGestureListener;
import android.view.MotionEvent;
import android.widget.ViewSwitcher;

public class CustomizedListView extends Activity implements OnGestureListener{
//All static variables
static final String URL = "http://api.androidhive.info/music/music.xml";
//XML node keys
static final String KEY_SONG = "song"; //parent node
static final String KEY_ID = "id";
static final String KEY_TITLE = "title";
static final String KEY_ARTIST = "artist";
static final String KEY_DURATION = "duration";
static final String KEY_THUMB_URL = "thumb_url";


private ViewSwitcher switcher1;
private GestureDetector gesturedetector = null;
ListView list;
LazyAdapter adapter;

@Override
public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);

    ArrayList<HashMap<String, String>> songsList = new ArrayList<HashMap<String, String>>();

    XMLParser parser = new XMLParser();
    String xml = parser.getXmlFromUrl(URL); //getting XML from URL
    Document doc = parser.getDomElement(xml); //getting DOM element

    NodeList nl = doc.getElementsByTagName(KEY_SONG);
    //looping through all song nodes <song>
    for (int i = 0; i < nl.getLength(); i++) {
        //creating new HashMap
        HashMap<String, String> map = new HashMap<String, String>();
        Element e = (Element) nl.item(i);
        //adding each child node to HashMap key => value
        map.put(KEY_ID, parser.getValue(e, KEY_ID));
        map.put(KEY_TITLE, parser.getValue(e, KEY_TITLE));
        map.put(KEY_ARTIST, parser.getValue(e, KEY_ARTIST));
        map.put(KEY_DURATION, parser.getValue(e, KEY_DURATION));
        map.put(KEY_THUMB_URL, parser.getValue(e, KEY_THUMB_URL));

        //adding HashList to ArrayList
        songsList.add(map);

    }


    list=(ListView)findViewById(R.id.list);

    //Getting adapter by passing xml data ArrayList
    adapter=new LazyAdapter(this, songsList);        
    list.setAdapter(adapter);


    //Click event for single list row
    list.setOnItemClickListener(new OnItemClickListener() {

        public void onItemClick(AdapterView<?> parent, View view,
                int position, long id) {


        }
    });



}   


@Override
public boolean onTouchEvent(MotionEvent event) {
        return gesturedetector.onTouchEvent(event);
}

public boolean onDown(MotionEvent e) {
    //TODO Auto-generated method stub
    return false;
}
int SWIPE_MIN_VELOCITY = 100;
int SWIPE_MIN_DISTANCE = 100;
//Sự kiện khi bạn vuốt màn hình đưa sang một bên nào đó

public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,float velocityY) {
    //Get Position
    float ev1X = e1.getX();
    float ev2X = e2.getX();

    //Get distance of X (e1) to X (e2)
    final float xdistance = Math.abs(ev1X - ev2X);
    //Get veclocity of cusor
    //Vận tốc = số điểm ảnh (px) /giây
   final float xvelocity = Math.abs(velocityX);

   //Vận tốc chuyển đổi X > 100 và khoảng cách từ điểm kéo đầu đến điểm kéo cuối > 100
   if( (xvelocity > SWIPE_MIN_VELOCITY) && (xdistance > SWIPE_MIN_DISTANCE) )
   {
        if(ev1X > ev2X)//Switch Left
        {
            previousView();
        }
        else//Switch Right
        {
            nextView();
        }
   }

    return false;
}

public void onLongPress(MotionEvent e) {

}

public boolean onScroll(MotionEvent e1, MotionEvent e2, float distanceX,float distanceY) {
    return false;
}

public void onShowPress(MotionEvent e) {

}

public boolean onSingleTapUp(MotionEvent e) {
    return false;
}

//Next, Previous Views
private void previousView() {
    switcher1.showPrevious();
}
private void nextView() {
    switcher1.showNext();
}

A continuación el código en el archivo XML.

<?xml version="1.0" encoding="utf-8"?>
  <ViewSwitcher xmlns:android="http://schemas.android.com/apk/res/android"
     android:id="@+id/viewSwitcher1"
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     android:layout_alignParentLeft="true"
     android:layout_alignParentTop="true" >

   <include
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     layout="@layout/list_row_main" />

   <include
     android:layout_width="wrap_content"
     android:layout_height="wrap_content"
     layout="@layout/list_row_swipe" />

</ViewSwitcher>
  • ¿qué es lo que no estás entendiendo?
  • Hey Praveen ! Bienvenido a ASÍ. Tienes que venir para arriba con una buena aplicación de la idea. Compartir con nosotros un poco de código de lo que usted ha escrito o en qué momento usted no pudo lograrlo. Todo el mundo está aquí para ayudarle.Feliz Codificación 🙂
  • He probado la aplicación. pero el problema es pasar de acción no está funcionando. Traté de onFling. no su trabajo..
  • Bienvenido Praveen de hacerlo. Para su requisito, lo que si muestra acción Rápida
  • Gracias. Pero el requisito del cliente es que necesitan el dedo para mostrar más opciones.
  • Estoy seguro de que usted está tratando de implementar este y Para ello se puede verificar este
  • exacto, Pero donde puedo conseguir el código fuente de la aplicación twitter ? No podía encontrar ningún enlace.

2 Kommentare

  1. 6

    Como yo entiendo su pregunta, el problema es detectar el gesto de toque en el control ListView, derecho?

    Por lo tanto, usted tiene que ampliar el ListView y detectar horizontal de gestos táctiles en el onInterceptTouchEvent método.

    Heres es un ejemplo de un ListView, que no reacciona de forma horizontal eventos de toque. Estos eventos serán enviados a tu hijo a ver, que es en realidad el elemento de lista de vista que tiene a la captura de estos eventos (uso gesto de escucha) y activar la ViewSwitcher.

    public class SampleListView extends ListView {
    
    .
    .
    .
    
    @Override
        public boolean onInterceptTouchEvent(MotionEvent ev) {
            switch (ev.getAction()) {
                case MotionEvent.ACTION_DOWN:
                    //reset difference values
                    mDiffX = 0;
                    mDiffY = 0;
    
                    mLastX = ev.getX();
                    mLastY = ev.getY();
                    break;
    
                case MotionEvent.ACTION_MOVE:
                    final float curX = ev.getX();
                    final float curY = ev.getY();
                    mDiffX += Math.abs(curX - mLastX);
                    mDiffY += Math.abs(curY - mLastY);
                    mLastX = curX;
                    mLastY = curY;
    
                    //don't intercept event, when user tries to scroll vertically
                    if (mDiffX > mDiffY) {
                        return false; //do not react to horizontal touch events, these events will be passed to your list item view
                    }
            }
    
            return super.onInterceptTouchEvent(ev);
        }
    
    .
    .
    .
    
    }
    • Sí, exactamente.. necesito hacer el gesto de toque trabajar dentro del ListView.
    • He añadido el código de ejemplo. quiero saber, si todavía hay algo claro.
    • kumar, oye, si AZ13 la solución de trabajo, por favor marca como un derecho de respuesta, otra cosa a comentar aquí, va a ser de gran ayuda para los demás. Gracias !
    • No, no trabajo para mí y que Nos dejó el proyecto.
  2. 0

    Puede utilizar motionevent para hacerlo. Usted necesidad justa de seguimiento de la velocidad.

    por Ejemplo.

    public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX,
            float velocityY) {
        //TODO Auto-generated method stub
           try {
               if (Math.abs(e1.getY() - e2.getY()) > SWIPE_MAX_OFF_PATH)
                   return false;
               //right to left swipe
               if(e1.getX() - e2.getX() > SWIPE_MIN_DISTANCE && Math.abs(velocityX) > SWIPE_THRESHOLD_VELOCITY) {                  
                  Toast.makeText(getApplicationContext(), "Left Swipe", 
                  Toast.LENGTH_SHORT).show();                  
                } 
    • He intentado hacer esto, pls ver a mi pregunta, pero el gesto en sí no está funcionando.

Kommentieren Sie den Artikel

Bitte geben Sie Ihren Kommentar ein!
Bitte geben Sie hier Ihren Namen ein

Pruebas en línea