VLayout的使用总结

不怕跌倒,所以飞翔

参考文献:
Carson_Ho 的Android开源库V - Layout:淘宝、天猫都在用的UI框架,赶紧用起来吧!
我就是马云飞的android VLayout 全面解析

V- Layout 是阿里出品的基础 UI 框架,用于快速实现页面的复杂布局。这个控件一般用于实现种类较多的页面展示。

一直以来都想看看这个开源项目怎么用,但是一直也没有太多时间去看,今天特意花了点时间去看了一下这个开源项目,没有深入的研究源码,只是简单的使用,把使用心得记录下来,以便学习它的人能快速的上手使用;

1.使用

首先先介绍几种布局形式

   - LinearLayoutHelper: 线性布局 
   - GridLayoutHelper: Grid布局, 支持横向的colspan 
   - FixLayoutHelper: 固定布局,始终在屏幕固定位置显示 
   - ScrollFixLayoutHelper: 固定布局,但之后当页面滑动到该图片区域才显示, 可以用来做返回顶部或其他书签等 
   - FloatLayoutHelper: 浮动布局,可以固定显示在屏幕上,但用户可以拖拽其位置 
   - ColumnLayoutHelper: 栏格布局,和布局在一排,可以配置不同列之间的宽度比值 
   - SingleLayoutHelper: 通栏布局,只会显示一个组件View 
   - OnePlusNLayoutHelper: 一拖N布局,可以配置1-5个子元素 
   - StickyLayoutHelper: stikcy布局, 可以配置吸顶或者吸底 
   - StaggeredGridLayoutHelper: 瀑布流布局,可配置间隔高度/宽度

以上这几种布局格式包含了多种布局的格式。

1.引入类库

这个没有什么好说的直接按照gitHub上的方法直接引入就可以了

 compile('com.alibaba.android:vlayout:1.0.7@aar') {
        transitive = true
    }

2.创建VirtualLayoutManager对象

VirtualLayoutManager layoutManager = new VirtualLayoutManager(this);
rv.setLayoutManager(layoutManager);

这个其实就是相当于RecycleView中的LayoutManager只不过是重写了罢了。

3.设置复用池大小

// 设置组件复用回收池
RecyclerView.RecycledViewPool viewPool = new RecyclerView.RecycledViewPool(); 
recyclerView.setRecycledViewPool(viewPool); 
viewPool.setMaxRecycledViews(0, 10);

4.创建管理Adapter的适配器

DelegateAdapter delegateAdapter = new DelegateAdapter(manager, true);

这个相当于适配器的类,但是他可以管理更多适配器去进行布局,所以相当于适配器的管理类,用于之后添加所有的适配器的集合

5.创建一个集合管理其中的适配器

List<DelegateAdapter.Adapter> adapters = new ArrayList<>();

这个集合是用来存放你写的适配器的。

6.实现适配器

其实实现适配器的话和以前的实现没有什么区别就是多覆写了一个类,继承关系也发生了改变而已。

public class BaseItemsAdapter extends DelegateAdapter.Adapter<ItemHolder> {

    private Context mContext;
    private LayoutHelper mHelper;
    private String mColor;/*这个颜色值主要是为了区分样式的*/
    private int mCount;

    public BaseItemsAdapter(Context context, LayoutHelper helper, String color, int count) {
        mContext = context;
        mHelper = helper;
        this.mColor = color;
        this.mCount = count;
    }

    @Override
    public LayoutHelper onCreateLayoutHelper() {
        return mHelper;
    }

    @Override
    public ItemHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        View itemView = LayoutInflater.from(mContext).inflate(R.layout.items_linear, parent, false);
        return new ItemHolder(itemView);
    }

    @Override
    public void onBindViewHolder(ItemHolder holder, int position) {
        holder.itemView.setBackgroundColor(Color.parseColor(mColor));
        holder.mTvContent.setText("这是基类的布局" + position);
    }

    @Override
    public int getItemCount() {
        return mCount;
    }
}
注意几点问题:

1.这里你主要看一下继承的不在是RecycleView的Adapter了而是DelegateAdapter的Adapter了;
2.重新覆写了一个onCreateLayoutHelper()这个方法,这个方法返回的是一个LayoutHelper;
3.关于这个LayoutHelper是上面提到的几种类型,这里可以从上个页面通过构造方法传过来。

6.最后把相应的适配器进行添加就好了

/*添加了所有的适配器之后添加到*/
delegateAdapter.addAdapters(adapters);

 /*设置recycleView*/
mRecycleView.setAdapter(delegateAdapter);

以上方法就能实现简单的组合布局了;还有一些细节的问题我会在下面进行讲解。。。

2.其他特点添加:

1.margin和padding

这里面的Margin和Padding指的是LayoutHelper的Margin和Padding而不是整个RecycleView的Margin和Padding
设置方法如下:

setPadding(int leftPadding, int topPadding, int rightPadding, int bottomPadding)
setMargin(int leftMargin, int topMargin, int rightMargin, int bottomMargin)
引用网络上的一张图片

2.设置背景颜色和图片

bgColor, bgImg这两个属性都是针对于非fix类型的LayoutHelper
设置方法如下:

setBgColor(int bgColor);

设置背景的方法我觉得没有用所以没有去研究怎么使用。

3.设置宽高比属性aspectRatio

这个宽高比要从两个方面来说

  • LayoutHelper定义的aspectRatio,指的是一行视图整体的宽度与高度之比,当然整体的宽度是减去了RecyclerView和对应的LayoutHelper的margin, padding。
  • 视图的LayoutParams定义的aspectRatio,指的是在LayoutHelper计算出视图宽度之后,用来确定视图高度时使用的,它会覆盖通过LayoutHelper的aspectRatio计算出来的视图高度,因此具备更高优先级。


    引用网络上的一张图片

    设置方法如下:

//对于LayoutHelper,调用
setAspectRatio(float aspectRatio);
//对于LayoutParams,调用
((VirutalLayoutManager.LayoutParams) layoutParams).mAspectRatio

4. 设置dividerHeight 行间距

这个行间距是针对LinearLayoutHelper的
设置方法如下:

setDividerHeight(int dividerHeight);

5.设置weights属性

这个属只是针对于ColumnLayoutHelper, GridLayoutHelper的属性

  • weights属性是一个float数组,每一项代表某一列占父容器宽度的百分比,总和建议是100,否则布局会超出容器宽度;如果布局中有4列,那么weights的长度也应该是4;长度大于4,多出的部分不参与宽度计算;如果小于4,不足的部分默认平分剩余的空间。
    设置方法如下:
setWeights(float[] weights);
引用网络上的一张图片

6.vGap, hGap

这个属性是针对GridLayoutHelper与StaggeredGridLayoutHelper都有这两个属性,分别控制视图之间的垂直间距和水平间距。

引用网络上的一张图片

设置方法如下:

setHGap(int hGap);
setVGap(int vGap);

7.spanCount, spanSizeLookup

只针对GridLayoutHelper的属性,但通过提供自定义的spanSizeLookUp,可以指定某个位置的视图占用多个网格区域。


引用网络上的一张图片

设置方法如下:

setSpanCount(int spanCount);
setSpanSizeLookup(SpanSizeLookup spanSizeLookup);

8.autoExpand

GridLayoutHelper的属性,当一行里视图的个数少于spanCount值的时候,如果autoExpand为true,视图的总宽度会填满可用区域;否则会在屏幕上留空白区域。


引用网络上的一张图片

设置方法如下:

setAutoExpand(boolean isAutoExpand);

9.lane

StaggeredGridLayoutHelper中有这个属性,设置瀑布流的列数

设置方法如下:

setLane(int lane)

10.fixAreaAdjuster

fix类型的LayoutHelper的属性,在可能需要设置一个相对父容器四个边的偏移量,比如整个页面里有一个固定的标题栏添加在vlayout容器上,vlayout内部的fix类型视图不希望与外部的标题有所重叠,那么就可以设置一个fixAreaAdjuster来做偏移。


引用网络上的一张图片

设置方法如下:

setAdjuster(FixAreaAdjuster adjuster);

11.alignType, x, y

FixLayoutHelper, ScrollFixLayoutHelper, FloatLayoutHelper的属性,表示吸边时的基准位置,有四个取值,分别是TOP_LEFT, TOP_RIGHT, BOTTOM_LEFT, BOTTOM_RIGHT。x和y是相对这四个位置的偏移量,最终的偏移量还要受上述的fixAreaAdjuster影响

  • TOP_LEFT:基准位置是左上角,x是视图左边相对父容器的左边距偏移量,y是视图顶边相对父容器的上边距偏移量;
  • TOP_RIGHT:基准位置是右上角,x是视图右边相对父容器的右边距偏移量,y是视图顶边相对父容器的上边距偏移量;
  • BOTTOM_LEFT:基准位置是左下角,x是视图左边相对父容器的左边距偏移量,y是视图底边相对父容器的下边距偏移量;
  • BOTTOM_RIGHT:基准位置是右下角,x是视图右边相对父容器的右边距偏移量,y是视图底边相对父容器的下边距偏移量;


    引用网络上的一张图片

设置代码如下:

//设置基准调用
setAlignType(int alignType);
//设置偏移量调用
setX(int x);
setY(int y);

12.showType

ScrollFixLayoutHelper的属性,取值有SHOW_ALWAYS, SHOW_ON_ENTER, SHOW_ON_LEAVE。

  • SHOW_ALWAYS:与FixLayoutHelper的行为一致,固定在某个位置;
  • SHOW_ON_ENTER:默认不显示视图,当页面滚动到这个视图的位置的时候,才显示;
  • SHOW_ON_LEAVE:默认不显示视图,当页面滚出这个视图的位置的时候显示;
引用网络上的一张图片

设置代码如下:

setShowType(int showType);

13.stickyStart, offset

StickyLayoutHelper的属性,当视图的位置在屏幕范围内时,视图会随页面滚动而滚动;当视图的位置滑出屏幕时,StickyLayoutHelper会将视图固定在顶部(stickyStart = true)或者底部(stickyStart = false),固定的位置支持设置偏移量offset。

引用网络上的一张图片

设置代码如下:

setStickyStart(boolean stickyStart);
setOffset(int offset);

关于这个开源框架里面有好多的细节需要注意,这里面有写得不好的话还希望大神们指点

Demo有很多都没有完善,等到有时间的时候去完善
Demo地址

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容