1. RecyclerView 是一个增强版的ListView,不仅可以实现和ListView同样的效果,还优化了ListView中存在的各种不足之处
  2.  
  3. ResyslerView 能够实现横向滚动,这是ListView所不能实现的
  4.  
  5. 目前官方更加推荐使用RecyclerView.
  6.  
  7. 1.实现垂直方向的滚动
  8.  
  9. dependencies 中添加库的引用
  10.  
  11. [html] view plain copy
  12.  
  13. dependencies {
  14. compile fileTree(dir: 'libs', include: ['*.jar'])
  15. testCompile 'junit:junit:4.12'
  16. compile 'com.android.support:appcompat-v7:24.2.0'
  17. compile 'com.android.support:recyclerview-v7:24.2.1'
  18. }
  19.  
  20. 添加布局文件:
  21.  
  22. [html] view plain copy
  23.  
  24. <?xml version="1.0" encoding="utf-8"?>
  25. <LinearLayout
  26. xmlns:android="http://schemas.android.com/apk/res/android"
  27. android:layout_width="match_parent"
  28. android:layout_height="match_parent">
  29.  
  30. <android.support.v7.widget.RecyclerView
  31. android:id="@+id/recycler_view"
  32. android:layout_width="match_parent"
  33. android:layout_height="match_parent">
  34. </android.support.v7.widget.RecyclerView>
  35. </LinearLayout>
  36.  
  37. 创建RecyclerView 适配器 BookBaseAdapter ,这个类继承 RecyclerView.Adapter 并将泛型指定为 BookBaseAdapter.ViewHolder
  38.  
  39. 其中ViewHolder是我们在 BookBaseAdapter 中定义的一个内部类:代码如下:
  40.  
  41. [html] view plain copy
  42.  
  43. public class BookBaseAdapter extends RecyclerView.Adapter<BookBaseAdapter.ViewHolder>{
  44.  
  45. private List<Book> mBookList;
  46.  
  47. static class ViewHolder extends RecyclerView.ViewHolder{
  48. ImageView bookImage;
  49. TextView bookname;
  50.  
  51. public ViewHolder(View view) {
  52. super(view);
  53. bookImage = (ImageView) view.findViewById(R.id.book_iamge);
  54. bookname = (TextView) view.findViewById(R.id.book_name);
  55. }
  56. }
  57.  
  58. public BookBaseAdapter(List<Book> mBookList) {
  59. this.mBookList = mBookList;
  60. }
  61.  
  62. [html] view plain copy
  63.  
  64. <span style="white-space:pre;"> </span>//加载item 的布局 创建ViewHolder实例
  65. @Override
  66. public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
  67. View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.book,parent,false);
  68. ViewHolder holder = new ViewHolder(view);
  69. return holder;
  70. }
  71.  
  72. [html] view plain copy
  73.  
  74. <span style="white-space:pre;"> </span>//对RecyclerView子项数据进行赋值
  75. @Override
  76. public void onBindViewHolder(ViewHolder holder, int position) {
  77. Book book = mBookList.get(position);
  78. holder.bookname.setText(book.getName());
  79. holder.bookImage.setImageResource(book.getImageId());
  80. }
  81.  
  82. [html] view plain copy
  83.  
  84. <span style="white-space:pre;"> </span>//返回子项个数
  85. @Override
  86. public int getItemCount() {
  87. return mBookList.size();
  88. }
  89. }
  90.  
  91. MainActivity调用:
  92. [html] view plain copy
  93.  
  94. public class MainActivity extends AppCompatActivity {
  95.  
  96. private List<Book> mlsit = new ArrayList<Book>();
  97.  
  98. @Override
  99. protected void onCreate(Bundle savedInstanceState) {
  100. super.onCreate(savedInstanceState);
  101. setContentView(R.layout.activity_main);
  102. //初始化List数据
  103. initBook();
  104. //初始化RecyclerView
  105. RecyclerView recyslerview = (RecyclerView) findViewById(R.id.recycler_view);
  106. //创建LinearLayoutManager 对象 这里使用 <span style="font-family:'Source Code Pro';">LinearLayoutManager 是线性布局的意思</span>
  107. LinearLayoutManager layoutmanager = new LinearLayoutManager(this);
  108. //设置RecyclerView 布局
  109. recyslerview.setLayoutManager(layoutmanager);
  110. //设置Adapter
  111. BookBaseAdapter adapter = new BookBaseAdapter(mlsit);
  112. recyslerview.setAdapter(adapter);
  113. }
  114.  
  115. private void initBook(){
  116. for (int i = 0; i < 10; i++) {
  117. Book book01 = new Book("Book"+i,R.drawable.icon01);
  118. mlsit.add(book01);
  119. Book book02 = new Book("Book"+i,R.drawable.icon02);
  120. mlsit.add(book02);
  121. Book book03 = new Book("Book"+i,R.drawable.icon03);
  122. mlsit.add(book03);
  123. }
  124. }
  125. }
  126.  
  127. main_layout布局:
  128. [html] view plain copy
  129.  
  130. <?xml version="1.0" encoding="utf-8"?>
  131. <LinearLayout
  132. xmlns:android="http://schemas.android.com/apk/res/android"
  133. android:layout_width="match_parent"
  134. android:layout_height="match_parent">
  135.  
  136. <android.support.v7.widget.RecyclerView
  137. android:id="@+id/recycler_view"
  138. android:layout_width="match_parent"
  139. android:layout_height="match_parent">
  140. </android.support.v7.widget.RecyclerView>
  141. </LinearLayout>
  142.  
  143. item布局:
  144. [html] view plain copy
  145.  
  146. <?xml version="1.0" encoding="utf-8"?>
  147. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  148. android:layout_width="match_parent"
  149. android:layout_height="wrap_content"
  150. android:orientation="horizontal">
  151.  
  152. <ImageView
  153. android:id="@+id/book_iamge"
  154. android:layout_width="wrap_content"
  155. android:layout_height="wrap_content"/>
  156.  
  157. <TextView
  158. android:id="@+id/book_name"
  159. android:layout_width="match_parent"
  160. android:layout_height="wrap_content"/>
  161.  
  162. </LinearLayout>
  163.  
  164. 此处省略Book对象的相关源码。如上就可以实现和ListView一样的效果。
  165.  
  166. 2.实现横向滚动
  167.  
  168. 对垂直布局中的代码做小修改:
  169.  
  170. onCreat方法中添加setOrientation()方法来设置布局的排列方向
  171.  
  172. [html] view plain copy
  173.  
  174. <span style="background-color:rgb(255,255,255);"> <span> </span>layoutmanager.setOrientation(LinearLayoutManager.HORIZONTAL);</span>
  175.  
  176. [html] view plain copy
  177.  
  178. @Override
  179. protected void onCreate(Bundle savedInstanceState) {
  180. super.onCreate(savedInstanceState);
  181. setContentView(R.layout.activity_main);
  182. //初始化List数据
  183. initBook();
  184. //初始化RecyclerView
  185. RecyclerView recyslerview = (RecyclerView) findViewById(R.id.recycler_view);
  186. //创建LinearLayoutManager 对象
  187. LinearLayoutManager layoutmanager = new LinearLayoutManager(this);
  188. layoutmanager.setOrientation(LinearLayoutManager.HORIZONTAL);
  189. //设置RecyclerView 布局
  190. recyslerview.setLayoutManager(layoutmanager);
  191. //设置Adapter
  192. BookBaseAdapter adapter = new BookBaseAdapter(mlsit);
  193. recyslerview.setAdapter(adapter);
  194. }
  195.  
  196. 修改一下item的布局:
  197.  
  198. [html] view plain copy
  199.  
  200. <?xml version="1.0" encoding="utf-8"?>
  201. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  202. android:layout_width="150dp"
  203. android:layout_height="wrap_content"
  204. android:orientation="vertical">
  205.  
  206. <ImageView
  207. android:id="@+id/book_iamge"
  208. android:layout_width="wrap_content"
  209. android:layout_height="wrap_content"
  210. android:layout_gravity="center_horizontal"/>
  211.  
  212. <TextView
  213. android:id="@+id/book_name"
  214. android:layout_width="match_parent"
  215. android:layout_height="wrap_content"
  216. android:layout_marginTop="10dp"
  217. android:layout_gravity="center_horizontal"/>
  218.  
  219. </LinearLayout>
  220.  
  221. 运行程序就可以发现我们实现了横向的滚动效果
  222.  
  223. 3.瀑布流布局
  224.  
  225. RecyclerView除了LinearLayoutManager 之外,还提供了GridlayoutManagerStaggeredGridlayoutManager这两种内置的布局排列方式
  226.  
  227. GridlayoutManager可以用于实现网格布局
  228.  
  229. StaggeredGridlayoutManager可以用于实现瀑布流布局,
  230.  
  231. 这里我们来实现一下炫酷的瀑布流布局:
  232.  
  233. 修改item.xml的布局
  234.  
  235. [html] view plain copy
  236.  
  237. <?xml version="1.0" encoding="utf-8"?>
  238. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  239. android:layout_width="match_parent"
  240. android:layout_height="wrap_content"
  241. android:layout_margin="5dp"
  242. android:orientation="vertical">
  243.  
  244. <ImageView
  245. android:id="@+id/book_iamge"
  246. android:layout_width="wrap_content"
  247. android:layout_height="wrap_content"
  248. android:layout_gravity="center_horizontal"/>
  249.  
  250. <TextView
  251. android:id="@+id/book_name"
  252. android:layout_width="wrap_content"
  253. android:layout_height="wrap_content"
  254. android:layout_marginTop="5dp"
  255. android:layout_gravity="left"/>
  256.  
  257. </LinearLayout>
  258.  
  259. onCreat方法:
  260.  
  261. [html] view plain copy
  262.  
  263. @Override
  264. protected void onCreate(Bundle savedInstanceState) {
  265. super.onCreate(savedInstanceState);
  266. setContentView(R.layout.activity_main);
  267. //初始化List数据
  268. initBook();
  269. //初始化RecyclerView
  270. RecyclerView recyslerview = (RecyclerView) findViewById(R.id.recycler_view);
  271. //创建LinearLayoutManager 对象
  272. /*
  273. * 第一个参数表示布局的列数
  274. * 第二个参数表示布局的方向,这里我们传入StaggeredGridLayoutManager.VERTICAL,表示布局纵向排列
  275. */
  276. StaggeredGridLayoutManager layoutmanager = new StaggeredGridLayoutManager(3,StaggeredGridLayoutManager.VERTICAL);
  277. //设置RecyclerView 布局
  278. recyslerview.setLayoutManager(layoutmanager);
  279. //设置Adapter
  280. BookBaseAdapter adapter = new BookBaseAdapter(mlsit);
  281. recyslerview.setAdapter(adapter);
  282. }
  283.  
  284. 仅仅修改一行代码,就可以成功的实现瀑布流的布局效果
  285.  
  286. 点击监听事件这里引用 http://blog.csdn.net/dmk877/article/details/50816933 的方法
  287.  
  288. RecyclerViewItem添加点击事件
  289.  
  290. Item的点击事件RecyclerView监听事件处理在ListView使用的时候,该控件给我们提供一个onItemClickListener监听器,这样当我们点击Item的时候,会回调相关的方法,以便我们方便处理Item点击事件。对于RecyclerView来讲,非常可惜的是,该控件没有给我们提供这样的内置监听器方法,不过我们可以进行改造实现,可以这样实现Item的点击事件的监听,在我们的adapter中增加这两个方法
  291. public interface OnItemClickListener{
  292. void onClick( int position);
  293. void onLongClick( int position);
  294. }
  295. public void setOnItemClickListener(OnItemClickListener onItemClickListener ){
  296. this. mOnItemClickListener=onItemClickListener;
  297. }
  298.  
  299. 然后onBindViewHolder方法要做如下更改
  300. [java] view plain copy
  301.  
  302. CODE上查看代码片派生到我的代码片
  303.  
  304. @Override
  305. public void onBindViewHolder(MyViewHolder holder, final int position) {
  306.  
  307. holder. tv.setText( mDatas.get(position));
  308.  
  309. if( mOnItemClickListener!= null){
  310. holder. itemView.setOnClickListener( new OnClickListener() {
  311.  
  312. @Override
  313. public void onClick(View v) {
  314. mOnItemClickListener.onClick(position);
  315. }
  316. });
  317.  
  318. holder. itemView.setOnLongClickListener( new OnLongClickListener() {
  319. @Override
  320. public boolean onLongClick(View v) {
  321. mOnItemClickListener.onLongClick(position);
  322. return false;
  323. }
  324. });
  325. }
  326. }<span style="color:#333333;">
  327. </span>
  328.  
  329. MainAcitivity中增加
  330. [java] view plain copy
  331.  
  332. CODE上查看代码片派生到我的代码片
  333.  
  334. recycleAdapter.setOnItemClickListener(new OnItemClickListener() {
  335.  
  336. @Override
  337. public void onLongClick(int position) {
  338. Toast.makeText(MainActivity.this,"onLongClick事件 您点击了第:"+position+"个Item",0).show();
  339. }
  340.  
  341. @Override
  342. public void onClick(int position) {
  343. Toast.makeText(MainActivity.this,"onClick事件 您点击了第:"+position+"个Item",0).show();
  344. }
  345. });
  346.  
  347. 参考文档:http://blog.csdn.net/dmk877/article/details/50816933

RecyclerView的基本用法的更多相关文章

  1. Android控件RecyclerView的基本用法

    Android控件RecyclerView的基本用法 转 https://www.jianshu.com/p/e71a4b73098f   github: https://github.com/Cym ...

  2. Android RecyclerView Adapter 新式用法之SortedListAdapterCallback

    引言 前几天在同事的提醒下发现V7中有了一个新的工具类SortedListAdapterCallback,配合RecyclerView Adapter和SortedList一起使用更加方便的管理我们在 ...

  3. RecyclerView的基础用法

    为了让RecyclerView可以在所有的Android版本中都能使用,Android开发团队将RecyclerView定义在support.v7包当中.在使用该控件时需要打开当前Modile的bui ...

  4. Android RecyclerView SearchView基本用法1

    版权声明:本文为xing_star原创文章,转载请注明出处! 本文同步自http://javaexception.com/archives/82 背景: 做了很多年的app开发,貌似没见过没有搜索功能 ...

  5. RecyclerView解密篇(二)

    在上一篇(RecyclerView解密篇(一))文章中简单的介绍了RecyclerView的基本用法,接下来要来讲讲RecyclerView的更多用法,要实现不同的功能效果,大部分都还是在于Recyc ...

  6. 一篇博客理解Recyclerview的使用

    从Android 5.0开始,谷歌公司推出了RecylerView控件,当看到RecylerView这个新控件的时候,大部分人会首先发出一个疑问,recylerview是什么?为什么会有recyler ...

  7. Android RecyclerView使用详解(二)

    在上一篇(RecyclerView使用详解(一))文章中简单的介绍了RecyclerView的基本用法,接下来要来讲讲RecyclerView的更多用法,要实现不同的功能效果,大部分都还是在于Recy ...

  8. RecyclerView 实现gallery画廊效果

    1.RecyclerView的基本用法 首先主Activity的布局文件: [html] view plaincopy <RelativeLayout xmlns:android="h ...

  9. <Android基础>(三) UI开发 Part 3 RecyclerView

    RecyclerView 1)RecyclerView的基本用法 2)横向滚动和瀑布流滚动 3)注册点击事件 3.6 强大的滚动控件 RecyclerView ListView缺点: 1.不使用技巧优 ...

随机推荐

  1. json串转成list

    List<BaseStaEmpEntity> baseStaEmpEntities = new ArrayList<>(); //json转List<baseStaEmp ...

  2. jquery获取ul中li的值

  3. Python变量及数据类型

    所有编程语言几乎都会有 ’ 变量‘ ,如 a = 2,用一个a变量指代数字2,在Python中,一切皆对象,因此在变量赋值的时候实际上是在内存中开辟了一块存储变量内容的内存空间对象. 对象可以指定不同 ...

  4. Laya 分帧加载优化

    Laya 分帧加载优化 @author ixenos Flash中的EnterFrame事件在Laya中等同于Laya.timer.frameLoop(1,...) Laya.timer.frameL ...

  5. BZOJ1740: [Usaco2005 mar]Yogurt factory 奶酪工厂

    n<=10000天每天Ci块生产一东西,S块保存一天,每天要交Yi件东西,求最少花多少钱. 这个我都不知道归哪类了.. #include<stdio.h> #include<s ...

  6. Mysql数据库的事物

    一 .事物的特性:ACID 数据库的事务必须具备ACID特性,ACID是指 Atomicity(原子性).Consistensy(一致性).Isolation(隔离型)和Durability(持久性) ...

  7. MySQL中的数据类型的长度范围和显示宽度(转)

    长度范围是随数据类型就已经是固定的值,而显示宽度与长度范围无关. 以下是每个整数类型的存储和范围(来自MySQL手册) 类型 字节 最小值 最大值 (带符号的/无符号的) (带符号的/无符号的) TI ...

  8. oracle 用户账户被锁处理

    一.以管理员身份登录 SQL> conn sys/sys as sysdba; (分号是必须的但是我是以system登录的所在这不应该写conn sys/sys as sysdba应该写conn ...

  9. Jmeter参数Parameters和Body Data区别

    1.如图: 2.有文章说,Parameters是get的参数:Body Data是post的参数:get的参数存在于url中,post的参数存在于body中:   但是我使用jmeter3.3版本测试 ...

  10. hdu1133 Buy the Ticket (卡兰特数应用+java大数)

    题目链接:http://acm.hdu.edu.cn/showproblem.php? pid=1133 [题意] 电影票50块一张 有m个人手里正好有50块,n个人手里正好有100块,售票厅開始没有 ...