Android 豆瓣电影- RecyclerView

前言

完整项目 托管在 github 上,直达电梯:豆瓣电影客户端 github

也可以先看前两篇文章:

Android 从零开始-豆瓣电影客户端
Android 从零开始-网络缓存实现与分析

一、基础

RecyclerView 是个支持库,存在 `com.android.support` 之中,集成方式

compile 'com.android.support:appcompat-v7:24.1.1'
compile 'com.android.support:recyclerview-v7:24.1.1'

目前使用的是 24.1.1 版本。可以根据自己的情况使用不同的版本,建议升级到最新版,因为有些 bug 也在不断修复中,如果你说没有 bug, 或许是没有碰到呢。

在 RecyclerView 中存在 三种 布局管理模式 分别是:LinearLayoutManagerGridLayoutManagerStaggeredGridLayoutManager
豆瓣客户端中使用了 两种 布局管理模式 分别是 LiearLayoutManagerGridLayoutManager,

LinearLayoutManager

  • 定义
    顾名思义局势 线性布局模式,这个是我们用的最多的方式,呈现效果就是顺序排列而下的方式

  • 使用

    1. xml 布局直接使用:
<android.support.v7.widget.RecyclerView
           android:id="@+id/recyclerview"
           android:layout_width="match_parent"
           android:layout_height="match_parent"
           android:clipToPadding="false"
           android:orientation="vertical"
           android:padding="4dp"
           android:scrollbarStyle="insideOverlay"
           android:scrollbars="vertical"
           app:layoutManager="android.support.v7.widget.LinearLayoutManager"
           />
  1. Java 代码中定义

LinearLayoutManager linearLayoutManager = new LinearLayoutManager(getActivity());
recyclerView.setLayoutManager(linearLayoutManager);

GridLayoutManager

  • 定义

网格布局,一排可以显示1格、或者更多格。

  • 使用

    1. xml 布局直接使用:
<android.support.v7.widget.RecyclerView
           android:id="@+id/recyclerview"
           android:layout_width="match_parent"
           android:layout_height="match_parent"
           android:clipToPadding="false"
           android:orientation="vertical"
           android:padding="4dp"
           android:scrollbarStyle="insideOverlay"
           android:scrollbars="vertical"
           app:layoutManager="android.support.v7.widget.GridLayoutManager"
           app:spanCount="3" />

app:layoutManager 定义布局方式,app:spanCount="3"列数。
需要在 xml 布局中加入 xmlns:app="http://schemas.android.com/apk/res-auto"

  1. Java 代码中定义
GridLayoutManager  mGridLayoutManager = new GridLayoutManager(getContext(), 3);
mRecyclerView.setLayoutManager(mGridLayoutManager);

StaggeredGridLayoutManager

  • 定义

流线型布局方式,就是通常说的瀑布流的效果。

  • 使用

    1. java 代码中定义
// 交错网格布局管理器
StaggeredGridLayoutManager staggeredGridLayoutManager = new StaggeredGridLayoutManager(2, LinearLayoutManager.VERTICAL);
// 设置布局管理器
recyclerView.setLayoutManager(staggeredGridLayoutManager);

其中设置 StaggeredGridLayoutManager(2, LinearLayoutManager.VERTICAL) 的 数字 2 指代的是列数,LinearLayoutManager.VERTICAL 和方向。

二、进阶

  1. 下图不规则布局效果是怎么实现出来的呢?

comming_soon

是这个方法的使用 SpanSizeLookup


mGridLayoutManager.setSpanSizeLookup(new GridLayoutManager.SpanSizeLookup() {
            @Override
            public int getSpanSize(int position) {
                switch (position % 4) {
                    case 0:
                        return 3;
                    default:
                        return 1;
                }
            }
        });

其中 position % 4 每4条数据一个循环,return 3; 表示此条数据占 3 列,即一行显示一条数据。

  1. 上拉加载更多 效果怎么实现呢?

load_more

限于篇幅,下篇文章详细介绍。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值