fragment的布局:

  1. <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
  2. xmlns:tools="http://schemas.android.com/tools"
  3. android:layout_width="match_parent"
  4. android:layout_height="match_parent"
  5. tools:context=".fragment.VodListFragment">
  6. <android.support.v7.widget.RecyclerView
  7. android:id="@+id/id_recyclerview"
  8. android:divider="@color/colorWhite"
  9. android:dividerHeight="0dp"
  10. android:layout_width="match_parent"
  11. android:layout_height="match_parent"></android.support.v7.widget.RecyclerView>
  12. </FrameLayout>

item的布局

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <layout>
  3. <data>
  4. <variable
  5. name="vodvideo"
  6. type="com.xiangbita.dqk.dqkand.model.VodVideo"/>
  7. <variable
  8. name="handler"
  9. type="com.xiangbita.dqk.dqkand.fragment.VodListFragment"/>
  10. </data>
  11. <android.support.v7.widget.CardView xmlns:card_view="http://schemas.android.com/apk/res-auto"
  12. xmlns:android="http://schemas.android.com/apk/res/android"
  13. android:layout_width="match_parent"
  14. android:id="@+id/cardView"
  15. android:onClick="@{(theView) -> handler.to_play(theView, vodvideo)}"
  16. android:layout_height="wrap_content">
  17. <LinearLayout
  18. android:orientation="vertical"
  19. android:layout_width="match_parent"
  20. android:layout_height="wrap_content">
  21. <ImageView
  22. xmlns:app="http://schemas.android.com/apk/res-auto"
  23. android:layout_width="match_parent"
  24. android:layout_height="wrap_content"
  25. android:scaleType="fitCenter"
  26. app:imageUrl="@{vodvideo.snapshot}"/>
  27. <TextView
  28. android:layout_width="match_parent"
  29. android:layout_height="wrap_content"
  30. android:text="title"/>
  31. </LinearLayout>
  32. </android.support.v7.widget.CardView>
  33. </layout>

fragment中对RecyclerView的初始化:

  1. View view  =inflater.inflate(R.layout.fragment_vod_list, container, false);
  2. mRecyclerView = (RecyclerView) view.findViewById(R.id.id_recyclerview);
  3. mspan_count=2;
  4. StaggeredGridLayoutManager layoutManager = new StaggeredGridLayoutManager(mspan_count,StaggeredGridLayoutManager.VERTICAL);
  5. layoutManager.setGapStrategy(StaggeredGridLayoutManager.GAP_HANDLING_NONE);
  6. mRecyclerView.setLayoutManager(layoutManager);
  7. mVodAdapter = new VodAdapter();
  8. mRecyclerView.setAdapter(mVodAdapter);
  9. SpacesItemDecoration decoration=new SpacesItemDecoration(2);
  10. mRecyclerView.addItemDecoration(decoration);
  11. mRecyclerView.setItemAnimator(new DefaultItemAnimator());
  12. videoList = new ArrayList<>();

上面代码中用到的内部类VodAdapter:

  1. class VodAdapter extends RecyclerView.Adapter<VodAdapter.VodItemViewHolder> {
  2. @Override
  3. public VodItemViewHolder onCreateViewHolder(ViewGroup parent, int viewType)
  4. {
  5. ViewDataBinding itembinding = DataBindingUtil.inflate(LayoutInflater.from(getContext()
  6. ), R.layout.vod_list_item, parent, false);
  7. VodItemViewHolder holder = new VodItemViewHolder(itembinding.getRoot());
  8. itembinding.setVariable(BR.handler,VodListFragment.this);
  9. holder.viewDataBinding = itembinding;
  10. return holder;
  11. }
  12. @Override
  13. public void onBindViewHolder(VodItemViewHolder holder, int position)
  14. {
  15. holder.viewDataBinding.setVariable(BR.vodvideo,videoList.get(position));
  16. }
  17. @Override
  18. public int getItemCount()
  19. {
  20. return videoList.size();
  21. }
  22. class VodItemViewHolder extends RecyclerView.ViewHolder
  23. {
  24. public ViewDataBinding viewDataBinding;
  25. public CardView cardView;
  26. public VodItemViewHolder(View view)
  27. {
  28. super(view);
  29. cardView = (CardView) view.findViewById(R.id.cardView);
  30. }
  31. }

用到的内部类SpaceItemDecoration:

  1. public class SpacesItemDecoration extends RecyclerView.ItemDecoration {
  2. private int space;
  3. public SpacesItemDecoration(int space) {
  4. this.space=space;
  5. }
  6. @Override
  7. public void getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) {
  8. outRect.left=space;
  9. outRect.right=space;
  10. outRect.bottom=space;
  11. if(parent.getChildAdapterPosition(view)<mspan_count){
  12. outRect.top=space;
  13. }
  14. }
  15. }

做个简单的说明,如果不加这个SpaceItemDecoration会导致数据第一次加载时的item布局异常。

参考资料:

Android RecyclerView 使用完全解析 体验艺术般的控件:http://blog.csdn.NET/lmj623565791/article/details/45059587
RecyclerView实现瀑布流布局: http://blog.csdn.net/tiankong1206/article/details/47088995

基于RecyclerView的瀑布流实现的更多相关文章

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

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

  2. RecyclerView 制作瀑布流图片

    这是瀑布流的效果图 RecyclerView(ListView的升级版) 加载图片用的是第三方图片加载框架 ------------------------------------- 在Xml中 &l ...

  3. [Android Pro] RecyclerView实现瀑布流效果(二)

    referece to : http://blog.csdn.net/u010687392 在上篇中我们知道RecyclerView中默认给我们提供了三种布局管理器,分别是LinearLayoutMa ...

  4. 使用RecyclerView实现瀑布流的效果

    主函数: public class MainActivity extends AppCompatActivity { private RecyclerView recyclerView; privat ...

  5. RecyclerView实现瀑布流效果(图文详解+源码奉送)

    最近有时间研究了一下RecyclerView,果然功能强大啊,能实现的效果还是比较多的,那么今天给大家介绍一个用RecyclerView实现的瀑布流效果. 先来一张效果图: 看看怎么实现吧: 整体工程 ...

  6. RecyclerView实现瀑布流效果(二)

    在上篇中我们知道RecyclerView中默认给我们提供了三种布局管理器,分别是LinearLayoutManager.GridLayoutManager.StaggeredGridLayoutMan ...

  7. 初步使用RecyclerView实现瀑布流

    先看效果 关于RecyclerView,真的是很强大. 个人觉得主要方便的地方是 1.直接可以设置条目布局,通过setLayoutManager LinearLayoutManager:线性布局,横向 ...

  8. 用RecyclerView实现瀑布流

    首先建立一个 PbRecyclerViewActivity.java文件: 1 public class PbRecyclerViewActivity extends AppCompatActivit ...

  9. 自定义基于jquery竖向瀑布流插件

    公司新项目做了一个关于图片的板块,网上找了一些瀑布流插件都不是很适合自己,于是就自己造轮子写一个,并封装成插件github 于是就想分享一下,主要是为了更好的学习与记忆. 如果大家进来了,希望能给我g ...

随机推荐

  1. Oracle EBS SLA 详解

    SLA概述 SLA :子分类账(Subledger Accounting),这个在R12中大力宣扬的内容,我们通常的认为总账就是对Journal的汇总,但是在实际的操作中我们会发现,对于Sub sys ...

  2. 高性能nosql ledisdb设计与实现 (2):replication

    ledisdb现在已经支持replication机制,为ledisdb的高可用做出了保障. 使用 假设master的ip为10.20.187.100,端口6380,slave的ip为10.20.187 ...

  3. Android进阶(三)android httpClient 支持HTTPS的访问方式

    项目中Android https请求地址遇到了这个异常(无终端认证): javax.net.ssl.SSLPeerUnverifiedException: No peer certificate 是S ...

  4. 分布式集群Session共享 简单多tomcat8+redis的session共享实现

    ; i++) { str = str + session.getAttribute("name" + i) + "<br>"; } response ...

  5. Dynamics CRM2013 ScLib::AccessCheckEx failed

    今天在系统中做某一操作的时候报如下截图错误,把错误日志下载下来,根据AccessRights这:ReadAccess一提示确定是对某一实体没有读的权限. 那怎样知道是哪个实体呢,再看上面错误日志中给出 ...

  6. ROS_Kinetic_03 ROS入门向导

    ROS_Kinetic_03 ROS入门向导 每个人都有不同的学习习惯和爱好并针对不同的应用进行ROS相关设计与开发, 没有固定不变的学习模式,但以下的内容是通常都会用到的. 1. ROS基础教程 1 ...

  7. oracle ebs应用产品安全性-定义访问权限集

    定义 定义访问权限集是一项分配至责任层的可选的安全功能,是对Oracle 11i应用产品弹性域安全性定义的功能扩展,对总帐管理模块的一些内容进行安全性定义和权限分配的集合,以控制不同的责任对一些内容的 ...

  8. Java 与 C++ 不一样的地方(持续更新中...)

    本文仅以记录 Java 与 C++ 不同之处,以备随时查询. Java 程序运行机制 Java 是一门编译解释型的语言,即它在运行的过程中既需要编译也需要解释.如下图表示的是 Java 程序运行机制: ...

  9. mysql 字符集更改与导入数据

    mysql 字符集更改与导入数据 mysqldb经常有中文乱码的问题,解决起来很恼火.其实所有开发和数据库统一为一种编码就可以了: utf8. 1 下面修改mysql的编码 1) 永久修改. 在/et ...

  10. mysql进阶(十七)Cannot Connect to Database Server

    Cannot Connect to Database Server 缘由 由于不同的项目中使用的数据库用户名与密码出现了不一致的情况,在其中之前较早一个项目执行过程中出现"The user  ...