基于RecyclerView的瀑布流实现
fragment的布局:
- <FrameLayout 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"
- tools:context=".fragment.VodListFragment">
- <android.support.v7.widget.RecyclerView
- android:id="@+id/id_recyclerview"
- android:divider="@color/colorWhite"
- android:dividerHeight="0dp"
- android:layout_width="match_parent"
- android:layout_height="match_parent"></android.support.v7.widget.RecyclerView>
- </FrameLayout>
item的布局
- <?xml version="1.0" encoding="utf-8"?>
- <layout>
- <data>
- <variable
- name="vodvideo"
- type="com.xiangbita.dqk.dqkand.model.VodVideo"/>
- <variable
- name="handler"
- type="com.xiangbita.dqk.dqkand.fragment.VodListFragment"/>
- </data>
- <android.support.v7.widget.CardView xmlns:card_view="http://schemas.android.com/apk/res-auto"
- xmlns:android="http://schemas.android.com/apk/res/android"
- android:layout_width="match_parent"
- android:id="@+id/cardView"
- android:onClick="@{(theView) -> handler.to_play(theView, vodvideo)}"
- android:layout_height="wrap_content">
- <LinearLayout
- android:orientation="vertical"
- android:layout_width="match_parent"
- android:layout_height="wrap_content">
- <ImageView
- xmlns:app="http://schemas.android.com/apk/res-auto"
- android:layout_width="match_parent"
- android:layout_height="wrap_content"
- android:scaleType="fitCenter"
- app:imageUrl="@{vodvideo.snapshot}"/>
- <TextView
- android:layout_width="match_parent"
- android:layout_height="wrap_content"
- android:text="title"/>
- </LinearLayout>
- </android.support.v7.widget.CardView>
- </layout>
fragment中对RecyclerView的初始化:
- View view =inflater.inflate(R.layout.fragment_vod_list, container, false);
- mRecyclerView = (RecyclerView) view.findViewById(R.id.id_recyclerview);
- mspan_count=2;
- StaggeredGridLayoutManager layoutManager = new StaggeredGridLayoutManager(mspan_count,StaggeredGridLayoutManager.VERTICAL);
- layoutManager.setGapStrategy(StaggeredGridLayoutManager.GAP_HANDLING_NONE);
- mRecyclerView.setLayoutManager(layoutManager);
- mVodAdapter = new VodAdapter();
- mRecyclerView.setAdapter(mVodAdapter);
- SpacesItemDecoration decoration=new SpacesItemDecoration(2);
- mRecyclerView.addItemDecoration(decoration);
- mRecyclerView.setItemAnimator(new DefaultItemAnimator());
- videoList = new ArrayList<>();
上面代码中用到的内部类VodAdapter:
- class VodAdapter extends RecyclerView.Adapter<VodAdapter.VodItemViewHolder> {
- @Override
- public VodItemViewHolder onCreateViewHolder(ViewGroup parent, int viewType)
- {
- ViewDataBinding itembinding = DataBindingUtil.inflate(LayoutInflater.from(getContext()
- ), R.layout.vod_list_item, parent, false);
- VodItemViewHolder holder = new VodItemViewHolder(itembinding.getRoot());
- itembinding.setVariable(BR.handler,VodListFragment.this);
- holder.viewDataBinding = itembinding;
- return holder;
- }
- @Override
- public void onBindViewHolder(VodItemViewHolder holder, int position)
- {
- holder.viewDataBinding.setVariable(BR.vodvideo,videoList.get(position));
- }
- @Override
- public int getItemCount()
- {
- return videoList.size();
- }
- class VodItemViewHolder extends RecyclerView.ViewHolder
- {
- public ViewDataBinding viewDataBinding;
- public CardView cardView;
- public VodItemViewHolder(View view)
- {
- super(view);
- cardView = (CardView) view.findViewById(R.id.cardView);
- }
- }
用到的内部类SpaceItemDecoration:
- public class SpacesItemDecoration extends RecyclerView.ItemDecoration {
- private int space;
- public SpacesItemDecoration(int space) {
- this.space=space;
- }
- @Override
- public void getItemOffsets(Rect outRect, View view, RecyclerView parent, RecyclerView.State state) {
- outRect.left=space;
- outRect.right=space;
- outRect.bottom=space;
- if(parent.getChildAdapterPosition(view)<mspan_count){
- outRect.top=space;
- }
- }
- }
做个简单的说明,如果不加这个SpaceItemDecoration会导致数据第一次加载时的item布局异常。
参考资料:
Android RecyclerView 使用完全解析 体验艺术般的控件:http://blog.csdn.NET/lmj623565791/article/details/45059587
RecyclerView实现瀑布流布局: http://blog.csdn.net/tiankong1206/article/details/47088995
基于RecyclerView的瀑布流实现的更多相关文章
- Android RecyclerView(瀑布流)水平/垂直方向分割线
Android RecyclerView(瀑布流)水平/垂直方向分割线 Android RecyclerView不像过去的ListView那样随意的设置水平方向的分割线,如果要实现Recycle ...
- RecyclerView 制作瀑布流图片
这是瀑布流的效果图 RecyclerView(ListView的升级版) 加载图片用的是第三方图片加载框架 ------------------------------------- 在Xml中 &l ...
- [Android Pro] RecyclerView实现瀑布流效果(二)
referece to : http://blog.csdn.net/u010687392 在上篇中我们知道RecyclerView中默认给我们提供了三种布局管理器,分别是LinearLayoutMa ...
- 使用RecyclerView实现瀑布流的效果
主函数: public class MainActivity extends AppCompatActivity { private RecyclerView recyclerView; privat ...
- RecyclerView实现瀑布流效果(图文详解+源码奉送)
最近有时间研究了一下RecyclerView,果然功能强大啊,能实现的效果还是比较多的,那么今天给大家介绍一个用RecyclerView实现的瀑布流效果. 先来一张效果图: 看看怎么实现吧: 整体工程 ...
- RecyclerView实现瀑布流效果(二)
在上篇中我们知道RecyclerView中默认给我们提供了三种布局管理器,分别是LinearLayoutManager.GridLayoutManager.StaggeredGridLayoutMan ...
- 初步使用RecyclerView实现瀑布流
先看效果 关于RecyclerView,真的是很强大. 个人觉得主要方便的地方是 1.直接可以设置条目布局,通过setLayoutManager LinearLayoutManager:线性布局,横向 ...
- 用RecyclerView实现瀑布流
首先建立一个 PbRecyclerViewActivity.java文件: 1 public class PbRecyclerViewActivity extends AppCompatActivit ...
- 自定义基于jquery竖向瀑布流插件
公司新项目做了一个关于图片的板块,网上找了一些瀑布流插件都不是很适合自己,于是就自己造轮子写一个,并封装成插件github 于是就想分享一下,主要是为了更好的学习与记忆. 如果大家进来了,希望能给我g ...
随机推荐
- 《java入门第一季》之泛型类引入
首先用一个例子引入泛型类. 我定义一个Object类: package cn.it_03; public class ObjectTool { private Object obj; public O ...
- Java中四大代码块的执行顺序(附code)
验证证的方法是写code,如下: public class test { static class A { public static String name = "hello"; ...
- 40个比较重要的Android面试题
1. Android的四大组件是哪些,它们的作用? 答:Activity:Activity是Android程序与用户交互的窗口,是Android构造块中最基本的一种,它需要为保持各界面的状态,做很多持 ...
- hadoop集群崩溃,因为tmp下/tmp/hadoop-hadoop/dfs/name文件误删除
hadoop执行start-all后,显示正常启动. starting namenode, logging to /opt/hadoop-0.20.2-cdh3u0/logs/hadoop-hadoo ...
- GDAL书籍
GDAL的书籍经过快两年的编写修改,终于出版发行了,有需要的同学可以到下面的网址进行购买. 购买地址: 亚马逊:http://www.amazon.cn/GDAL%E6%BA%90%E7%A0%81% ...
- Web资源认证原理
Web服务器与浏览器之间的认证流程没有规定的步骤,根据不同的认证模式及鉴权方式可能会有不同的执行步骤.下图用一个最简单的流程了解整个认证过程是如何工作的,首先浏览器向服务器发起请求,然后服务器向浏览器 ...
- 【一天一道LeetCode】#58. Length of Last Word
一天一道LeetCode系列 (一)题目 Given a string s consists of upper/lower-case alphabets and empty space charact ...
- unity使用UGUI创建摇杆
1.现在unity做一个项目,各种插件各种包,于是项目资源就无限变大了,其实一些简单的功能可以自己写,这里就是试着使用UGUI编写一个摇杆功能 2.脚本如下: using UnityEngine; u ...
- 【算法导论】八皇后问题的算法实现(C、MATLAB、Python版)
八皇后问题是一道经典的回溯问题.问题描述如下:皇后可以在横.竖.斜线上不限步数地吃掉其他棋子.如何将8个皇后放在棋盘上(有8*8个方格),使它们谁也不能被吃掉? 看到这个问题,最容易想 ...
- Android 自定义view --圆形百分比(进度条)
转载请注明出处:http://blog.csdn.net/wingichoy/article/details/50334595 注:本文由于是在学习过程中写的,存在大量问题(overdraw onDr ...