界面无小事(八):RecyclerView增删item
界面無小事(一): RecyclerView+CardView了解一下
界面無小事(二): 讓RecyclerView展示更多不同視圖
界面無小事(三):用RecyclerView + Toolbar做個(gè)文件選擇器
界面無小事(四):來寫個(gè)滾動(dòng)選擇器吧!
界面無小事(五):自定義TextView
界面無小事(六):來做個(gè)好看得側(cè)拉菜單!
界面無小事(七):使用代碼動(dòng)態(tài)增刪布局
目錄
- 前言
- 增刪item
- 自定義增刪動(dòng)畫
- 最后
前言
之前寫過一篇代碼動(dòng)態(tài)增刪布局的, 對(duì)比下這次的RecyclerView增刪item, 說句實(shí)話, 代碼動(dòng)態(tài)增刪布局基本可以退群了.
增刪item
當(dāng)然首先你可以按照第一篇-界面無小事(一): RecyclerView+CardView了解一下建立基礎(chǔ)的RecyclerView. 這次的關(guān)鍵是在適配器代碼中加入增刪item的操作. 要注意一點(diǎn), 刷新和原來在ListView的操作是不一樣的. 你可以直接看官方文檔, 大致有這幾個(gè):
- notifyItemInserted()
- notifyItemRemoved()
- notifyItemMoved()
- notifyItemChanged()
在適配器中加入如下代碼:
public void addData(int position) {mData.add(position, "hello python");notifyItemInserted(position); }public void removeData(int position) {mData.remove(position);notifyItemRemoved(position); } 復(fù)制代碼然后我們在toolbar中加上add和del按鈕, 對(duì)應(yīng)這兩個(gè)方法.
<?xml version="1.0" encoding="utf-8"?> <menu xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"><itemandroid:id="@+id/add"android:icon="@mipmap/ic_launcher"android:title="@string/add"app:showAsAction="never" /><itemandroid:id="@+id/del"android:icon="@mipmap/ic_launcher"android:title="@string/del"app:showAsAction="never" /> </menu> 復(fù)制代碼并且設(shè)置長按為刪除操作, 點(diǎn)擊是增加操作. 好了, 上效果圖:
不單單是我演示的這種布局, 還有線型的, 橫向的, 瀑布流都可以有這種類似效果. 可參考界面無小事(二): 讓RecyclerView展示更多不同視圖.
那既然有默認(rèn)動(dòng)畫, 肯定就能自定義動(dòng)畫了. 在這之前, 先說說幾個(gè)方法. 用來設(shè)置動(dòng)畫的具體狀態(tài)的持續(xù)時(shí)間.
rvTest.getItemAnimator().setAddDuration(400); rvTest.getItemAnimator().setRemoveDuration(400); rvTest.getItemAnimator().setMoveDuration(400); rvTest.getItemAnimator().setChangeDuration(400); 復(fù)制代碼自定義增刪動(dòng)畫
這里借助開源項(xiàng)目. 因?yàn)檫@個(gè)項(xiàng)目真的足夠地棒. 自帶動(dòng)畫個(gè)數(shù)都已經(jīng)足夠用了, 見下. 你還可以繼續(xù)在這基礎(chǔ)上自定義. 是不是感覺三生萬物了.
Animators
| Cool | LandingAnimator |
| Scale | ScaleInAnimator, ScaleInTopAnimator, ScaleInBottomAnimator, ScaleInLeftAnimator, ScaleInRightAnimator |
| Fade | FadeInAnimator, FadeInDownAnimator, FadeInUpAnimator, FadeInLeftAnimator, FadeInRightAnimator |
| Flip | FlipInTopXAnimator, FlipInBottomXAnimator, FlipInLeftYAnimator, FlipInRightYAnimator |
| Slide | SlideInLeftAnimator, SlideInRightAnimator, OvershootInLeftAnimator, OvershootInRightAnimator, SlideInUpAnimator, SlideInDownAnimator |
而且非常難得的是使用方法還很簡單, 需要幾個(gè)步驟
- 在Module的build.gradle中寫入
- 在Project的build.gradle中寫入
具體使用部分只要用動(dòng)畫類名替換之前默認(rèn)的動(dòng)畫類名即可. 例如:
rvTest.setAdapter(mAdapter); rvTest.setItemAnimator(new SlideInLeftAnimator()); 復(fù)制代碼好了, 接下來看幾個(gè)效果圖吧:
最后
喜歡記得點(diǎn)贊哦, 有意見或者建議評(píng)論區(qū)見, 暗中關(guān)注我也是可以的.
總結(jié)
以上是生活随笔為你收集整理的界面无小事(八):RecyclerView增删item的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: @scheduled 每30s 执行一次
- 下一篇: 远程连接spark_spark内部原理篇