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

Android使用CardView作為RecyclerView的Item并實現拖拽和左滑刪除

 更新時間:2017年11月27日 17:18:27   作者:靜永萱  
這篇文章主要介紹了Android使用CardView作為RecyclerView的Item并實現拖拽和左滑刪除,具有一定的參考價值,感興趣的小伙伴們可以參考一下

引言

CardView是Android 5.0系統之后引入的眾多控件之一,實現之后的效果也是比較酷的,它經常被用在RecyclerView和ListView中的Item中。今天我們就來了解一下CardView的屬性,然后使用CardView和RecyclerView結合實現一個可以拖拽Item的布局。

CardView的屬性

 CardView繼承自FrameLayout,所以子控件的布局規(guī)則和FrameLayout的一樣,是按照層次堆疊的

下面是CardView的一些常用屬性:

CardView的基本使用

先看一下效果:

這是一個CardView,多個羅列起來看起啦會更酷,好了,我們先看一下代碼:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:app="http://schemas.android.com/apk/res-auto"
  android:orientation="vertical" android:paddingTop="10dp"
  android:layout_width="match_parent" android:layout_height="wrap_content">
 
  <android.support.v7.widget.CardView
    android:layout_width="match_parent" android:layout_height="60dp"
    android:layout_marginLeft="10dp" android:layout_marginRight="10dp"
    app:contentPaddingLeft="20dp" app:cardBackgroundColor="@color/colorPrimary"
    app:cardCornerRadius="5dp" app:cardElevation="5dp"
    android:layout_marginBottom="10dp"
    app:cardPreventCornerOverlap="true">
    <LinearLayout
      android:layout_width="match_parent" android:layout_height="match_parent"
      android:orientation="horizontal" android:gravity="center_vertical">
      <!--左側圖片-->
      <ImageView
        android:layout_width="50dp" android:layout_height="50dp"
        android:src="@mipmap/ic_launcher"/>
      <LinearLayout
        android:layout_width="match_parent" android:layout_height="match_parent"
        android:orientation="vertical" android:layout_marginLeft="10dp"
        android:gravity="center_vertical">
        <!--姓名-->
        <TextView
          android:id="@+id/txt_name" android:layout_width="wrap_content"
          android:layout_height="wrap_content" android:textSize="16sp"
          android:textColor="@android:color/white" android:text="王二"/>
        <!--描述-->
        <TextView
          android:id="@+id/txt_describe" android:layout_width="wrap_content"
          android:layout_height="wrap_content" android:layout_marginTop="5dp"
          android:textSize="12sp" android:textColor="@android:color/darker_gray"
          android:text="一個很厲害的人"/>
      </LinearLayout>
    </LinearLayout>
  </android.support.v7.widget.CardView>
</LinearLayout>

看完了布局文件,是不是覺得這個布局不僅炫酷而且使用簡單,下面我們把它應用到RecyclerView中,看起來會更炫酷。

CardView應用在RecyclerView中

CardView通常會應用在RecyclerView和ListView中,今天我們就講一講如何應用在RecyclerView中。我們現在在大多數應用或者手機系統界面中會見到這樣的效果:

是不是覺得很棒,下面我們就用CardView和RecyclerView來實現一下這個效果。

布局文件

我們實現這個效果的第一步是先添加依賴庫:

implementation 'com.android.support:recyclerview-v7:26.+'
implementation 'com.android.support:cardview-v7:26.+'

然后寫一下布局文件,Item的布局文件我就直接采用上面的代碼了,然后再寫一個主界面的布局文件,比較簡單,如下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:app="http://schemas.android.com/apk/res-auto"
  xmlns:tools="http://schemas.android.com/tools"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:orientation="vertical" android:paddingTop="10dp"
  tools:context="com.jyx.demo.myapplication.MainActivity">
 
  <android.support.v7.widget.RecyclerView
    android:id="@+id/my_recyclerView"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"/>
 
</LinearLayout>

Activity內代碼

public class MainActivity extends AppCompatActivity {
  private RecyclerView mRecyclerView;
 
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
 
    mRecyclerView = (RecyclerView) findViewById(R.id.my_recyclerView);
    //設置LayoutManager
    LinearLayoutManager linearLayoutManager = new LinearLayoutManager(this);
    linearLayoutManager.setOrientation(LinearLayoutManager.VERTICAL);
    mRecyclerView.setLayoutManager(linearLayoutManager);
 
    //綁定adapter
    MyAdapter myAdapter = new MyAdapter(this);
    mRecyclerView.setAdapter(myAdapter);  
 
  }
  //adapter
  class MyAdapter extends RecyclerView.Adapter<MyAdapter.ViewHolder> {
 
    LayoutInflater mInflater;
    List<MData> mList = addData();
 
    public MyAdapter(Context context) {
      mInflater = LayoutInflater.from(context);
    }
 
    @Override
    public MyAdapter.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
      View view = mInflater.inflate(R.layout.item_my_recyclerview,parent,false);
      ViewHolder viewHolder = new ViewHolder(view);
      return viewHolder;
    }
 
    @Override
    public void onBindViewHolder(MyAdapter.ViewHolder holder, int position) {
      holder.mName.setText(mList.get(position).getUserName());
      holder.mDescribe.setText(mList.get(position).getDescription());
    }
 
    @Override
    public int getItemCount() {
      return mList.size();
    }
 
    public class ViewHolder extends RecyclerView.ViewHolder {
      private TextView mName;
      private TextView mDescribe;
      public ViewHolder(View itemView) {
        super(itemView);
        mName = itemView.findViewById(R.id.txt_name);
        mDescribe = itemView.findViewById(R.id.txt_describe);
      }
    }
  }
  //制造一個數據源
  private class MData{
    String userName;
    String description;
 
    public String getUserName() {
      return userName;
    }
 
    public void setUserName(String userName) {
      this.userName = userName;
    }
 
    public String getDescription() {
      return description;
    }
 
    public void setDescription(String description) {
      this.description = description;
    }
  }
  private List<MData> addData(){
    List<MData> list = new ArrayList();
 
    MData mData = new MData();
    mData.setUserName("王二");
    mData.setDescription("一個很厲害的人");
    list.add(mData);
 
    mData = new MData();
    mData.setUserName("張三");
    mData.setDescription("呵呵");
    list.add(mData);
 
    mData = new MData();
    mData.setUserName("李四");
    mData.setDescription("嘻嘻");
    list.add(mData);
 
    mData = new MData();
    mData.setUserName("趙一");
    mData.setDescription("呵呵");
    list.add(mData);
 
    mData = new MData();
    mData.setUserName("錢多");
    mData.setDescription("地主家的傻兒子");
    list.add(mData);
    return list;
  }
}

好了,這就是一個沒有任何效果的列表界面,我一看一下效果:

ItemTouchHelper

想實現拖拽和滑動刪除的效果,很可惜RecyclerView并沒有提供現成的API供我們使用,但是SDK為我們提供了ItemTouchHelper這樣一個工具類幫助我們來輕松實現這些功能,我們先來了解一下ItemTouchHelper。官方文檔是這樣介紹的:

This is a utility class to add swipe to dismiss and drag & drop support to RecyclerView.It works with a RecyclerView and a Callback class, which configures what type of interactions are enabled and also receives events when user performs these actions.Depending on which functionality you support, you should override onMove(RecyclerView, ViewHolder, ViewHolder) and / or onSwiped(ViewHolder, int).

大致意思就是,這是個工具類,可以實拖拽移動和策劃刪除,使用這個工具需要RecyclerView和Callback。同時需要重寫onMove()和onSwiped()方法。接下來就講講如何使用ItemTouchHlper。

1.新建一個接口,并且讓Adapter實現

我們選擇使用一個接口來實現Adapter和ItemTouchHelper之間涉及數據的操作,因為ItemTouchHelper完成觸摸的各種動畫以后,就要對Adapter的數據進行操作,比如我們在側滑刪除以后,最后需要調用Adapter的notifyItemRemove()方法來移除該數據。所以我們可以把數據操作的部分抽象成一個接口方法,讓Callbac調用它即可。具體如下:

新建一個接口:

ItemTouchHelperAdapter

public interface ItemTouchHelperAdapter {
  //移動item
  public void onItemMove(int fromPosition,int toPosition);
  //刪除item
  public void onItemDelete(int position);
}

之后讓Adapter實現這個接口

class MyAdapter extends RecyclerView.Adapter<MyAdapter.ViewHolder> implements ItemTouchHelperAdapter{
 
    LayoutInflater mInflater;
    List<MData> mList = addData();
 
    public MyAdapter(Context context) {
      mInflater = LayoutInflater.from(context);
    }
 
    @Override
    public MyAdapter.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
      View view = mInflater.inflate(R.layout.item_my_recyclerview,parent,false);
      ViewHolder viewHolder = new ViewHolder(view);
      return viewHolder;
    }
 
    @Override
    public void onBindViewHolder(MyAdapter.ViewHolder holder, int position) {
      holder.mName.setText(mList.get(position).getUserName());
      holder.mDescribe.setText(mList.get(position).getDescription());
    }
 
    @Override
    public int getItemCount() {
      return mList.size();
    }
 
    @Override
    public void onItemMove(int fromPosition, int toPosition) {
      //交換位置
      Collections.swap(mList,fromPosition,toPosition);
      notifyItemMoved(fromPosition,toPosition);
    }
 
    @Override
    public void onItemDelete(int position) {
      //移除數據
      mList.remove(position);
      notifyItemRemoved(position);
    }
 
    public class ViewHolder extends RecyclerView.ViewHolder {
      private TextView mName;
      private TextView mDescribe;
      public ViewHolder(View itemView) {
        super(itemView);
        mName = itemView.findViewById(R.id.txt_name);
        mDescribe = itemView.findViewById(R.id.txt_describe);
      }
    }
  }

接下來我們直接在Callback中直接調用接口里的方法就可以了。

2.新建Callback方法,繼承ItemTouchHelper.Callback

官方文檔已經告訴我們,使用ItemTouchHelper需要一個Callback,這個Callback是ItemTouchHelper.Callback的子類,我們需要新建一個類來繼承ItemTouchHelper.Callback,然后重寫一些方法來實現我們的需求。代碼如下:

public class myItemTouchHelperCallBack extends ItemTouchHelper.Callback{
  private ItemTouchHelperAdapter itemTouchHelperAdapter;
 
  public myItemTouchHelperCallBack(ItemTouchHelperAdapter itemTouchHelperAdapter) {
    this.itemTouchHelperAdapter = itemTouchHelperAdapter;
  }
 
  @Override
  public int getMovementFlags(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder) {
    //允許上下拖動
    int dragFlags = ItemTouchHelper.UP | ItemTouchHelper.DOWN;
    //允許從右向左滑動
    int swipeFlags = ItemTouchHelper.LEFT;
    return makeMovementFlags(dragFlags,swipeFlags);
  }
 
  @Override
  public boolean onMove(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, RecyclerView.ViewHolder target) {
    //onItemMove接口里的方法
    itemTouchHelperAdapter.onItemMove(viewHolder.getAdapterPosition(),target.getAdapterPosition());
    return true;
  }
 
  @Override
  public void onSwiped(RecyclerView.ViewHolder viewHolder, int direction) {
    //onItemDelete接口里的方法
    itemTouchHelperAdapter.onItemDelete(viewHolder.getAdapterPosition());
  }
 
  @Override
  public boolean isLongPressDragEnabled() {
    //該方法返回值為true時,表示支持長按ItemView拖動
    return true;
  }
 
  @Override
  public boolean isItemViewSwipeEnabled() {
    //該方法返回true時,表示如果用戶觸摸并且左滑了view,那么可以執(zhí)行滑動刪除操作,就是可以調用onSwiped()方法
    return true;
  }
}

ItemTouchHelper.Callback還有其他幾個常用方法:

  1. public void onSelectedChanged(RecyclerView.ViewHolder viewHolder, int actionState):從靜止狀態(tài)變?yōu)橥献Щ蛘呋瑒拥臅r候會調用該方法,參數actionState表示當前狀態(tài)。
  2. public void clearView(RecyclerView recyclerView, ViewHolder viewHolder):當用戶操作完某個item并且動畫也結束后會調用該方法,一般我們在該方法內恢復ItemView的初始狀態(tài),防止由于復用而產生的錯亂問題。
  3. public void onChildDraw(…):我們可以在這個方法內實現我們自定義的交互規(guī)則或者自定義動畫。

這樣下來我們就只剩下一步了。

3.為RecyclerView添加ItemTouchHelper

代碼如下:

  ItemTouchHelper.Callback callback = new myItemTouchHelperCallBack(myAdapter);
  ItemTouchHelper touchHelper = new ItemTouchHelper(callback);
  touchHelper.attachToRecyclerView(mRecyclerView);

這樣,我們就實現了我們的需求,我們一起來看看效果:

好了,我們的需求完成了,效果是不是很炫酷,當然大家可以根據自己的需求做出更炫酷的效果,到時候別忘了與大家一起分享。希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • Android特效之水波紋的實現

    Android特效之水波紋的實現

    今天我們主要講一講如何通過自定義View(以下簡稱WaveView)實現 "咻咻咻" 式的水波紋擴散效果,感興趣的小伙伴們可以參考學習。
    2016-08-08
  • android自定義view仿今日頭條加載文字變色效果

    android自定義view仿今日頭條加載文字變色效果

    這篇文章主要為大家詳細介紹了android自定義view仿今日頭條加載文字變色效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-07-07
  • Android Flutter圖片處理之高斯模糊的實現

    Android Flutter圖片處理之高斯模糊的實現

    這篇文章主要為大家詳細介紹了如何利用Android Flutter實現高斯模糊效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • Android開發(fā)Jetpack組件Lifecycle使用篇

    Android開發(fā)Jetpack組件Lifecycle使用篇

    這一篇文章來介紹Android?Jetpack架構組件的Lifecycle;?Lifecycle用于幫助開發(fā)者管理Activity和Fragment?的生命周期,?由于Lifecycle是LiveData和ViewModel的基礎;所以需要先學習它
    2022-08-08
  • 總結安卓(Android)中常用的跳轉工具

    總結安卓(Android)中常用的跳轉工具

    在大家日常開發(fā)的時候經常會用到各式各樣的跳轉,如跳轉到QQ、微信聊天界面、跳轉到聯系人界面或者跳轉到瀏覽器和照相機等等之類的,本文將常用到的一些跳轉集合到一起,這樣更方便大家以后使用,有需要的小伙伴們可以參考借鑒。
    2016-08-08
  • Android組件初始化三種方式小結

    Android組件初始化三種方式小結

    在Android中,組件的初始化通常需要在適當的生命周期方法中進行,本文給大家詳細的介紹了初始化的三種方式,文中有詳細的代碼示例供大家參考,具有一定的參考價值,需要的朋友可以參考下
    2023-08-08
  • ExpandableListView實現手風琴效果

    ExpandableListView實現手風琴效果

    這篇文章主要為大家詳細介紹了ExpandableListView實現手風琴效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • 基于Android中dp和px之間進行轉換的實現代碼

    基于Android中dp和px之間進行轉換的實現代碼

    本篇文章是對在Android中dp和px之間進行轉換的實現方法進行了分析介紹,需要的朋友參考下
    2013-05-05
  • Android ViewPager導航小圓點實現無限循環(huán)效果

    Android ViewPager導航小圓點實現無限循環(huán)效果

    這篇文章主要為大家詳細介紹了Android ViewPager導航小圓點實現無限循環(huán)效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • Android實現九宮格手勢密碼

    Android實現九宮格手勢密碼

    這篇文章主要為大家詳細介紹了Android實現九宮格手勢密碼,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-06-06

最新評論