Android RecyclerView滑動(dòng)刪除和拖動(dòng)排序
本篇是接著上面三篇之后的一個(gè)對(duì)RecyclerView的介紹,這里多說(shuō)兩句,如果你還在使用ListView的話,可以放棄掉ListView了。RecyclerView自動(dòng)幫我們緩存Item視圖(ViewHolder),允許我們自定義各種動(dòng)作的動(dòng)畫(huà)和分割線,允許我們對(duì)Item進(jìn)行一些手勢(shì)操作。另外,因?yàn)镈esign庫(kù)的推出大大方便我們編寫(xiě)帶有Material風(fēng)格的App,而ListView是不兼容這個(gè)庫(kù)的,比如滑動(dòng)的相互協(xié)調(diào),只有RecyclerView能做到。
先看本篇內(nèi)容的效果圖:

效果內(nèi)容主要有三部分:
•長(zhǎng)按點(diǎn)擊其中一個(gè)Item之后可以將其拖動(dòng)到其他地方
•向左右滑動(dòng)可以刪除某個(gè)Item
•長(zhǎng)按的時(shí)候會(huì)有一個(gè)浮起的動(dòng)作,放下之后會(huì)重新重新對(duì)齊
①先易后難,卡片浮起效果
在Material Design中,物件的呈現(xiàn)是以3d的模式來(lái)進(jìn)行的,也就是在原來(lái)的基礎(chǔ)上增加了一個(gè)Z軸來(lái)表示物體的高度。

當(dāng)我們點(diǎn)擊一個(gè)卡片的時(shí)候,應(yīng)該給予用戶一些反饋,讓用戶知道自己在操作這個(gè)卡片,也就是觸摸反饋。觸摸效果圖的觸摸反饋是先出現(xiàn)水波紋,接著當(dāng)卡片可以移動(dòng)的時(shí)候先浮動(dòng),再開(kāi)始移動(dòng),最后下落,效果如下:(浮起的動(dòng)畫(huà)可能要仔細(xì)看)

實(shí)現(xiàn):
水波紋效果使用系統(tǒng)提供的,因?yàn)镈emo中使用的是一個(gè)CardView來(lái)呈現(xiàn)內(nèi)容,所以只需要給CardView加上兩個(gè)屬性即可:
android:clickable="true"
android:foreground="?android:attr/selectableItemBackground"
浮起和下沉的動(dòng)畫(huà)也不難,改變View的translationZ屬性即可:
private void pickUpAnimation(View view) {
ObjectAnimator animator = ObjectAnimator.ofFloat(view, "translationZ", 1f, 10f);
animator.setInterpolator(new DecelerateInterpolator());
animator.setDuration(300);
animator.start();
}
②滑動(dòng)(Swipe)和移動(dòng)(Move)Item
Swipe是指我們上面的左右滑動(dòng)刪除,Move則是我們對(duì)Item的移動(dòng),改變列表的排序。要實(shí)現(xiàn)這兩個(gè)功能,需要用到一個(gè)類(lèi)ItemTouchHelper,當(dāng)我們構(gòu)造好這個(gè)類(lèi)之后,可以調(diào)用它的attachToRecyclerView方法將其綁定在某個(gè)RecyclerView中,當(dāng)RecyclerView出現(xiàn)某些操作(滑動(dòng)和移動(dòng))時(shí),構(gòu)造這個(gè)類(lèi)的時(shí)候傳入的回調(diào)類(lèi)會(huì)回調(diào)相應(yīng)的方法,我們?cè)谶@些方法中對(duì)數(shù)據(jù)集進(jìn)行操作即可。
new ItemTouchHelper(new ItemTouchHelper.Callback() { //省略代碼
}).attachToRecyclerView(mRecyclerView);
接著就是重寫(xiě)接口Callback的方法了,這里需要重寫(xiě)的有幾個(gè),分別是:
•isItemViewSwipeEnable : Item是否可以滑動(dòng)
•isLongPressDragEnable :Item是否可以長(zhǎng)按
•getMovementFlags : 獲取移動(dòng)標(biāo)志
•onMove : 當(dāng)一個(gè)Item被另外的Item替代時(shí)回調(diào),也就是數(shù)據(jù)集的內(nèi)容順序改變
•onMoved : 當(dāng)onMove返回true的時(shí)候回調(diào)
•onSwiped : 當(dāng)某個(gè)Item被滑動(dòng)離開(kāi)屏幕之后回調(diào)
•setSelectedChange : 某個(gè)Item被長(zhǎng)按選中會(huì)被回調(diào),當(dāng)某個(gè)被長(zhǎng)按移動(dòng)的Item被釋放時(shí)也調(diào)用
new ItemTouchHelper(new ItemTouchHelper.Callback() {
private RecyclerView.ViewHolder vh;
@Override
public boolean isItemViewSwipeEnabled() {
return true;
}
@Override
public boolean isLongPressDragEnabled() {
return true;
}
@Override
public int getMovementFlags(RecyclerView recyclerView, RecyclerView.ViewHolder
viewHolder) {
// 拖拽的標(biāo)記,這里允許上下左右四個(gè)方向
int dragFlags = ItemTouchHelper.UP | ItemTouchHelper.DOWN | ItemTouchHelper.LEFT |
ItemTouchHelper.RIGHT;
// 滑動(dòng)的標(biāo)記,這里允許左右滑動(dòng)
int swipeFlags = ItemTouchHelper.START | ItemTouchHelper.END;
return makeMovementFlags(dragFlags, swipeFlags);
}
/*
這個(gè)方法會(huì)在某個(gè)Item被拖動(dòng)和移動(dòng)的時(shí)候回調(diào),這里我們用來(lái)播放動(dòng)畫(huà),當(dāng)viewHolder不為空時(shí)為選中狀態(tài)
否則為釋放狀態(tài)
*/
@Override
public void onSelectedChanged(RecyclerView.ViewHolder viewHolder, int actionState) {
super.onSelectedChanged(viewHolder, actionState);
if (viewHolder != null) {
vh = viewHolder;
pickUpAnimation(viewHolder.itemView);
} else {
if (vh != null) {
putDownAnimation(vh.itemView);
}
}
}
@Override
public boolean onMove(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder,
RecyclerView.ViewHolder target) {
// 移動(dòng)時(shí)更改列表中對(duì)應(yīng)的位置并返回true
Collections.swap(newsList, viewHolder.getAdapterPosition(), target
.getAdapterPosition());
return true;
}
/*
當(dāng)onMove返回true時(shí)調(diào)用
*/
@Override
public void onMoved(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, int
fromPos, RecyclerView.ViewHolder target, int toPos, int x, int y) {
super.onMoved(recyclerView, viewHolder, fromPos, target, toPos, x, y);
// 移動(dòng)完成后刷新列表
mAdapter.notifyItemMoved(viewHolder.getAdapterPosition(), target
.getAdapterPosition());
}
@Override
public void onSwiped(RecyclerView.ViewHolder viewHolder, int direction) {
// 將數(shù)據(jù)集中的數(shù)據(jù)移除
newsList.remove(viewHolder.getAdapterPosition());
// 刷新列表
mAdapter.notifyItemRemoved(viewHolder.getAdapterPosition());
}
}).attachToRecyclerView(mRecyclerView);
這里直接貼出代碼,并做了注釋,應(yīng)該比較簡(jiǎn)單了。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Android RecyclerView item選中放大被遮擋問(wèn)題詳解
- Android RecyclerView實(shí)現(xiàn)多種item布局的方法
- Android使用CardView作為RecyclerView的Item并實(shí)現(xiàn)拖拽和左滑刪除
- Android中RecyclerView實(shí)現(xiàn)Item添加和刪除的代碼示例
- Android中RecyclerView的item寬高問(wèn)題詳解
- Android RecyclerView顯示Item布局不一致解決辦法
- Android RecyclerView的Item點(diǎn)擊事件實(shí)現(xiàn)整理
- Android 中RecyclerView多種item布局的寫(xiě)法(頭布局+腳布局)
- Android RecyclerView自由拖動(dòng)item的實(shí)現(xiàn)代碼
相關(guān)文章
Android 實(shí)現(xiàn)自定義圓形進(jìn)度條的功能
這篇文章主要介紹了Android 實(shí)現(xiàn)自定義圓形進(jìn)度條的功能的相關(guān)資料,開(kāi)發(fā)Android應(yīng)用的朋友肯定對(duì)自定義View不陌生,很多都有重新寫(xiě)的,這里就對(duì)實(shí)現(xiàn)圓形進(jìn)度條介紹下,需要的朋友可以參考下2016-11-11
Android Studio實(shí)現(xiàn)單選對(duì)話框
這篇文章主要為大家詳細(xì)介紹了Android Studio實(shí)現(xiàn)單選對(duì)話框,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05
Android 邊播邊緩存的實(shí)現(xiàn)(MP4 未加密m3u8)
這篇文章主要介紹了Android 邊播邊緩存的實(shí)現(xiàn)(MP4 未加密m3u8),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-11-11
Android Intent發(fā)送廣播消息實(shí)例詳解
這篇文章主要介紹了Android Intent發(fā)送廣播消息實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-04-04
Android實(shí)現(xiàn)動(dòng)畫(huà)效果的自定義下拉菜單功能
這篇文章主要介紹了Android實(shí)現(xiàn)動(dòng)畫(huà)效果的自定義下拉菜單功能,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-02-02
Android中使用GridView和ImageViewSwitcher實(shí)現(xiàn)電子相冊(cè)簡(jiǎn)單功能實(shí)例
本篇文章主要介紹了Android中使用GridView和ImageViewSwitcher實(shí)現(xiàn)電子相冊(cè)簡(jiǎn)單功能實(shí)例,具有一定的參考價(jià)值,有需要的可以了解一下。2016-12-12

