RecyclerView
一种可以替换掉listview gridview 瀑布流等控件的新视图控件,控制视图回收和复用 ==优化内存可以替换listview
与listview的不同之处是:listview缓存convertview不同的是,Recyclerview缓存的是viewholder.
提供了一种插拔式的体验,高度的解耦,异常的灵活,通过设置它提供的不同LayoutManager,ItemDecoration , ItemAnimator实现想要的效果
1、RecyclerView.Adapter 适配器
2、RecyclerView.ItemDecoration 每个item附加的子视图,可用来绘制Divider,设置padding等
3、RecyclerView.ItemAnimator 负责添加、删除数据时的动画效果
4、RecyclerView.ViewHolder 缓存的对象
5、RecyclerView.LayoutManager 布局器,负责Item视图的布局

具体使用1、activity:

	private Activity activity;
private List<PicData> mpicDatas;
private MyAdapter adapter; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_recycleview);
activity = this; // 获取recycleView 设置布局管理器 设置items 分割线 设置 item 动画
RecyclerView my_recycleview = (RecyclerView) this
.findViewById(R.id.my_recycleview);
my_recycleview.setLayoutManager(new LinearLayoutManager(
getApplicationContext()));
my_recycleview.setItemAnimator(new DefaultItemAnimator());// 设置默认的动画
mpicDatas = Tool.getData();
adapter = new MyAdapter(mpicDatas);
adapter.setOnMyItemClickListener(new OnMyItemClickListener() { @Override
public void OnItemClick(View view, int position) {
Toast.makeText(activity, "Click" + mpicDatas.get(position),
Toast.LENGTH_SHORT).show();
adapter.removeData(position);
} @Override
public void OnItemLongClick(View view, int position) {
Toast.makeText(activity, "LongClick" + mpicDatas.get(position),
Toast.LENGTH_SHORT).show();
adapter.addData(position, mpicDatas.get(position));
}
});
my_recycleview.setAdapter(adapter);
// 自定义动画有问题
// my_recycleview.setItemAnimator(new MyItemAnimator());
}

  2、适配器 要处理点击事件和对应的视图处理:

// 提供 个数 和viewholder 已经绑定数据 onBindViewHolder
// 触发事件 和动画效果需要自己灵活处理
public class MyAdapter extends RecyclerView.Adapter<ViewHolder> {
List<PicData> mpicdatas;
private OnMyItemClickListener mOnItemClickListener;
public MyAdapter() {
}
public MyAdapter(List<PicData> mpicdatas) {
this.mpicdatas = mpicdatas;
}
public MyAdapter(List<PicData> mpicdatas,
OnMyItemClickListener mOnItemClickListener) {
this.mpicdatas = mpicdatas;
this.mOnItemClickListener = mOnItemClickListener;
} // 移除数据
public void removeData(int po) {
if(po>mpicdatas.size()-1){
return;
}
mpicdatas.remove(po);
notifyItemRemoved(po);
} // 指定位置添加数据
public void addData(int po, PicData mPicData) { if(po>mpicdatas.size()){
po=mpicdatas.size();
}
if(po<0){
po=0;
}
mpicdatas.add(po, mPicData);
notifyItemInserted(po);
} // 获取对象个数
@Override
public int getItemCount() {
return mpicdatas.size();
} // 具体用于绑定对应数据
@Override
public void onBindViewHolder(ViewHolder mViewHolder1, int arg1) {
final MyViewHolder mViewHolder = (MyViewHolder) mViewHolder1;
PicData mPicData = mpicdatas.get(arg1);
// mViewHolder.im.setBackground(background)
mViewHolder.tv_des.setText(mPicData.getDes());
mViewHolder.tv_name.setText(mPicData.getName());
// 设置点击事件
if (mOnItemClickListener != null) {
// 判断是否设置过点击事件 如果设置过 不再设置 防止重复创建 增加内存开销
if (!mViewHolder.itemView.hasOnClickListeners()) {
mViewHolder.itemView
.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
int po = mViewHolder.getPosition();
mOnItemClickListener.OnItemClick(v, po);
}
}); mViewHolder.itemView
.setOnLongClickListener(new OnLongClickListener() {
@Override
public boolean onLongClick(View v) {
int po = mViewHolder.getPosition();
mOnItemClickListener.OnItemLongClick(v, po);
return true;
}
});
}
}
} // 创建一个可返回的holder 用于回收和复用
@Override
public MyViewHolder onCreateViewHolder(ViewGroup parent, int arg1) {
MyViewHolder holder = new MyViewHolder(LayoutInflater.from(
RecycleviewActivity.this).inflate(
R.layout.activity_recycleview_item, parent, false));
return holder;
} // viewholder 静态内部类
class MyViewHolder extends ViewHolder {
private TextView tv_name;
private TextView tv_des;
private ImageView im; public MyViewHolder(View view) {
super(view);
tv_name = (TextView) view.findViewById(R.id.tv_title);
tv_des = (TextView) view.findViewById(R.id.tv_des);
im = (ImageView) view.findViewById(R.id.im_holder);
}
} // 设置点击事件
public void setOnMyItemClickListener(
OnMyItemClickListener mOnItemClickListener) {
this.mOnItemClickListener = mOnItemClickListener;
} }

  3、点击事件的接口

import android.view.View;

public interface OnMyItemClickListener {
public void OnItemClick(View view, int position); public void OnItemLongClick(View view, int position);
}

  4、model

public class PicData {
private String name;
private String des;
private String path; public PicData() {
} public PicData(String name, String des, String path) {
this.des = des;
this.name = name;
this.path = path;
} public String getName() {
return name;
} public void setName(String name) {
this.name = name;
} public String getDes() {
return des;
} public void setDes(String des) {
this.des = des;
} public String getPath() {
return path;
} public void setPath(String path) {
this.path = path;
} }

  5、工具

public class Tool {

	/**
* 获取对应的测试数据
* @return
*/
public static List<PicData> getData(){
String image[]={
"http://imgsrc.baidu.com/forum/w%3D580/sign=f786dbba8744ebf86d716437e9f8d736/9fe5546034a85edf11571c9a49540923df547580.jpg",
"http://upload.wendu.cn/2016/0225/thumb_300_0_1456366681530.jpg",
"http://upload.wendu.cn/2016/0225/thumb_300_0_1456386396842.jpg",
"http://upload.wendu.cn/2016/0225/thumb_300_0_1456386399211.jpg",
"http://upload.wendu.cn/2016/0217/thumb_300_0_1455684747338.jpg",
"http://upload.wendu.cn/2016/0203/thumb_300_0_1454499202633.png",
"http://upload.wendu.cn/2016/0122/thumb_300_0_1453463650114.jpg",
"http://upload.wendu.cn/2016/0123/thumb_213_160_1453513340130.png",
"http://upload.wendu.cn/2016/0129/thumb_300_0_1454030278472.jpg"
}; List<PicData> mlist=new ArrayList<PicData>();
for(int i=0;i<image.length;i++){
mlist.add(new PicData("第几张"+i, "测试第几张图片 测试数据"+i, image[i]));
}
return mlist; } }

  6、布局

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".MainActivity" > <android.support.v7.widget.RecyclerView
android:id="@+id/my_recycleview"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
/> </RelativeLayout>

  

Android RecyclerView使用(一)的更多相关文章

  1. Android RecyclerView 实现支付宝首页效果

    Android RecyclerView 实现支付宝首页效果 [TOC] 虽然我本人不喜欢支付宝的,但是这个网格本身其实还是不错的,项目更新中更改了一个布局为网格模式,类似支付宝.(估计是产品抄袭的= ...

  2. Android RecyclerView的基本使用

    Android RecyclerView 在去年的Google I/O大会上就推出来了,以前经常使用的ListView 继承的是AbsListView,而RecyclerView则直接继承 ViewG ...

  3. Android RecyclerView单击、长按事件:基于OnItemTouchListener +GestureDetector标准实现(二),封装抽取成通用工具类

     Android RecyclerView单击.长按事件:基于OnItemTouchListener +GestureDetector标准实现(二),封装抽取成通用工具类 我写的附录文章2,介绍了 ...

  4. Android RecyclerView单击、长按事件标准实现:基于OnItemTouchListener + GestureDetector

     Android RecyclerView单击.长按事件:基于OnItemTouchListener + GestureDetector标准实现 Android RecyclerView虽然拥有L ...

  5. Android RecyclerView添加Header头部

     Android RecyclerView添加Header头部 Android RecyclerView不像以前的ListView那样直接添加头部,如果要给RecyclerView增加头部,则需要 ...

  6. Android RecyclerView(瀑布流)水平/垂直方向分割线

     Android RecyclerView(瀑布流)水平/垂直方向分割线 Android RecyclerView不像过去的ListView那样随意的设置水平方向的分割线,如果要实现Recycle ...

  7. 极简的Android RecyclerView Adapter(使用DataBinding)

    阅读本篇文章需要读者对Android Databinding和RecyclerView有一定的了解. 简介 我们知道,DataBinding的核心理念是数据驱动.数据驱动驱动的目标就是View,使用D ...

  8. 浅谈Android RecyclerView

    Android RecyclerView 是Android5.0推出来的,导入support-v7包即可使用. 个人体验来说,RecyclerView绝对是一款功能强大的控件. 首先总结下Recycl ...

  9. [Android]RecyclerView的简单演示样例

    去年google的IO上就展示了一个新的ListView.它就是RecyclerView. 下面是官方的说明,我英语能力有限,只是我大概这么理解:RecyclerView会比ListView更具有拓展 ...

  10. (转载) Android RecyclerView 使用完全解析 体验艺术般的控件

    Android RecyclerView 使用完全解析 体验艺术般的控件 标签: Recyclerviewpager瀑布流 2015-04-16 09:07 721474人阅读 评论(458) 收藏  ...

随机推荐

  1. 配置并学习微信JS-SDK(2)—图片接口

    测试地址:http://www.qq210.com/shoutu/android 检查图像接口 选择本地或拍照的图片 上传选择的图片 预览上传的图片 //1.检查图像接口 document.query ...

  2. getimagesize函数介绍

    getimagesize(); 返回结果说明 索引 0 给出的是图像宽度的像素值 索引 1 给出的是图像高度的像素值 索引 2 给出的是图像的类型,返回的是数字,其中1 = GIF,2 = JPG,3 ...

  3. Python【第一篇】基础介绍

    一.本节主要内容 Python介绍 发展史 Python 2 or 3? 安装 Hello World程序 变量 用户输入 模块初识 .pyc文件 数据类型初识 数据运算 表达式if ...else语 ...

  4. WPF之 XAML集合项简单演示

    我们直接通过xaml文件演示一个简单的xaml集合项: <Window x:Class="WPF_XAML集合项.MainWindow" xmlns="http:/ ...

  5. Ipv6_Only-b

    网上好多关于ipv6的资料,说半天ipv6是什么,怎么建立测试环境,,,可是没有看到具体的操作和解决的方案,这里,为大家提供一种方案,希望给大家带来帮助吧. 总的来说有三个方面需要进行检查和修改: 1 ...

  6. 关于64位Win7/Win 8 下怎么学习汇编语言

    我看有许多同学用Win 7/Win 8 学习汇编,现在好多人的内存升级了都用64位系统了,但是64位W7没有自带的DEBUG和MASM. 1.首先下载DOSBOX,(下面附带地址)它的作用就是让你在6 ...

  7. http server v0.1_http_webapp.c

    #include <stdio.h> #include <stdlib.h> #include <string.h> #include <unistd.h&g ...

  8. bzoj 1051: [HAOI2006]受欢迎的牛 tarjan缩点

    1051: [HAOI2006]受欢迎的牛 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 2092  Solved: 1096[Submit][Sta ...

  9. Phonegap 3.0 拍照 出错的说明

    在官方3.0 提供的摄像机操作例子是不成功的,因为该例子没有说明摄像机操作需要添加Plugin. 添加插件方法(安装cordova3.0时必须使用官方命令行方式,通过nodejs安装,且装上了git) ...

  10. ireport常见问题

    $V{PAGE_NUMBER} 表示当前是第几页 ,在text field 的 选项evaluation time选report是共几页,now表是当前页.页码可在ireport里直接设置. &quo ...