上篇博客讲了如何导入RecyclerView 。

本章将告诉小伙伴们怎么使用RecyclerView :

第一步:在布局中使用RecyclerView并且绑定控件;

第二步:自定义Adapter;(继承自RecyclerView.Adapter)

第三步:使用LinerLayoutManager控制显示样式;

(二、三顺序可调)

第一步:

在布局中使用:

 <android.support.v7.widget.RecyclerView
android:id="@+id/recycleview"
android:layout_width="match_parent"
android:layout_height="match_parent"> </android.support.v7.widget.RecyclerView>

控件的绑定很简单就不说了。

下面要编写需要展示的item的样式,为了简单我们就显示一个TextView,别的内容大家可以自己定制:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="70dp"
android:background="#ff00ff"
android:layout_margin="2dp"
android:orientation="vertical"> <TextView
android:id="@+id/recycle_tv"
android:textSize="20dp"
android:gravity="center"
android:layout_width="72dp"
android:layout_height="match_parent" />
</LinearLayout>

布局的内容很也简单,唯一需要注意的是因为是为item布局所以高度千万不能设置成match_parent,一定要固定一个高度。

创建一些文字内容填充item(模拟从网络取来的数据)

 private void initdata() {
mData = new ArrayList<String>();
for (int i = 0; i < 43; i++) {
mData.add("item" + i);
Log.i(TAG, "initdata: item" + i);
}
}

mData是数据源(在前面定义过了)。

绑定控件并控制RecyclerView的显示效果:

private void initview() {

        mRecycleView = (RecyclerView) findViewById(R.id.recycleview);

        myAdapter = new MyAdapter(this, mData);
mRecycleView.setAdapter(myAdapter);//设置适配器 //设置布局管理器 , 将布局设置成纵向
LinearLayoutManager linerLayoutManager = new LinearLayoutManager(this, LinearLayoutManager.VERTICAL, false);
mRecycleView.setLayoutManager(linerLayoutManager); //设置分隔线
//mRecycleView.addItemDecoration(new DividerItemDecoration(this , DividerItemDecoration.VERTICAL_LIST)); //设置增加或删除条目动画
mRecycleView.setItemAnimator(new DefaultItemAnimator()); }

细心的你一定发现了

MyAdapter这个方法根本没定义,没错这个就是我们需要自定义的适配器。

mRecycleView.setLayoutManager()

这个方法用来控制RecyclerView显示的样式,参数就是可选的样式:

参数是: 

new GridLayoutManager(this, 3)

显示成一个拥有三列的GridView(效果还不赖是吧  ;-)  )

  

参数是:

new LinearLayoutManager(this)

显示成一个垂直列表(ListView样式)

参数是:

new StaggeredGridLayoutManager(5, StaggeredGridLayoutManager.HORIZONTAL)

横向显示((⊙o⊙)… 跟我想的有点不一样,应该是哪里出问题了。。。)

Adapter的编写:

package com.guwei.a02recycleview;

import android.content.Context;
import android.support.v7.widget.RecyclerView;
import android.util.Log;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView; import java.util.List; /**
* Created by guwei on 16-7-28.
*/
public class MyAdapter extends RecyclerView.Adapter<MyViewHolder>{
private LayoutInflater inflater;
private Context mContext;
private List<String> mDatas; //创建构造参数
public MyAdapter(Context context , List<String> datas){
this.mContext = context;
this.mDatas = datas;
inflater = LayoutInflater.from(context);
} //创建ViewHolder
@Override
public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View view = inflater.inflate(R.layout.recycleview_item , parent , false);
MyViewHolder viewHolder = new MyViewHolder(view);
return viewHolder;
} //绑定ViewHolder
@Override
public void onBindViewHolder(MyViewHolder holder, int position) {
//为textview 赋值
holder.tv.setText(mDatas.get(position));
} @Override
public int getItemCount() {
//Log.i("TAG", "mDatas "+mDatas); return mDatas.size(); } //新增item
public void addData(int pos){
mDatas.add("新增");
notifyItemInserted(pos);
} //移除item
public void deleateData(int pos){
mDatas.remove(pos);
notifyItemRemoved(pos);
}
}
class MyViewHolder extends RecyclerView.ViewHolder{ TextView tv; public MyViewHolder(View itemView) {
super(itemView); tv = (TextView) itemView.findViewById(R.id.recycle_tv);
tv.setTextSize(20); }
}

Adapter的编写主要是要继承自 RecyclerView.Adapter<holder>

看到啦?原来继承BaseAdapter的时候还是建议使用ViewHolder的方法的。现在已经直接集成在RecyclerView.Adapter<holder>中了强制使用(这也是为你好!因为这样更省资源,不需要每次都使用find方法。这个不是本次重点)。

然后重写三个方法:

  - onCreateViewHolder() //创建ViewHolder 该方法下指定我们自己定义的item 并绑定

  - onBindViewHolder()    //绑定ViewHolder 该方法为绑定的自定义的item中的组件进行设置(比如我们例子中的TextView , 使用set方法设置显示的内容)

  - getItemCount()    //返回数据的大小

 //创建ViewHolder
@Override
public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
View view = inflater.inflate(R.layout.recycleview_item , parent , false);
MyViewHolder viewHolder = new MyViewHolder(view);
return viewHolder;
} //绑定ViewHolder
@Override
public void onBindViewHolder(MyViewHolder holder, int position) {
//为textview 赋值
holder.tv.setText(mDatas.get(position));
} @Override
public int getItemCount() {
//Log.i("TAG", "mDatas "+mDatas); return mDatas.size(); }

前面说了ViewHolder是强制使用的,用法跟原来一样:

class MyViewHolder extends RecyclerView.ViewHolder{

    TextView tv;

    public MyViewHolder(View itemView) {
super(itemView); tv = (TextView) itemView.findViewById(R.id.recycle_tv);
tv.setTextSize(20); }
}

RecyclerView还提供了一个删除item的动画,我们可以在adapter中实现该方法供调用:

 //新增item
public void addData(int pos){
mDatas.add("新增");
notifyItemInserted(pos);
} //移除item
public void deleateData(int pos){
mDatas.remove(pos);
notifyItemRemoved(pos);
}

调用的方法:

移除:

myAdapter.deleateData(1);

新增:

 myAdapter.addData(1);

参数为postion

MainActivity.java :

package com.guwei.a02recycleview;

import android.os.Bundle;
import android.support.design.widget.FloatingActionButton;
import android.support.design.widget.Snackbar;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.DefaultItemAnimator;
import android.support.v7.widget.GridLayoutManager;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;
import android.support.v7.widget.StaggeredGridLayoutManager;
import android.support.v7.widget.Toolbar;
import android.util.Log;
import android.view.View;
import android.view.Menu;
import android.view.MenuItem; import java.util.ArrayList;
import java.util.List; public class MainActivity extends AppCompatActivity { public String TAG = "RECYCLE";
private RecyclerView mRecycleView;
private List<String> mData;
private MyAdapter myAdapter; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); initdata();
initview();
toolbar();
} private void initdata() {
mData = new ArrayList<String>();
for (int i = 0; i < 43; i++) {
mData.add("item" + i);
Log.i(TAG, "initdata: item" + i);
}
} private void initview() { mRecycleView = (RecyclerView) findViewById(R.id.recycleview); myAdapter = new MyAdapter(this, mData);
mRecycleView.setAdapter(myAdapter);//设置适配器 //设置布局管理器 , 将布局设置成纵向
LinearLayoutManager linerLayoutManager = new LinearLayoutManager(this, LinearLayoutManager.VERTICAL, false);
mRecycleView.setLayoutManager(linerLayoutManager); //设置分隔线
//mRecycleView.addItemDecoration(new DividerItemDecoration(this , DividerItemDecoration.VERTICAL_LIST)); //设置增加或删除条目动画
mRecycleView.setItemAnimator(new DefaultItemAnimator()); } private void toolbar() { Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
setSupportActionBar(toolbar); FloatingActionButton fab = (FloatingActionButton) findViewById(R.id.fab);
fab.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View view) {
myAdapter.addData(1);
}
});
} @Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.menu_main, menu);
return true;
} @Override
public boolean onOptionsItemSelected(MenuItem item) {
// Handle action bar item clicks here. The action bar will
// automatically handle clicks on the Home/Up button, so long
// as you specify a parent activity in AndroidManifest.xml.
int id = item.getItemId(); switch (id) {
case R.id.action_gridview:
/**
* GridLayoutManager(xx1 , xx2);
* 参数1: content
* 参数2: 列数
* **/
mRecycleView.setLayoutManager(new GridLayoutManager(this, 3));
break;
case R.id.action_listview:
/**
* 默认样式
*
* 垂直列表
* **/
mRecycleView.setLayoutManager(new LinearLayoutManager(this));
break;
/**
*水平显示
*
* 参数1:列数
* 参数2:水平显示
* **/
case R.id.action_settings:
mRecycleView.setLayoutManager(new StaggeredGridLayoutManager(5,
StaggeredGridLayoutManager.HORIZONTAL));
break;
}
return super.onOptionsItemSelected(item);
}
}

后面还有监听事件的编写

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

  1. Android用RecyclerView实现的二维Excel效果组件

    excelPanel 二维RecyclerView.不仅可以加载历史数据,而且可以加载未来的数据.   包括在您的项目中 excelPanel 二维RecyclerView.不仅可以加载历史数据,而且 ...

  2. android studio中使用recyclerview小白篇(二)

    前面一个说了怎么把这个包引用进来,这一节说怎么做一个简单的例子出来,我也是照着别人的例子写的,然后慢慢改就行了,做好的效果如下图 1.在我们的activity_main中把recyclerview填加 ...

  3. RecyclerView解密篇(三)

    在上一篇(RecyclerView使用详解(二))文章中介绍了RecyclerView的多Item布局实现,接下来要来讲讲RecyclerView的Cursor实现,相较于之前的实现,Cursor有更 ...

  4. Android之RecyclerView(一)

    概述 RecyclerView 是一个 ViewGroup,它用于渲染任何基于适配器的 View.它被官方定义为 ListView 和 GridView 的取代者,是在 Support V7 包中引入 ...

  5. Android RecyclerView使用详解(三)

    在上一篇(RecyclerView使用详解(二))文章中介绍了RecyclerView的多Item布局实现,接下来要来讲讲RecyclerView的Cursor实现,相较于之前的实现,Cursor有更 ...

  6. RecyclerView使用技巧(item动画及嵌套高度适配解决方案)

    原文地址 · Frank-Zhu  http://frank-zhu.github.io/android/2015/02/26/android-recyclerview-part-3/?utm_sou ...

  7. Android开源项目库汇总

    最近做了一个Android开源项目库汇总,里面集合了OpenDigg 上的优质的Android开源项目库,方便移动开发人员便捷的找到自己需要的项目工具等,感兴趣的可以到GitHub上给个star. 抽 ...

  8. GitHub上受欢迎的Android UI Library

    GitHub上受欢迎的Android UI Library 内容 抽屉菜单 ListView WebView SwitchButton 按钮 点赞按钮 进度条 TabLayout 图标 下拉刷新 Vi ...

  9. Android UI相关开源项目库汇总

    最近做了一个Android UI相关开源项目库汇总,里面集合了OpenDigg 上的优质的Android开源项目库,方便移动开发人员便捷的找到自己需要的项目工具等,感兴趣的可以到GitHub上给个st ...

  10. 最新最全的 Android 开源项目合集

    原文链接:https://github.com/opendigg/awesome-github-android-ui 在 Github 上做了一个很新的 Android 开发相关开源项目汇总,涉及到 ...

随机推荐

  1. Emacs学习心得之 LaTeX编辑

    目录 1. 前言 2. texlive的安装 3. AUCTEX的安装和配置 4. RefTEX的安装和配置 一.前言 本篇博文记录了Emacs下LaTeX编辑环境的搭建,参考一下文章: http:/ ...

  2. 三种POST和GET的提交方式

    向服务器提交数据有两种方式,post和get.两者的区别主要有三点,安全性.长度限制.数据结构.其中get请求安全性相比较而言较差,数据长度受浏览器地址栏限制,没有方法体.两种都是较为重要的数据提交方 ...

  3. 【Swift 2.1】共享文件操作小结(iOS 8 +)

    前言 适用于 iOS 8 + 本地共享文件列表 声明 欢迎转载,但请保留文章原始出处:) 博客园:http://www.cnblogs.com 农民伯伯: http://over140.cnblogs ...

  4. iOS可执行文件瘦身方法

    缩减iOS安装包大小是很多中大型APP都要做的事,一般首先会对资源文件下手,压缩图片/音频,去除不必要的资源.这些资源优化做完后,我们还可以尝试对可执行文件进行瘦身,项目越大,可执行文件占用的体积越大 ...

  5. SQL SERVER中关于OR会导致索引扫描或全表扫描的浅析

    在SQL SERVER的查询语句中使用OR是否会导致不走索引查找(Index Seek)或索引失效(堆表走全表扫描 (Table Scan).聚集索引表走聚集索引扫描(Clustered Index ...

  6. 使用Java实现简单串口通信

    最近一门课要求编写一个上位机串口通信工具,我基于Java编写了一个带有图形界面的简单串口通信工具,下面详述一下过程,供大家参考 ^_^ 一: 首先,你需要下载一个额外的支持Java串口通信操作的jar ...

  7. nodejs处理图片、CSS、JS链接

    接触Nodejs不深,看到页面上每一个链接都要写一个handler,像在页面显示图片,或者调用外部CSS.JS文件,每个链接都要写一个handler,觉得太麻烦,是否可以写个程序出来,能够自动识别图片 ...

  8. Xamarin.Android VSTS 持续集成

    这些天做了一个基于 VSTS 的 Xamarin.Android的持续集成,这里分享下 Build Agent 环境需求 DotNetFramework msbuild visualstudio An ...

  9. 【Windows编程】系列第十一篇:多文档界面框架

    前面我们所举的例子中都是单文档界面框架,也就是说这个窗口里面的客户区就是一个文档界面,可以编写程序在里面输入或者绘制文本和图形输出,但是不能有出现多个文档的情况.比如下面的UltraEdit就是一个典 ...

  10. 跨云应用部署第一步:使用IPSEC VPN连接AWS中国版和Windows Azure中国版

    随着公有云的普及,越来越多的客户将关键应用迁移到云端.但是事实证明,没有哪家云服务提供商可以提供100%的SLA,无论是例行维护还是意外中断服务,对于客户的关键应用而言,都会受到不同程度的影响.此外, ...