欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android App中ListView仿QQ實現(xiàn)滑動刪除效果的要點解析

 更新時間:2016年04月26日 16:15:52   作者:鴻洋_  
這篇文章主要介紹了Android App中ListView仿QQ實現(xiàn)滑動刪除效果的要點解析,重點是要判斷手勢按下的位置坐標,需要的朋友可以參考下

本來準備在ListView的每個Item的布局上設置一個隱藏的Button,當滑動的時候顯示。但是因為每次只要存在一個Button,發(fā)現(xiàn)每個Item上的Button相互間不好控制。所以決定繼承ListView然后結合PopupWindow。
首先是布局文件:
delete_btn.xml:這里只需要一個Button

<?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
  android:layout_width="wrap_content" 
  android:layout_height="wrap_content" 
  android:orientation="vertical" > 
   <Button  
    android:id="@+id/id_item_btn" 
    android:layout_width="60dp" 
    android:singleLine="true" 
    android:layout_height="wrap_content" 
    android:text="刪除" 
    android:background="@drawable/d_delete_btn" 
    android:textColor="#ffffff" 
    android:paddingLeft="15dp" 
    android:paddingRight="15dp" 
    android:layout_alignParentRight="true" 
    android:layout_centerVertical="true" 
    android:layout_marginRight="15dp" 
    /> 
</LinearLayout> 

主布局文件:activity_main.xml,ListView的每個Item的樣式直接使用了系統(tǒng)的android.R.layout.simple_list_item_1

<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" > 
 
  <com.example.listviewitemslidedeletebtnshow.QQListView 
    android:id="@+id/id_listview" 
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" > 
  </com.example.listviewitemslidedeletebtnshow.QQListView> 
 
</RelativeLayout> 

接下來看看QQListView的實現(xiàn):

package com.example.listviewitemslidedeletebtnshow; 
 
import android.content.Context; 
import android.util.AttributeSet; 
import android.view.Gravity; 
import android.view.LayoutInflater; 
import android.view.MotionEvent; 
import android.view.View; 
import android.view.ViewConfiguration; 
import android.widget.Button; 
import android.widget.LinearLayout; 
import android.widget.ListView; 
import android.widget.PopupWindow; 
 
public class QQListView extends ListView 
{ 
 
  private static final String TAG = "QQlistView"; 
 
  // private static final int VELOCITY_SANP = 200; 
  // private VelocityTracker mVelocityTracker; 
  /** 
   * 用戶滑動的最小距離 
   */ 
  private int touchSlop; 
 
  /** 
   * 是否響應滑動 
   */ 
  private boolean isSliding; 
 
  /** 
   * 手指按下時的x坐標 
   */ 
  private int xDown; 
  /** 
   * 手指按下時的y坐標 
   */ 
  private int yDown; 
  /** 
   * 手指移動時的x坐標 
   */ 
  private int xMove; 
  /** 
   * 手指移動時的y坐標 
   */ 
  private int yMove; 
 
  private LayoutInflater mInflater; 
 
  private PopupWindow mPopupWindow; 
  private int mPopupWindowHeight; 
  private int mPopupWindowWidth; 
 
  private Button mDelBtn; 
  /** 
   * 為刪除按鈕提供一個回調(diào)接口 
   */ 
  private DelButtonClickListener mListener; 
 
  /** 
   * 當前手指觸摸的View 
   */ 
  private View mCurrentView; 
 
  /** 
   * 當前手指觸摸的位置 
   */ 
  private int mCurrentViewPos; 
 
  /** 
   * 必要的一些初始化 
   * 
   * @param context 
   * @param attrs 
   */ 
  public QQListView(Context context, AttributeSet attrs) 
  { 
    super(context, attrs); 
 
    mInflater = LayoutInflater.from(context); 
    touchSlop = ViewConfiguration.get(context).getScaledTouchSlop(); 
 
    View view = mInflater.inflate(R.layout.delete_btn, null); 
    mDelBtn = (Button) view.findViewById(R.id.id_item_btn); 
    mPopupWindow = new PopupWindow(view, LinearLayout.LayoutParams.WRAP_CONTENT, 
        LinearLayout.LayoutParams.WRAP_CONTENT); 
    /** 
     * 先調(diào)用下measure,否則拿不到寬和高 
     */ 
    mPopupWindow.getContentView().measure(0, 0); 
    mPopupWindowHeight = mPopupWindow.getContentView().getMeasuredHeight(); 
    mPopupWindowWidth = mPopupWindow.getContentView().getMeasuredWidth(); 
  } 
 
  @Override 
  public boolean dispatchTouchEvent(MotionEvent ev) 
  { 
    int action = ev.getAction(); 
    int x = (int) ev.getX(); 
    int y = (int) ev.getY(); 
    switch (action) 
    { 
 
    case MotionEvent.ACTION_DOWN: 
      xDown = x; 
      yDown = y; 
      /** 
       * 如果當前popupWindow顯示,則直接隱藏,然后屏蔽ListView的touch事件的下傳 
       */ 
      if (mPopupWindow.isShowing()) 
      { 
        dismissPopWindow(); 
        return false; 
      } 
      // 獲得當前手指按下時的item的位置 
      mCurrentViewPos = pointToPosition(xDown, yDown); 
      // 獲得當前手指按下時的item 
      View view = getChildAt(mCurrentViewPos - getFirstVisiblePosition()); 
      mCurrentView = view; 
      break; 
    case MotionEvent.ACTION_MOVE: 
      xMove = x; 
      yMove = y; 
      int dx = xMove - xDown; 
      int dy = yMove - yDown; 
      /** 
       * 判斷是否是從右到左的滑動 
       */ 
      if (xMove < xDown && Math.abs(dx) > touchSlop && Math.abs(dy) < touchSlop) 
      { 
        // Log.e(TAG, "touchslop = " + touchSlop + " , dx = " + dx + 
        // " , dy = " + dy); 
        isSliding = true; 
      } 
      break; 
    } 
    return super.dispatchTouchEvent(ev); 
  } 
 
  @Override 
  public boolean onTouchEvent(MotionEvent ev) 
  { 
    int action = ev.getAction(); 
    /** 
     * 如果是從右到左的滑動才相應 
     */ 
    if (isSliding) 
    { 
      switch (action) 
      { 
      case MotionEvent.ACTION_MOVE: 
 
        int[] location = new int[2]; 
        // 獲得當前item的位置x與y 
        mCurrentView.getLocationOnScreen(location); 
        // 設置popupWindow的動畫 
        mPopupWindow.setAnimationStyle(R.style.popwindow_delete_btn_anim_style); 
        mPopupWindow.update(); 
        mPopupWindow.showAtLocation(mCurrentView, Gravity.LEFT | Gravity.TOP, 
            location[0] + mCurrentView.getWidth(), location[1] + mCurrentView.getHeight() / 2 
                - mPopupWindowHeight / 2); 
        // 設置刪除按鈕的回調(diào) 
        mDelBtn.setOnClickListener(new OnClickListener() 
        { 
          @Override 
          public void onClick(View v) 
          { 
            if (mListener != null) 
            { 
              mListener.clickHappend(mCurrentViewPos); 
              mPopupWindow.dismiss(); 
            } 
          } 
        }); 
        // Log.e(TAG, "mPopupWindow.getHeight()=" + mPopupWindowHeight); 
 
        break; 
      case MotionEvent.ACTION_UP: 
        isSliding = false; 
 
      } 
      // 相應滑動期間屏幕itemClick事件,避免發(fā)生沖突 
      return true; 
    } 
 
    return super.onTouchEvent(ev); 
  } 
 
  /** 
   * 隱藏popupWindow 
   */ 
  private void dismissPopWindow() 
  { 
    if (mPopupWindow != null && mPopupWindow.isShowing()) 
    { 
      mPopupWindow.dismiss(); 
    } 
  } 
 
  public void setDelButtonClickListener(DelButtonClickListener listener) 
  { 
    mListener = listener; 
  } 
 
  interface DelButtonClickListener 
  { 
    public void clickHappend(int position); 
  } 
 
} 

代碼注釋寫得很詳細,簡單說一下,在dispatchTouchEvent中設置當前是否響應用戶滑動,然后在onTouchEvent中判斷是否響應,如果響應則popupWindow以動畫的形式展示出來。當然屏幕上如果存在PopupWindow則屏幕ListView的滾動與Item的點擊,以及從右到左滑動時屏幕Item的click事件。
接下來是MainActivity.java,這里代碼很簡單不做介紹了。

package com.example.listviewitemslidedeletebtnshow; 
 
import java.util.ArrayList; 
import java.util.Arrays; 
import java.util.List; 
 
import android.app.Activity; 
import android.os.Bundle; 
import android.view.View; 
import android.widget.AdapterView; 
import android.widget.AdapterView.OnItemClickListener; 
import android.widget.ArrayAdapter; 
import android.widget.Toast; 
 
import com.example.listviewitemslidedeletebtnshow.QQListView.DelButtonClickListener; 
 
public class MainActivity extends Activity 
{ 
  private QQListView mListView; 
  private ArrayAdapter<String> mAdapter; 
  private List<String> mDatas; 
 
  @Override 
  protected void onCreate(Bundle savedInstanceState) 
  { 
    super.onCreate(savedInstanceState); 
    setContentView(R.layout.activity_main); 
 
    mListView = (QQListView) findViewById(R.id.id_listview); 
    // 不要直接Arrays.asList 
    mDatas = new ArrayList<String>(Arrays.asList("HelloWorld", "Welcome", "Java", "Android", "Servlet", "Struts", 
        "Hibernate", "Spring", "HTML5", "Javascript", "Lucene")); 
    mAdapter = new ArrayAdapter<String>(this, android.R.layout.simple_list_item_1, mDatas); 
    mListView.setAdapter(mAdapter); 
 
    mListView.setDelButtonClickListener(new DelButtonClickListener() 
    { 
      @Override 
      public void clickHappend(final int position) 
      { 
        Toast.makeText(MainActivity.this, position + " : " + mAdapter.getItem(position), 1).show(); 
        mAdapter.remove(mAdapter.getItem(position)); 
      } 
    }); 
 
    mListView.setOnItemClickListener(new OnItemClickListener() 
    { 
      @Override 
      public void onItemClick(AdapterView<?> parent, View view, int position, long id) 
      { 
        Toast.makeText(MainActivity.this, position + " : " + mAdapter.getItem(position), 1).show(); 
      } 
    }); 
  } 
} 

效果圖如下:樓主使用asm.jar以及gifcamera截的gif,由于button的動畫很短感覺截圖效果很卡不流暢,大家有什么好的截圖,還望推薦。有興趣的還是下載源碼看看效果i。

2016426161603799.gif (360×617)

相關文章

  • Android ContentProvider的實現(xiàn)及簡單實例代碼

    Android ContentProvider的實現(xiàn)及簡單實例代碼

    這篇文章主要介紹了Android ContentProvider的實現(xiàn)及簡單實例代碼的相關資料,需要的朋友可以參考下
    2017-02-02
  • AndroidStudio4.1 自定義模板的使用方法

    AndroidStudio4.1 自定義模板的使用方法

    這篇文章主要介紹了AndroidStudio4.1 自定義模板的使用方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-01-01
  • Android使用線程更換壁紙

    Android使用線程更換壁紙

    這篇文章主要為大家詳細介紹了Android使用線程更換壁紙的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • Android手機上同時安裝正式包與測試包的方法

    Android手機上同時安裝正式包與測試包的方法

    這篇文章主要給大家介紹了關于Android手機上同時安裝正式包與測試包的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-02-02
  • android實現(xiàn)清理緩存功能

    android實現(xiàn)清理緩存功能

    這篇文章主要為大家詳細介紹了android實現(xiàn)清理緩存,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-11-11
  • Android自定義密碼輸入框和數(shù)字鍵盤

    Android自定義密碼輸入框和數(shù)字鍵盤

    這篇文章主要為大家詳細介紹了Android自定義密碼輸入框和數(shù)字鍵盤的相關代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • Android仿Win8的metro的UI界面(上)

    Android仿Win8的metro的UI界面(上)

    這篇文章主要為大家詳細介紹了Android仿Win8的metro的UI界面,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-08-08
  • android2.3.5 CDMA/EVDO撥號APN解決方案

    android2.3.5 CDMA/EVDO撥號APN解決方案

    google提供的android2.3里面,只能在GSM/WCDMA情況下才能從“設置”->“無線和網(wǎng)絡”->“移動網(wǎng)絡”->“接入點名稱”中選擇不同的apn帳號進行撥號連接,而CDMA/EVDO則沒有這個功能,接下來本文介紹一些方法實現(xiàn)這個功能,感興趣的朋友可以了解下
    2013-01-01
  • Android  ImageView繪制圓角效果

    Android ImageView繪制圓角效果

    這篇文章主要介紹了Android ImageView繪制圓角效果,一種是使用Xfermode,另一種是BitmapShader來實現(xiàn)圓形和圓角的效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • Android自定義PasswordInputView密碼輸入

    Android自定義PasswordInputView密碼輸入

    這篇文章主要為大家詳細介紹了Android自定義PasswordInputView密碼輸入功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-08-08

最新評論