ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
***** **RecycleView** # Material Design新控件 Material Design(材料设计)是Google在2014年I/O大会上发布的一种新的设计规范,最开始只支持5.0及其以上的设备,随后不久Google就退出了其兼容库Android Design Support Library,兼容至2.1.使用material design新控件,android应用的整体美观提升很大程度 * DrawerLayout * TabLayout * RecyclerView.........等 # RecycleView 1.RecyclerView是什么? RecylerView是support-v7包中的新组件,是一个强大的滑动组件,与经典的ListView相比,同样拥有item回收复用的功能,这一点从它的名字recylerview即回收view也可以看出。看到这也许有人会问,不是已经有ListView了吗,为什么还要RecylerView呢?这就牵扯到第二个问题了。 2.RecyclerView的优点是什么? 根据官方的介绍RecylerView是ListView的升级版,既然如此那RecylerView必然有它的优点,现就RecylerView相对于ListView的优点罗列如下: * RecylerView封装了viewholder的回收复用,也就是说RecylerView标准化了ViewHolder,编写Adapter面向的是ViewHolder而不再是View了,复用的 逻辑被封装了,写起来更加简单。 * 提供了一种插拔式的体验,高度的解耦,异常的灵活,针对一个Item的显示RecylerView专门抽取出了相应的类,来控制Item的显示,使其的扩展性非常强。例如:你想控制横向或者纵向滑动列表效果可以通过LinearLayoutManager这个类来进行控制(与GridView效果对应的是GridLayoutManager,与瀑布流对应的还有StaggeredGridLayoutManager等),也就是说RecylerView不再拘泥于ListView的线性展示方式,它也可以实现GridView的效果等多种效果。你想控制Item的分隔线,可以通过继承RecylerView的ItemDecoration这个类,然后针对自己的业务需求去抒写代码。 非常强大,可以展示listView和GridView,并且还能横向展示(HorizontalScrollview) * 可以控制Item增删的动画,可以通过ItemAnimator这个类进行控制,当然针对增删的动画,RecylerView有其自己默认的实现。 3.实现效果特点及使用 1.添加依赖:RecyclerView 抽取一个跳转页面的方法enterActivity(Context context,Class clazz) studio中使用快捷键将点击事件创建到activity 2.效果 * 单行,多行,横向排列显示(单横,多横) 此时只需要更改布局管理者对象即可,然后调用一下刷新的方法 recyclerView的适配器继承的时候需要传入关联的holder,多条目的时候不需要,但是要在用到的位置向下转型....分块的,面向holder去写代码 * recyclerView.setLayoutManager(new LinearLayoutManager(this)); * recyclerView.setLayoutManager(new GridLayoutManager(this,3)); * recyclerView.setLayoutManager(new LinearLayoutManager(this,RecyclerView.HORIZONTAL,false)); * recyclerView.setLayoutManager(new GridLayoutManager(this,3,RecyclerView.HORIZONTAL,false));//false表示不反转...可以进行反转显示 * 瀑布流效果 recyclerView.setLayoutManager(new StaggeredGridLayoutManager(3,RecyclerView.VERTICAL)); * ViewGroup.LayoutParams layoutParams = holder.text_01.getLayoutParams(); * layoutParams.height = heightList.get(position); * holder.text_01.setLayoutParams(layoutParams); * holder.text_01.setBackgroundColor(Color.rgb((int) (100+ Math.random()*155),(int) (100+ Math.random()*155),(int) (100+ Math.random()*155))); * 条目点击事件 //设置点击事件...实际上是对适配器设置点击事件waterFallAdapter.setOnItemClickListner(new OnItemClickListner() { * 间隔线处理(添加下划线) * 多条目效果展示 * 条目动画 * 条目拖动删除效果 * 下拉刷新 * 3.使用:基本步骤----http://blog.csdn.net/lmj623565791/article/details/45059587 * 控制其显示的方式,请通过布局管理器LayoutManager mRecyclerView.setLayoutManager(layout); 抽象类,提供了三个实现类 * LinearLayoutManager 现行管理器,支持横向、纵向。 * GridLayoutManager 网格布局管理器 分割:一般如果仅仅是希望有空隙,还是去设置item的margin方便 * StaggeredGridLayoutManager 瀑布就式布局管理器 * 控制Item间的间隔线(可绘制),请通过ItemDecoration android:divider="#ffff0000",android:dividerHeight="10dp" * 发现没有分割线,RecyclerView并没有支持divider这样的属性 mRecyclerView.addItemDecoration(new DividerItemDecoration( getActivity(), DividerItemDecoration.HORIZONTAL));//默认的偏黑色分割线 RecyclerView.ItemDecoration解释:该类为抽象类 * onDraw方法先于drawChildren * onDrawOver在drawChildren之后,一般我们选择复写其中一个即可。 * getItemOffsets 可以通过outRect.set()为每个Item设置一定的偏移量,主要用于绘制Decorator DividerItemDecoration * private static final int[] ATTRS = new int[]{ android.R.attr.listDivider };通过读取系统主题中的 android.R.attr.listDivider作为Item间的分割线 * 获取到listDivider以后,该属性的值是个Drawable(mDivider = a.getDrawable(0);), * 在getItemOffsets中,outRect去设置了绘制的范围。onDraw中实现了真正的绘制 * * 自定义分割线 .setDrawable(getResources().getDrawable(R.mipmap.ic_launcher));通过这个方法可以使用一张图片作为分割线...就可以使用shape进行绘制了 * 还可以在主题线面设置listDivider属性值 <style name="AppTheme" parent="AppBaseTheme"> <item name="android:listDivider">@drawable/divider_bg</item> </style> * 控制Item增删的动画,请通过ItemAnimator mRecyclerView.setItemAnimator(new DefaultItemAnimator());//设置默认添加或者删除的动画效果 * 这里更新数据集不是用adapter.notifyDataSetChanged()而是 notifyItemInserted(position)与notifyItemRemoved(position),否则没有动画效果 * 只提供了一种动画,那么我们肯定可以去自定义各种nice的动画效果 https://github.com/gabrielemariotti/RecyclerViewItemAnimators * 控制点击、长按事件,请自己写 通过adapter中自己去提供回调 * mAdapter.setOnItemClickLitener(new OnItemClickLitener() public void onItemClick(View view, int position) public void onItemLongClick(View view, int position) * OnItemClickLitener接口里面的两个方法 为什么使用这么多步骤? * 从它类名上看,RecyclerView代表的意义是,我只管Recycler View,也就是说RecyclerView只管回收与复用View,其他的你可以自己去设置。可以看出其高度的解耦,给予你充分的定制自由(所以你才可以轻松的通过这个控件实现ListView,GirdView,瀑布流等效果)