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

Android Recyclerview實現(xiàn)多選,單選,全選,反選,批量刪除的功能

 更新時間:2017年06月14日 11:04:10   作者:郭_昊  
本篇文章主要介紹了Android Recyclerview 實現(xiàn)多選,單選,全選,反選,批量刪除的功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下

效果圖如下:

這里寫圖片描述 

這里寫圖片描述 

這里寫圖片描述

Recyclerview 實現(xiàn)多選,單選,全選,反選,批量刪除的步驟

1.在Recyclerview布局中添加上底部的全選和反選按鈕,刪除按鈕,和計算數(shù)量等控件

2.這里選中的控件沒有用checkbox來做,用的是imageview,選中和不選中其實是兩張圖片

3.默認是不顯示選中的控件的,點擊編輯的時候顯示,點擊取消的時候隱藏

4.通過adapter和activity數(shù)據(jù)之間的傳遞,然后進行具體的操作

具體代碼如下:

在recyclerview的布局中寫全選,反選,刪除,計數(shù)等相應的控件

 <LinearLayout
  android:id="@+id/ll_mycollection_bottom_dialog"
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  android:orientation="vertical"
  android:layout_gravity="bottom"
  android:visibility="gone"
  android:background="@color/app_bg">

  <View
   android:background="#e5e5e5"
   android:layout_width="match_parent"
   android:layout_height="1px"/>

  <RelativeLayout
   android:background="@color/white"
   android:layout_width="match_parent"
   android:layout_height="@dimen/px_90">


   <TextView
    android:layout_centerVertical="true"
    android:id="@+id/tv"
    android:textColor="#1A1A1A"
    android:textSize="@dimen/px_28"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginLeft="@dimen/px_30"
    android:text="@string/mine_certify_select" />

   <TextView
    android:layout_centerVertical="true"
    android:layout_toRightOf="@+id/tv"
    android:textColor="#1A1A1A"
    android:textSize="@dimen/px_28"
    android:id="@+id/tv_select_num"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginLeft="@dimen/px_18"
    android:text="0" />

   <Button
    android:textColor="@color/color_b7b8bd"
    android:textSize="@dimen/px_28"
    android:layout_centerVertical="true"
    android:background="@drawable/button__noclickable_shape"
    android:gravity="center"
    android:id="@+id/btn_delete"
    android:layout_width="@dimen/px_160"
    android:layout_height="@dimen/px_66"
    android:layout_marginRight="@dimen/px_30"
    android:layout_alignParentRight="true"
    android:text="刪除" />

   <TextView
    android:layout_centerVertical="true"
    android:id="@+id/select_all"
    android:layout_marginRight="@dimen/px_30"
    android:background="@drawable/bg_selete_all"
    android:layout_toLeftOf="@+id/btn_delete"
    android:layout_width="@dimen/px_160"
    android:layout_height="@dimen/px_66"
    android:text="全選"
    android:gravity="center"
    android:textColor="#000001"
    android:textSize="@dimen/px_28"/>

  </RelativeLayout>
 </LinearLayout>

Adapter中的布局就不必再寫了,就一個item,最左邊一個imageview.

  <ImageView
   android:id="@+id/check_box"
   android:src="@mipmap/ic_uncheck"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:layout_gravity="center_vertical"
   android:layout_marginLeft="@dimen/px_24"
   android:gravity="center"
   android:visibility="gone"/>

布局寫完開始寫邏輯代碼

首先在adapter定義一個方法,以便在activity中拿到數(shù)據(jù)添加進adapter中

 public void notifyAdapter(List<MyLiveList.MyLive> myLiveList,boolean isAdd){
  if (!isAdd){
   this.mMyLiveList=myLiveList;
  }else {
   this.mMyLiveList.addAll(myLiveList);
  }
  notifyDataSetChanged();
 }

然后在activity中拿到獲取到數(shù)據(jù)后調用adapter中的這個方法,添加數(shù)據(jù)

 mAdapter.notifyAdapter(data.getList(), false);

在adapter中在判空,更有保證

 public List<MyLiveList.MyLive> getMyLiveList(){
  if (mMyLiveList == null) {
   mMyLiveList =new ArrayList<>();
  }
  return mMyLiveList;
 }

然后adapter中的getItemCount就直接拿到上面這個mMyLiveList的大小就可以了

接下來開始點擊編輯的時候顯示出imageview和recycleview中的底部全選反選部分

定義兩個變量

 private static final int MYLIVE_MODE_CHECK = 0;
 private static final int MYLIVE_MODE_EDIT = 1;

//點擊編輯的時候顯示,順便調mAdapter.setEditMode(mEditMode);賦值
 mEditMode = mEditMode == MYLIVE_MODE_CHECK ? MYLIVE_MODE_EDIT : MYLIVE_MODE_CHECK;
  if (mEditMode == MYLIVE_MODE_EDIT) {
   activity_btn.setText("取消");
   ll_mycollection_bottom_dialog.setVisibility(View.VISIBLE);
   editorStatus = true;
  } else {
   activity_btn.setText("編輯");
   ll_mycollection_bottom_dialog.setVisibility(View.GONE);
   editorStatus = false;
   onRefresh();
  }
  mAdapter.setEditMode(mEditMode);

//當然,adapter中也有先關的變量在記錄
 private static final int MYLIVE_MODE_CHECK = 0;
 int mEditMode = MYLIVE_MODE_CHECK;

 public void setEditMode(int editMode) {
  mEditMode = editMode;
  notifyDataSetChanged();
 }
//在onBindViewHolder中做顯示和隱藏的操作.

 holder.setIsRecyclable(false); // 為了條目不復用

//顯示和隱藏
  if (mEditMode == MYLIVE_MODE_CHECK) {
   holder.mCheckBox.setVisibility(View.GONE);
  } else {
   holder.mCheckBox.setVisibility(View.VISIBLE);

為了方便記錄選中的狀態(tài),在bean里面用個變量記起來

 public boolean isSelect;
  public boolean isSelect() {
   return isSelect;
  }
  public void setSelect(boolean isSelect) {
   this.isSelect = isSelect;
  }
//然后點擊條目選中和不選中的時候為Imageview設置不同的圖片
   if(myLive.isSelect()) {
    holder.mCheckBox.setImageResource(R.mipmap.ic_checked);
   }else{
    holder.mCheckBox.setImageResource(R.mipmap.ic_uncheck);
   }

//在adapter中暴漏一個Item的點擊事件的接口
 public interface OnSwipeListener {
  void onItemClickListener(int pos,List<MyLiveList.MyLive> myLiveList);
 }

/* 
在activity中的item點擊事件中,來操作Imageview是否選中 
*/

//用一個變量記錄
 private int index = 0;

 MyLive myLive = myLiveList.get(pos);
   boolean isSelect = myLive.isSelect();
   if (!isSelect) {
    index++;
    myLive.setSelect(true);
    if (index == myLiveList.size()) {
     isSelectAll = true;
     selectAll.setText("取消全選");
    }

   } else {
    myLive.setSelect(false);
    index--;
    isSelectAll = false;
    selectAll.setText("全選");
   }
   setBtnBackground(index);
   tv_select_num.setText(String.valueOf(index));
   radioAdapter.notifyDataSetChanged();
 /**
  * 根據(jù)選擇的數(shù)量是否為0來判斷按鈕的是否可點擊.
  *
  * @param size
  */
 private void setBtnBackground(int size) {
  if (size != 0) {
   mBtnDelete.setBackgroundResource(R.drawable.button_shape);
   mBtnDelete.setEnabled(true);
   mBtnDelete.setTextColor(Color.WHITE);
  } else {
   mBtnDelete.setBackgroundResource(R.drawable.button__noclickable_shape);
   mBtnDelete.setEnabled(false);
   mBtnDelete.setTextColor(ContextCompat.getColor(this, R.color.color_b7b8bd));
  }
 }

至于全選和反選的操作,就是遍歷這個bean類,得到他的選擇狀態(tài),重新設置就可以了.

 if (radioAdapter == null) return;
  if (!isSelectAll) {
   for (int i = 0, j = radioAdapter.getMyLiveList().size(); i < j; i++) {
    radioAdapter.getMyLiveList().get(i).setSelect(true);
   }
   index = radioAdapter.getMyLiveList().size();
   mBtnDelete.setEnabled(true);
   selectAll.setText("取消全選");
   isSelectAll = true;
  } else {
   for (int i = 0, j = radioAdapter.getMyLiveList().size(); i < j; i++) {
    radioAdapter.getMyLiveList().get(i).setSelect(false);
   }
   index = 0;
   mBtnDelete.setEnabled(false);
   selectAll.setText("全選");
   isSelectAll = false;
  }
  radioAdapter.notifyDataSetChanged();
  setBtnBackground(index);
  tv_select_num.setText(String.valueOf(index));

最后刪除的話就調刪除的接口,遍歷這個bean,判斷當前的狀態(tài)如果是選中的狀態(tài),就刪除! 這樣就OK了 !!!

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • Android編程設置屏幕亮度的方法

    Android編程設置屏幕亮度的方法

    這篇文章主要介紹了Android編程設置屏幕亮度的方法,結合實例形式分析了Android獲取及設置屏幕亮度的相關實現(xiàn)技巧,需要的朋友可以參考下
    2017-07-07
  • Android應用開發(fā)中Fragment的靜態(tài)加載與動態(tài)加載實例

    Android應用開發(fā)中Fragment的靜態(tài)加載與動態(tài)加載實例

    這篇文章主要介紹了Android應用開發(fā)中Fragment的靜態(tài)加載與動態(tài)加載實例,例子中包括動態(tài)的添加更新以及刪除Fragment等操作,很有借鑒意義,需要的朋友可以參考下
    2016-02-02
  • Compose自定義View實現(xiàn)宇智波斑寫輪眼

    Compose自定義View實現(xiàn)宇智波斑寫輪眼

    這篇文章主要為大家介紹了Compose自定義View實現(xiàn)宇智波斑寫輪眼示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-02-02
  • Android動態(tài)時鐘壁紙開發(fā)

    Android動態(tài)時鐘壁紙開發(fā)

    這篇文章主要為大家詳細介紹了Android動態(tài)時鐘壁紙開發(fā)的相關資料,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • Jetpack Compose實現(xiàn)對話框和進度條實例解析

    Jetpack Compose實現(xiàn)對話框和進度條實例解析

    對話框和進度條其實并無多大聯(lián)系,放在一起寫是因為兩者的內容都不多,所以湊到一起,對話框是我們平時開發(fā)使用得比較多的組件,進度條的使用頻率也很高,比如下載文件,上傳文件,處理任務時都可以使用進度條
    2023-04-04
  • Android仿QQ微信實時監(jiān)測網絡狀態(tài)

    Android仿QQ微信實時監(jiān)測網絡狀態(tài)

    這篇文章主要為大家詳細介紹了Android仿QQ微信實時監(jiān)測網絡狀態(tài),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • Android自定義ListView實現(xiàn)下拉刷新上拉加載更多

    Android自定義ListView實現(xiàn)下拉刷新上拉加載更多

    Listview現(xiàn)在用的很少了,基本都是使用Recycleview,但是不得不說Listview具有劃時代的意義,我們可以自己添加下拉刷新,上拉加載更多功能。本文就來利用自定義ListView實現(xiàn)下拉刷新上拉加載更多效果,需要的可以參考一下
    2022-10-10
  • Android?WebView的使用與后退鍵處理詳細討論

    Android?WebView的使用與后退鍵處理詳細討論

    在android開發(fā)中我們有時候根據(jù)項目的需求多少會加載一些webview,加載webview,我們有時候會根據(jù)UI來自定義返回鍵,下面這篇文章主要給大家介紹了關于Android?WebView的使用與后退鍵處理的相關資料,需要的朋友可以參考下
    2024-04-04
  • android不同activity之間共享數(shù)據(jù)解決方法

    android不同activity之間共享數(shù)據(jù)解決方法

    最近做局域網socket連接問題,要在多個activity之間公用一個socket連接,就在網上搜了下資料,感覺還是application方法好用,帖出來需要的朋友可以參考下
    2012-11-11
  • Android中Permission權限機制的具體使用

    Android中Permission權限機制的具體使用

    這篇文章主要介紹了Android中Permission權限機制的具體使用,本文講解了權限級別 protection level、ICC(inter-component communication)權限保護等內容,需要的朋友可以參考下
    2015-04-04

最新評論