内容简介:vlayout(VirtualLayout)是阿里开源的一个针对 RecyclerView 的 LayoutManager 扩展,主要提供一整套布局方案和布局间的组件复用的问题。 vlayout 1.2.11 已发布,该版本修复了以下问题: #295 升级后出现 on...
vlayout(VirtualLayout)是阿里开源的一个针对 RecyclerView 的 LayoutManager 扩展,主要提供一整套布局方案和布局间的组件复用的问题。
vlayout 1.2.11 已发布,该版本修复了以下问题:
#295 升级后出现 onBindViewHolder 未分发的问题
#304 DelegateAdapter 中的 onViewAttachedToWindow(onViewDetachedFromWindow) bug
设计思路
通过定制化的 LayoutManager,接管整个 RecyclerView 的布局逻辑;LayoutManager 管理了一系列 LayoutHelper,LayoutHelper 负责具体布局逻辑实现的地方;每一个 LayoutHelper 负责页面某一个范围内的组件布局;不同的 LayoutHelper 可以做不同的布局逻辑,因此可以在一个 RecyclerView 页面里提供异构的布局结构,这就能比系统自带的 LinearLayoutManager、GridLayoutManager 等提供更加丰富的能力。同时支持扩展 LayoutHelper 来提供更多的布局能力。
主要功能
默认通用布局实现,解耦所有的 View 和布局之间的关系: Linear, Grid, 吸顶, 浮动, 固定位置等。
LinearLayoutHelper: 线性布局
GridLayoutHelper: Grid 布局, 支持横向的 colspan
FixLayoutHelper: 固定布局,始终在屏幕固定位置显示
ScrollFixLayoutHelper: 固定布局,但之后当页面滑动到该图片区域才显示, 可以用来做返回顶部或其他书签等
FloatLayoutHelper: 浮动布局,可以固定显示在屏幕上,但用户可以拖拽其位置
ColumnLayoutHelper: 栏格布局,都布局在一排,可以配置不同列之间的宽度比值
SingleLayoutHelper: 通栏布局,只会显示一个组件 View
OnePlusNLayoutHelper: 一拖N布局,可以配置1-5个子元素
StickyLayoutHelper: stikcy 布局, 可以配置吸顶或者吸底
StaggeredGridLayoutHelper: 瀑布流布局,可配置间隔高度/宽度
上述默认实现里可以大致分为两类:一是非fix类型布局,像线性、Grid、栏格等,它们的特点是布局在整个页面流里,随页面滚动而滚动;另一类就是fix类型的布局,它们的子节点往往不随页面滚动而滚动。
所有除布局外的组件复用,VirtualLayout 将用来管理大的模块布局组合,扩展了 RecyclerView ,使得同一 RecyclerView 内的组件可以复用,减少 View 的创建和销毁过程。
Demo
【声明】文章转载自:开源中国社区 [http://www.oschina.net]
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- vlayout 1.2.6 发布,LayoutManager 定制化布局
- vlayout 1.2.15 发布,LayoutManager 定制化布局
- vlayout 1.2.16 发布,LayoutManager 定制化布局
- vlayout 1.2.14 发布,阿里 LayoutManager 定制化布局
- vlayout 1.2.20 发布,阿里 LayoutManager 定制化布局
- vlayout 1.2.31 发布,阿里 LayoutManager 定制化布局
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
Web ReDesign 2.0
Kelly Goto、Emily Cotler / Peachpit Press / 2004-12-10 / USD 45.00
If anything, this volume's premise--that the business of Web design is one of constant change-has only proven truer over time. So much so, in fact, that the 12-month design cycles cited in the last ed......一起来看看 《Web ReDesign 2.0》 这本书的介绍吧!