vlayout 1.2.14 发布,阿里 LayoutManager 定制化布局

栏目: 软件资讯 · 发布时间: 6年前

内容简介:vlayout(VirtualLayout)是阿里开源的一个针对 RecyclerView 的 LayoutManager 扩展,主要提供一整套布局方案和布局间的组件复用的问题。 vlayout 1.2.14 已发布,该版本新增了一个用来监控性能的 API : layo...

vlayout(VirtualLayout)是阿里开源的一个针对 RecyclerView 的 LayoutManager 扩展,主要提供一整套布局方案和布局间的组件复用的问题。

vlayout 1.2.14 已发布,该版本新增了一个用来监控性能的 API :

layoutManager.setPerformanceMonitor(new PerformanceMonitor() {

        @Override
        public void recordStart(String phase, View view) {
                
        }

        @Override
        public void recordEnd(String phase, View view) {
                
        }
 });

设计思路

通过定制化的 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

vlayout 1.2.14 发布,阿里 LayoutManager 定制化布局

下载地址:


【声明】文章转载自:开源中国社区 [http://www.oschina.net]


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Kafka技术内幕

Kafka技术内幕

郑奇煌 / 人民邮电出版社 / 2017-11 / 119.00元

Kafka自LinkedIn开源以来就以高性能、高吞吐量、分布式的特性著称,本书以0.10版本的源码为基础,深入分析了Kafka的设计与实现,包括生产者和消费者的消息处理流程,新旧消费者不同的设计方式,存储层的实现,协调者和控制器如何确保Kafka集群的分布式和容错特性,两种同步集群工具MirrorMaker和uReplicator,流处理的两种API以及Kafka的一些高级特性等。一起来看看 《Kafka技术内幕》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

URL 编码/解码
URL 编码/解码

URL 编码/解码

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换