RecyclerView在SystemUI中使用的经典案例

话说RecyclerView比较强大,而且在我负责的模块SystemUI中也使用到了这个控件所以就结合源码学习一下,一举两得!

首先先看一下SystemUI中RecyclerView的使用效果,如图:


这个界面的整体布局是在自定义控件QSCustomizer.java中的构造方法中加载的

LayoutInflater.from(getContext()).inflate(R.layout.qs_customize_panel_content, this);

后来进行了一系列的操作

mRecyclerView = (RecyclerView) findViewById(android.R.id.list);
mTileAdapter = new TileAdapter(getContext());
mRecyclerView.setAdapter(mTileAdapter);
mTileAdapter.getItemTouchHelper().attachToRecyclerView(mRecyclerView);
GridLayoutManager layout = new GridLayoutManager(getContext(), 4);
layout.setSpanSizeLookup(mTileAdapter.getSizeLookup());
mRecyclerView.setLayoutManager(layout);
mRecyclerView.addItemDecoration(mTileAdapter.getItemDecoration());
DefaultItemAnimator animator = new DefaultItemAnimator();
animator.setMoveDuration(TileAdapter.MOVE_DURATION);
mRecyclerView.setItemAnimator(animator);

①实现item的拖拽效果,CallBack是在adapter中写的

   可参考文档https://blog.csdn.net/a553181867/article/details/54799391

②控制显示方式为GridLayout效果

③动态设置item所占的每行的比重,中间的提示字符串就是通过这个方式实现的占比为4

④自定义item之间的间隔(可定制)

⑤设置动画效果

拖动动画和item拖动之间的替换是通过Adapter中的内部类实现的,具体拖动细节就不做研讨了。

private final ItemTouchHelper.Callback mCallbacks = new ItemTouchHelper.Callback() {
可参考文档: https://blog.csdn.net/a553181867/article/details/54799391


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值