Android之RecycleView實現(xiàn)指定范圍的拖動效果
1 問題
在RecycleView里面實現(xiàn)指定位置的拖動效果,(這里是實現(xiàn)線性布局的,不是網(wǎng)格布局的)
@Override
public boolean onMove(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, RecyclerView.ViewHolder target) {
Log.i(TAG, "onMove viewHolder.getAdapterPosition() is:" + viewHolder.getAdapterPosition());
int itemViewType = viewHolder.getAdapterPosition();
Log.i(TAG, "onMove---------------------------------itemViewType is:" + itemViewType);
// if (itemViewType == 0 || itemViewType == 1 || itemViewType == 16) {
// Log.i(TAG, "onMove---------------------------------itemViewType is:" + itemViewType);
// return false;
// }
int fromPosition = viewHolder.getAdapterPosition();//得到拖動ViewHolder的position
int toPosition = target.getAdapterPosition();//得到目標ViewHolder的position
Log.i(TAG, "onMove---------------------------------fromPosition is:" + fromPosition);
Log.i(TAG, "onMove---------------------------------toPosition is:" + toPosition);
//這里的position如果不是指定范圍內的話,直接返回false,就拖動不到其它位置了
if (DragUtil.INSTANCE.getProhibitDragIndexs().contains(toPosition)) {
return false;
}
itemTouchAdapter.onMove(fromPosition,toPosition);
return true;
}
2 關鍵代碼如下
MyItemTouchCallback.java
import android.graphics.Canvas;
import android.graphics.Color;
import android.graphics.drawable.Drawable;
import android.util.Log;
import androidx.recyclerview.widget.GridLayoutManager;
import androidx.recyclerview.widget.ItemTouchHelper;
import androidx.recyclerview.widget.RecyclerView;
import com.appsinnova.android.keepdrop.manager.FileScanManager;
/**
* Created by Administrator on 2016/4/12.
*/
public class MyItemTouchCallback extends ItemTouchHelper.Callback {
public static final String TAG = MyItemTouchCallback.class.getSimpleName();
private ItemTouchAdapter itemTouchAdapter;
public MyItemTouchCallback(ItemTouchAdapter itemTouchAdapter){
this.itemTouchAdapter = itemTouchAdapter;
}
@Override
public boolean isLongPressDragEnabled() {
return false;
}
@Override
public boolean isItemViewSwipeEnabled() {
return true;
}
@Override
public int getMovementFlags(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder) {
Log.i(TAG, "getMovementFlags viewHolder.getAdapterPosition() is:" + viewHolder.getAdapterPosition());
int itemViewType = viewHolder.getAdapterPosition();
Log.i(TAG, "---------------------------------itemViewType is:" + itemViewType);
// if (itemViewType == 0 || itemViewType == 1 || itemViewType == 16) {
// Log.i(TAG, "-getMovementFlags--------------------------------itemViewType is:" + itemViewType);
// return makeMovementFlags(0, 0);
// }
if (recyclerView.getLayoutManager() instanceof GridLayoutManager) {
final int dragFlags = ItemTouchHelper.UP | ItemTouchHelper.DOWN | ItemTouchHelper.LEFT | ItemTouchHelper.RIGHT;
final int swipeFlags = 0;
return makeMovementFlags(dragFlags, swipeFlags);
} else {
final int dragFlags = ItemTouchHelper.UP | ItemTouchHelper.DOWN;
//final int swipeFlags = ItemTouchHelper.START | ItemTouchHelper.END;
final int swipeFlags = 0;
Log.i(TAG, "makeMovementFlags start");
return makeMovementFlags(dragFlags, swipeFlags);
}
}
@Override
public boolean onMove(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, RecyclerView.ViewHolder target) {
Log.i(TAG, "onMove viewHolder.getAdapterPosition() is:" + viewHolder.getAdapterPosition());
int itemViewType = viewHolder.getAdapterPosition();
Log.i(TAG, "onMove---------------------------------itemViewType is:" + itemViewType);
// if (itemViewType == 0 || itemViewType == 1 || itemViewType == 16) {
// Log.i(TAG, "onMove---------------------------------itemViewType is:" + itemViewType);
// return false;
// }
int fromPosition = viewHolder.getAdapterPosition();//得到拖動ViewHolder的position
int toPosition = target.getAdapterPosition();//得到目標ViewHolder的position
Log.i(TAG, "onMove---------------------------------fromPosition is:" + fromPosition);
Log.i(TAG, "onMove---------------------------------toPosition is:" + toPosition);
//這里的position如果不是指定范圍內的話,直接返回false,就拖動不到其它位置了
if (DragUtil.INSTANCE.getProhibitDragIndexs().contains(toPosition)) {
return false;
}
itemTouchAdapter.onMove(fromPosition,toPosition);
return true;
}
@Override
public void onSwiped(RecyclerView.ViewHolder viewHolder, int direction) {
int position = viewHolder.getAdapterPosition();
itemTouchAdapter.onSwiped(position);
}
@Override
public void onChildDraw(Canvas c, RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder, float dX, float dY, int actionState, boolean isCurrentlyActive) {
if (actionState == ItemTouchHelper.ACTION_STATE_SWIPE) {
//滑動時改變Item的透明度
final float alpha = 1 - Math.abs(dX) / (float) viewHolder.itemView.getWidth();
viewHolder.itemView.setAlpha(alpha);
viewHolder.itemView.setTranslationX(dX);
} else {
super.onChildDraw(c, recyclerView, viewHolder, dX, dY, actionState, isCurrentlyActive);
}
}
@Override
public void onSelectedChanged(RecyclerView.ViewHolder viewHolder, int actionState) {
if (actionState != ItemTouchHelper.ACTION_STATE_IDLE) {
if (background == null && bkcolor == -1) {
Drawable drawable = viewHolder.itemView.getBackground();
if (drawable == null) {
bkcolor = 0;
} else {
background = drawable;
}
}
viewHolder.itemView.setBackgroundColor(Color.LTGRAY);
}
super.onSelectedChanged(viewHolder, actionState);
}
@Override
public void clearView(RecyclerView recyclerView, RecyclerView.ViewHolder viewHolder) {
super.clearView(recyclerView, viewHolder);
viewHolder.itemView.setAlpha(1.0f);
if (background != null) viewHolder.itemView.setBackgroundDrawable(background);
if (bkcolor != -1) viewHolder.itemView.setBackgroundColor(bkcolor);
//viewHolder.itemView.setBackgroundColor(0);
if (onDragListener!=null){
onDragListener.onFinishDrag();
}
}
private Drawable background = null;
private int bkcolor = -1;
private OnDragListener onDragListener;
public MyItemTouchCallback setOnDragListener(OnDragListener onDragListener) {
this.onDragListener = onDragListener;
return this;
}
public interface OnDragListener{
void onFinishDrag();
}
public interface ItemTouchAdapter {
void onMove(int fromPosition, int toPosition);
void onSwiped(int position);
}
}
OnRecyclerItemClickListener.java
import android.view.GestureDetector;
import android.view.MotionEvent;
import android.view.View;
import androidx.core.view.GestureDetectorCompat;
import androidx.recyclerview.widget.RecyclerView;
/**
* Created by Administrator on 2016/4/14.
*/
public class OnRecyclerItemClickListener implements RecyclerView.OnItemTouchListener {
private GestureDetectorCompat mGestureDetector;
private RecyclerView recyclerView;
public OnRecyclerItemClickListener(RecyclerView recyclerView){
this.recyclerView = recyclerView;
mGestureDetector = new GestureDetectorCompat(recyclerView.getContext(),new ItemTouchHelperGestureListener());
}
@Override
public boolean onInterceptTouchEvent(RecyclerView rv, MotionEvent e) {
mGestureDetector.onTouchEvent(e);
return false;
}
@Override
public void onTouchEvent(RecyclerView rv, MotionEvent e) {
mGestureDetector.onTouchEvent(e);
}
@Override
public void onRequestDisallowInterceptTouchEvent(boolean disallowIntercept) {
}
private class ItemTouchHelperGestureListener extends GestureDetector.SimpleOnGestureListener {
@Override
public boolean onSingleTapUp(MotionEvent e) {
View child = recyclerView.findChildViewUnder(e.getX(), e.getY());
if (child!=null) {
RecyclerView.ViewHolder vh = recyclerView.getChildViewHolder(child);
onItemClick(vh);
}
return true;
}
@Override
public void onLongPress(MotionEvent e) {
View child = recyclerView.findChildViewUnder(e.getX(), e.getY());
if (child!=null) {
RecyclerView.ViewHolder vh = recyclerView.getChildViewHolder(child);
onLongClick(vh);
}
}
}
public void onLongClick(RecyclerView.ViewHolder vh){}
public void onItemClick(RecyclerView.ViewHolder vh){}
}
適配器里面實現(xiàn)接口
MyItemTouchCallback.ItemTouchAdapter
import android.text.TextUtils;
import android.util.Log;
import android.view.View;
import android.widget.ImageView;
import org.greenrobot.eventbus.EventBus;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import static com.appsinnova.android.keepdrop.recommend.entity.ChannelHead.channelType;
public class ChannelManagerAdapter extends BaseMultiItemQuickAdapter<MultiItemEntity, BaseViewHolder> implements MyItemTouchCallback.ItemTouchAdapter {
public static final String TAG = ChannelManagerAdapter.class.getSimpleName();
public static final int MY_VEDIO_TYPE = 0;
public static final int MORE_VEDIO_TYPE = 1;
public static final int CAN_EDITABLE = 1;
public static final int CAN_NOT_EDITABLE = 0;
public List<MultiItemEntity> results = null;
public ChannelManagerAdapter(List<MultiItemEntity> data) {
super(data);
addItemType(ChannelHead.channelHeadType, R.layout.item_channel_head);
addItemType(channelType, R.layout.item_channel);
this.results = data;
}
@Override
protected void convert(BaseViewHolder helper, MultiItemEntity item) {
switch (helper.getItemViewType()) {
}
}
@Override
public void onMove(int fromPosition, int toPosition) {
if (fromPosition==results.size()-1 || toPosition==results.size()-1){
return;
}
if (fromPosition < toPosition) {
for (int i = fromPosition; i < toPosition; i++) {
Collections.swap(results, i, i + 1);
}
} else {
for (int i = fromPosition; i > toPosition; i--) {
Collections.swap(results, i, i - 1);
}
}
//這個數(shù)據(jù)是移動后的數(shù)據(jù),會更新原始數(shù)據(jù)
int size = results.size();
List<RecommendVedioModel.RecommendVedioItem> items = new ArrayList<RecommendVedioModel.RecommendVedioItem>();
RecommendVedioModel recommendVedioModel = SPHelper.getInstance().getObject(SpConstants.RECOMMEND_VEDIO_CATETGORY, RecommendVedioModel.class);
for (int i = 0; i < size; ++i) {
if (results.get(i).getItemType() == channelType) {
RecommendVedioModel.RecommendVedioItem item = (RecommendVedioModel.RecommendVedioItem)results.get(i);
items.add(item);
}
}
if (recommendVedioModel != null) {
recommendVedioModel.items = items;
} else {
Log.i(TAG, "recommendVedioModel is null");
}
SPHelper.getInstance().putObject(SpConstants.RECOMMEND_VEDIO_CATETGORY, recommendVedioModel);
notifyItemMoved(fromPosition, toPosition);
}
@Override
public void onSwiped(int position) {
}
}
然后在頁面顯示的地方
channelManagerAdapter = ChannelManagerAdapter(allDatas)
val layoutManager = LinearLayoutManager(this)
layoutManager.orientation = LinearLayoutManager.VERTICAL
channelRecycleview.setLayoutManager(layoutManager)
channelRecycleview.setAdapter(channelManagerAdapter)
val itemTouchHelper = ItemTouchHelper(MyItemTouchCallback(channelManagerAdapter))
itemTouchHelper.attachToRecyclerView(channelRecycleview)
channelRecycleview.addOnItemTouchListener(object : OnRecyclerItemClickListener(channelRecycleview) {
override fun onLongClick(vh: RecyclerView.ViewHolder) {
LogUtil.i(TAG, "onLongClick vh.layoutPosition is:" + vh.layoutPosition)
var index = vh.layoutPosition
if (!prohibitDragIndexs.contains(index)) {
itemTouchHelper.startDrag(vh)
}
}
})
到此這篇關于Android之RecycleView實現(xiàn)指定范圍的拖動效果的文章就介紹到這了,更多相關android recycleView實現(xiàn)指定范圍的拖動內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
- android RecycleView實現(xiàn)下拉刷新和上拉加載
- Android RecycleView滑動停止后自動吸附效果的實現(xiàn)代碼(滑動定位)
- Android 使用RecycleView列表實現(xiàn)加載更多的示例代碼
- android RecycleView實現(xiàn)多級樹形列表
- Android RecycleView實現(xiàn)Item拖拽效果
- Android RecycleView和線型布局制作聊天布局
- Android移動開發(fā)recycleView的頁面點擊跳轉設計實現(xiàn)
- Android使用NestedScrollView?內嵌RecycleView滑動沖突問題解決
相關文章
Android開發(fā)中如何去掉app標題欄的實現(xiàn)
這篇文章主要介紹了Android開發(fā)中如何去掉app標題欄的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-04-04
Android編程自定義AlertDialog樣式的方法詳解
這篇文章主要介紹了Android編程自定義AlertDialog樣式的方法,結合實例形式詳細分析了Android自定義AlertDialog樣式的具體布局與功能實現(xiàn)相關操作技巧,需要的朋友可以參考下2018-02-02
Android中Fragment子類及其PreferenceFragment的創(chuàng)建過程演示
這篇文章主要介紹了Android中Fragment子類及其PreferenceFragment的創(chuàng)建過程演示,PreferenceFragment用來保存Fragment的選項設置,需要的朋友可以參考下2016-05-05
詳解Android Activity之間切換傳遞數(shù)據(jù)的方法
這篇文章主要介紹了詳解Android Activity之間切換傳遞數(shù)據(jù)的方法 的相關資料,需要的朋友可以參考下2016-04-04
android webview 中l(wèi)ocalStorage無效的解決方法
這篇文章主要介紹了android webview 中l(wèi)ocalStorage無效的解決方法,本文直接給出解決方法實現(xiàn)代碼,需要的朋友可以參考下2015-06-06
android onTouchEvent處理機制總結(必看)
下面小編就為大家?guī)硪黄猘ndroid onTouchEvent處理機制總結(必看)小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-04-04
Android編程實現(xiàn)Toast自定義布局簡單示例
這篇文章主要介紹了Android編程實現(xiàn)Toast自定義布局的方法,結合簡單實例形式分析了Toast自定義布局的實現(xiàn)步驟與相關操作技巧,需要的朋友可以參考下2017-02-02

