话说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