您好,登錄后才能下訂單哦!
要為L(zhǎng)istView列表項(xiàng)添加自定義滑動(dòng)動(dòng)畫(huà),可以使用ListView的ItemAnimator類(lèi)。以下是一個(gè)示例代碼,演示如何實(shí)現(xiàn)列表項(xiàng)的自定義滑動(dòng)動(dòng)畫(huà):
public class CustomItemAnimator extends DefaultItemAnimator {
@Override
public boolean animateRemove(RecyclerView.ViewHolder holder) {
// 添加自定義的移除動(dòng)畫(huà)
ObjectAnimator anim = ObjectAnimator.ofFloat(holder.itemView, "translationX", 0, -holder.itemView.getWidth());
anim.setDuration(500);
anim.start();
return true;
}
@Override
public boolean animateAdd(RecyclerView.ViewHolder holder) {
// 添加自定義的添加動(dòng)畫(huà)
ObjectAnimator anim = ObjectAnimator.ofFloat(holder.itemView, "translationX", holder.itemView.getWidth(), 0);
anim.setDuration(500);
anim.start();
return true;
}
@Override
public boolean animateMove(RecyclerView.ViewHolder holder, int fromX, int fromY, int toX, int toY) {
// 添加自定義的移動(dòng)動(dòng)畫(huà)
ObjectAnimator animX = ObjectAnimator.ofFloat(holder.itemView, "translationX", fromX, toX);
ObjectAnimator animY = ObjectAnimator.ofFloat(holder.itemView, "translationY", fromY, toY);
AnimatorSet animSet = new AnimatorSet();
animSet.playTogether(animX, animY);
animSet.setDuration(500);
animSet.start();
return true;
}
}
然后在使用ListView時(shí),將這個(gè)自定義的ItemAnimator設(shè)置給ListView:
ListView listView = findViewById(R.id.listView);
CustomItemAnimator itemAnimator = new CustomItemAnimator();
listView.setItemAnimator(itemAnimator);
現(xiàn)在當(dāng)你在ListView中添加或移除列表項(xiàng)時(shí),就會(huì)觸發(fā)自定義的滑動(dòng)動(dòng)畫(huà)效果。你可以根據(jù)需要修改animateAdd、animateRemove和animateMove方法來(lái)實(shí)現(xiàn)不同的動(dòng)畫(huà)效果。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。