*****
**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,瀑布流等效果)
- 班规
- 第一单元 Git
- 1.1 Git简介
- 1.2 Git安装
- 1.3 版本控制
- 1.4 远程仓库
- 1.5 分支管理
- 1.6 Git命令总结
- 1.7 在Android Studio中使用Git
- 第一单元 作业
- 第二单元 项目立项
- 2.1 需求文档
- 2.2 原型图
- 2.3 接口文档
- 2.4 项目实现
- 2.5 制定开发计划
- 第二单元 作业
- 第三单元 MVP搭建项目框架
- 3.1 代码架构模式
- 3.2 普通方式写代码
- 3.3 使用MVC重构代码
- 3.4 使用MVP重构代码
- 3.5 使用接口提高代码通用性
- 3.6 内存泄漏
- 3.7 使用契约统一管理接口
- 第三单元 作业
- 第四单元 MVP架构优化
- 4.1 MVP基类封装与泛型应用
- 4.3 BaseActivity的封装
- 第五单元 Volley网络框架
- 5.1 Volley网络框架
- 第六单元 Glide实现图片异步加载
- 6.1 开始使用
- 6.2 占位符
- 6.3 Glide缓存
- 6.4 GlideGifVideo与色彩模式
- 第七单元 传统屏幕适配
- 7.1 相对布局
- 7.1 权重
- 7.3 .9Patch
- 7.4 dimens适配
- 7.5 国际化
- 7.6 shape实现自定义样式
- 7.7 自定义样式
- 7.8 沉浸式状态栏
- 第八单元 RecyclerView
- 8.1 RecycleView
- 第九单元 自定义View
- 第十单元 自定义View实战
- 第十一单元 自定义View进阶
- 第二十单元 属性动画
- 第十三单元 异常捕获机制
- 第十四单元 原生登录、注册模块
- 第十五单元 第三方登录、分享、统计
- 第十六单元 HTML5新特性
- 第十七单元 CSS3新特性
- 第十八单元 WebView与JS交互
- 第一周周考
- 第二周周考
- 第三周周考
- 月考