基于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 ...
随机推荐
- 【一天一道LeetCode】#83. Remove Duplicates from Sorted List
一天一道LeetCode 本系列文章已全部上传至我的github,地址:ZeeCoder's Github 欢迎大家关注我的新浪微博,我的新浪微博 欢迎转载,转载请注明出处 (一)题目 Given a ...
- 看uboot的时候发现随机数的另外一种算法
#include <stdio.h> #include <time.h> static unsigned int y = 1U; unsigned int rand_r(uns ...
- Cannot start service MSSQL$MICROSOFT##WID on computer
在做ADFS部署过程中配置ADFS服务时遇到如下问题 检查系统日志错误日志如下,很明显"NT SERVICE\MSSQL$MICROSOFT##WID"这个账户不在log on a ...
- 高性能C++网络库libtnet实践:comet单机百万连接挂载测试
最近在用go语言做一个挂载大量长连接的推送服务器,虽然已经完成,但是内存占用情况让我不怎么满意,于是考虑使用libtnet来重新实现一个.后续我会使用comet来表明推送服务器. 对于comet来说, ...
- 学习pthreads,使用属性对象创建结合线程和分离线程
当我们创建了子线程,是让它犹如脱缰之马,信步驰骋,还是如乖巧听话的孩子,时不时教导一下呢?针对这个问题,本文介绍线程的结合和分离,结构分为三个部分,第一部分给出代码示例,第二部分对代码进行讲解,第三部 ...
- 【嵌入式开发】C语言 结构体相关 的 函数 指针 数组
. 作者 : 万境绝尘 转载请注明出处 : http://www.hanshuliang.com/?post=30 . 结构体概述 : 结构体是 多个 变量的集合, 变量的类型可以不同; -- 可进行 ...
- 如何实现 集群化/Session 复制-doc(cluster-howto.html)
源文档链接: http://tomcat.apache.org/tomcat-6.0-doc/cluster-howto.html 翻译日期: 2014年3月19日 翻译人员: 铁锚 感受: Tomc ...
- MTK GPIO 一些理解
基于6575平台: GPIO驱动程序提供了两个接口: (1)内核空间:所提供的GPIO驱动程序,驱动程序可以调用其他函数 (2)用户空间:用户空间的程序可以通过发送IOCTL /dev/ mtgp ...
- 【1】mac下面iTerm配置oh-my-zsh教程
1.安装iterm 地址如下: http://iterm2.com/ 2.安装oh-my-zsh 打开iterm输入如下命令: sh -c "$(curl -fsSL https://raw ...
- 安卓TV开发(七) 移动智能终端多媒体之在线解析网页视频源
载请标明出处:http://blog.csdn.net/sk719887916/article/details/40049137,作者:skay 结束了所有UI绘制的学习,智能设备常用的应用音视频类, ...