【约束布局】ConstraintLayout 组件可见性 View.GONE 处理 与 Margin 属性

【约束布局】ConstraintLayout 组件可见性 View.GONE 处理 与 Margin 属性,第1张

【约束布局】ConstraintLayout 组件可见性 View.GONE 处理 与 Margin 属性

很久没写文章了,但是针对今天这篇文章还是值得记录下,供大家参考学习,目前布局中用ConstraintLayout(简称cons)应该很常见了,至于为什么要用这个布局,我想大家用过的都知道cons没有出现之前稍微复杂点的界面就各种嵌套,对于维护,修改也不是很方便。cons它作用就是控件与控件直接约束,不需要额外的嵌套。好了说下今天的正题:

1.首先了解下cons中的Margin属性:

cons中用Margin属性必须有个条件就是约束,比如你要设置marginStart=15dp.那么你必须有个横向约束,要设置margintop,必须要有竖向约束。不然就算你设置了值也不会生效的,当然这是约束布局的基本原则。
2.当组件设置View.GONE时,Margin属性以及goneMargin属性的作用:

这个就是今天的重点,前面讲了margin属性的设置,现在模拟一个场景假如有A,B,C三个控件,依次ABC顺序:




    

    

    

每个都设置了10dp间隔,现在C在底部,并且距离底部有10dp,(我们假如设计图就是这么设计的),现在需要根据数据控制C是否显示,假如C不显示那么B是什么效果呐,改下布局




    

    

    

很明显B挨着底部了,没有10dp间距,这样跟设计图不符,这时候有朋友在想我给B设置个marginBottom=10dp不就行了,雀氏在C控件不显示情况下没有问题,C控件显示是不是间距就是20dp了?




    

    

    

等会,抽支烟冷静下。这时候就有了goneMargin了,顾名思义,就是在约束布局中对于控件设置了gone时该属性起效。我们先改下代码看下效果:
 




    

    

    

是不是就有了,这个属性是针对可见属性设置的,如果约束的控件不可见(C)该属性起效。

有人在想如果这时候c可见了会不会跟上面一样20dp间距,骚年别慌,看下面代码就知道了
 




    

    

    

总结:cons布局功能虽然强大,但是使用过程中还是有许多细节地方需要注意的,比如ScroolView嵌套cons,cons高度最好建议设置成match_partent(如果cons中还有rv显示不全的话也设置match_partent),此外对于goneMarin属性的其他方向间距是类似的(说明:不是说只能用goneMargin才能实现上面效果)。如果此篇文章有帮助到你,就请给个赞吧!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5686679.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-17
下一篇 2022-12-17

发表评论

登录后才能评论

评论列表(0条)

保存