项目中经常遇到给RecyclerView左右设置padding、layout_margin,有时候会导致item不能滑动到边缘,设置ItemDecoration呢,又容易第一个item和最后一个item的边缘和item之间的间距不一样
所以就初步使用下面的方法,可以自己设置每个item的padding值,不需要再在RecyclerView里设置啦,代码没有封装,只有初步使用,经常使用的话,建议提取出来
RecyclerView.ItemDecoration itemDecoration = new RecyclerView.ItemDecoration() {
@Override
public void onDraw(Canvas c, RecyclerView parent, RecyclerView.State state) {
super.onDraw(c, parent, state);
}
@Override
public void getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) {
super.getItemOffsets(outRect, view, parent, state);
int childAdapterPosition = parent.getChildAdapterPosition(view);
int lastCount = parent.getAdapter().getItemCount() - 1;
if (childAdapterPosition == 0) {
//第一个item 设置paddingRight 8 dp
outRect.set(0, 0, DimenUtil.dp2px(getContext(), 8), 0);
} else if (childAdapterPosition == lastCount) {
//最后一个item 设置paddingLeft 8 dp
outRect.set(DimenUtil.dp2px(getContext(), 8), 0, 0, 0);
} else {
outRect.set(DimenUtil.dp2px(getContext(), 8), 0, DimenUtil.dp2px(getContext(), 8), 0);
}
}
};
rectclerview.addItemDecoration(itemDecoration);
提供一下DimenUtil.dp2px方法:
public static int dp2px(Context context, float dp) {
final float scale = context.getResources().getDisplayMetrics().density;
return (int) (dp * scale + 0.5);
}
本文介绍了一种在RecyclerView中为每个Item动态设置Padding的方法,解决了Item滑动不到边缘及间距不一致的问题。通过自定义ItemDecoration,根据Item位置调整Padding大小,确保了UI的一致性和用户体验。

被折叠的 条评论
为什么被折叠?



