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


猜你喜欢

转载自blog.csdn.net/qq_28852011/article/details/80263050