這篇文章主要為大家展示了“Android如何使用CardView作為RecyclerView的Item并實現(xiàn)拖拽和左滑刪除”,內(nèi)容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學習一下“Android如何使用CardView作為RecyclerView的Item并實現(xiàn)拖拽和左滑刪除”這篇文章吧。
在當涂等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都網(wǎng)站建設(shè)、成都網(wǎng)站設(shè)計 網(wǎng)站設(shè)計制作按需定制網(wǎng)站,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站設(shè)計,營銷型網(wǎng)站建設(shè),外貿(mào)網(wǎng)站制作,當涂網(wǎng)站建設(shè)費用合理。
CardView的屬性
CardView繼承自FrameLayout,所以子控件的布局規(guī)則和FrameLayout的一樣,是按照層次堆疊的
下面是CardView的一些常用屬性:
CardView的基本使用
先看一下效果:
這是一個CardView,多個羅列起來看起啦會更酷,好了,我們先看一下代碼:
看完了布局文件,是不是覺得這個布局不僅炫酷而且使用簡單,下面我們把它應(yīng)用到RecyclerView中,看起來會更炫酷。
CardView應(yīng)用在RecyclerView中
CardView通常會應(yīng)用在RecyclerView和ListView中,今天我們就講一講如何應(yīng)用在RecyclerView中。我們現(xiàn)在在大多數(shù)應(yīng)用或者手機系統(tǒng)界面中會見到這樣的效果:
是不是覺得很棒,下面我們就用CardView和RecyclerView來實現(xiàn)一下這個效果。
布局文件
我們實現(xiàn)這個效果的第一步是先添加依賴庫:
implementation 'com.android.support:recyclerview-v7:26.+' implementation 'com.android.support:cardview-v7:26.+'
然后寫一下布局文件,Item的布局文件我就直接采用上面的代碼了,然后再寫一個主界面的布局文件,比較簡單,如下:
Activity內(nèi)代碼
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); //設(shè)置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{ LayoutInflater mInflater; List 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); } } } //制造一個數(shù)據(jù)源 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 addData(){ List 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
想實現(xiàn)拖拽和滑動刪除的效果,很可惜RecyclerView并沒有提供現(xiàn)成的API供我們使用,但是SDK為我們提供了ItemTouchHelper這樣一個工具類幫助我們來輕松實現(xiàn)這些功能,我們先來了解一下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實現(xiàn)
我們選擇使用一個接口來實現(xiàn)Adapter和ItemTouchHelper之間涉及數(shù)據(jù)的操作,因為ItemTouchHelper完成觸摸的各種動畫以后,就要對Adapter的數(shù)據(jù)進行操作,比如我們在側(cè)滑刪除以后,最后需要調(diào)用Adapter的notifyItemRemove()方法來移除該數(shù)據(jù)。所以我們可以把數(shù)據(jù)操作的部分抽象成一個接口方法,讓Callbac調(diào)用它即可。具體如下:
新建一個接口:
ItemTouchHelperAdapter
public interface ItemTouchHelperAdapter { //移動item public void onItemMove(int fromPosition,int toPosition); //刪除item public void onItemDelete(int position); }
之后讓Adapter實現(xiàn)這個接口
class MyAdapter extends RecyclerView.Adapterimplements ItemTouchHelperAdapter{ LayoutInflater mInflater; List 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) { //移除數(shù)據(jù) 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中直接調(diào)用接口里的方法就可以了。
2.新建Callback方法,繼承ItemTouchHelper.Callback
官方文檔已經(jīng)告訴我們,使用ItemTouchHelper需要一個Callback,這個Callback是ItemTouchHelper.Callback的子類,我們需要新建一個類來繼承ItemTouchHelper.Callback,然后重寫一些方法來實現(xiàn)我們的需求。代碼如下:
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í)行滑動刪除操作,就是可以調(diào)用onSwiped()方法 return true; } }
ItemTouchHelper.Callback還有其他幾個常用方法:
public void onSelectedChanged(RecyclerView.ViewHolder viewHolder, int actionState):從靜止狀態(tài)變?yōu)橥献Щ蛘呋瑒拥臅r候會調(diào)用該方法,參數(shù)actionState表示當前狀態(tài)。
public void clearView(RecyclerView recyclerView, ViewHolder viewHolder):當用戶操作完某個item并且動畫也結(jié)束后會調(diào)用該方法,一般我們在該方法內(nèi)恢復ItemView的初始狀態(tài),防止由于復用而產(chǎn)生的錯亂問題。
public void onChildDraw(…):我們可以在這個方法內(nèi)實現(xiàn)我們自定義的交互規(guī)則或者自定義動畫。
這樣下來我們就只剩下一步了。
3.為RecyclerView添加ItemTouchHelper
代碼如下:
ItemTouchHelper.Callback callback = new myItemTouchHelperCallBack(myAdapter); ItemTouchHelper touchHelper = new ItemTouchHelper(callback); touchHelper.attachToRecyclerView(mRecyclerView);
這樣,我們就實現(xiàn)了我們的需求,我們一起來看看效果:
以上是“Android如何使用CardView作為RecyclerView的Item并實現(xiàn)拖拽和左滑刪除”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學習更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!