RelativeLayout的addRule方法

本文深入探讨了Android开发中RelativeLayout布局的原理和使用方法,包括LayoutParams类的构造函数及addRule方法,详解如何通过设置参数实现不同类型的相对布局。

 RelativeLayout,顾名思义,就是以“相对”位置/对齐 为基础的布局方式。android.widget.RelativeLayout 有个 继承自android.view.ViewGroup.LayoutParams 的内嵌类 LayoutParams,使用这个类的实例调用 RelativeLayout.addView 就可以实现“相对布局”。

  android.widget.RelativeLayout.LayoutParams 有一个构造函数:RelativeLayout.LayoutParams(int w, int h),参数指定了子 View 的宽度和高度,这一点和其父类是一样的。而实现相对布局的关键在它的 两个 addRule 方法上。anchor 参数指定可以是 View 的 id(“相对于谁”)、RelativeLayout.TRUE(启用某种对齐方式) 或者 是-1(应用于某些不需要 anchor 的 verb);AddRule 方法的 verb 参数指定相对的“动作”(以下常量均定义于 android.widget.RelativeLayout中,为了简便不给出其全名):

  ALIGN_BOTTOM、ALIGN_LEFT、 ALIGN_RIGHT、 ALIGN_TOP: 本 View 的 底边/左边/右边/顶边 和 anchor 指定的 View 的 底边/左边/右边/顶边 对齐。
ALIGN_WITH_PARENT_BOTTOM 、ALIGN_WITH_PARENT_LEFT 、  ALIGN_WITH_PARENT_RIGHT 、 ALIGN_WITH_PARENT_TOP : 和上面一组常量类似,只不过不需要再指定 anchor, 其 anchor 自动为 Parent View。
CENTER_HORIZONTAL、CENTER_IN_PARENT 、CENTER_VERTICAL : 如果 anchor 为 TRUE,在 Parent 中 水平居中/水平和垂直均居中/垂直居中。
POSITION_ABOVE 、POSITION_BELOW 、 POSITION_TO_LEFT 、POSITION_TO_RIGHT  : 本 View  位于 anchor 指定的 View 的 上边/下边/左边/右边。

val newLp = when (val lp = srcLp) { is ConstraintLayout.LayoutParams -> { ConstraintLayout.LayoutParams(srcLp.width, srcLp.height).apply { // 自定义尺寸(可根据需要修改) width = srcLp.width height = srcLp.height // 边距 marginStart = srcLp.marginStart topMargin = srcLp.topMargin marginEnd = srcLp.marginEnd bottomMargin = srcLp.bottomMargin // Bias horizontalBias = srcLp.horizontalBias verticalBias = srcLp.verticalBias // 圆形约束(如果未使用可省略) circleConstraint = srcLp.circleConstraint circleRadius = srcLp.circleRadius circleAngle = srcLp.circleAngle // MatchConstraint 设置 matchConstraintPercentWidth = srcLp.matchConstraintPercentWidth matchConstraintPercentHeight = srcLp.matchConstraintPercentHeight matchConstraintDefaultWidth = srcLp.matchConstraintDefaultWidth matchConstraintDefaultHeight = srcLp.matchConstraintDefaultHeight // 所有约束连接关系 startToStart = srcLp.startToStart startToEnd = srcLp.startToEnd endToEnd = srcLp.endToEnd endToStart = srcLp.endToStart topToTop = srcLp.topToTop topToBottom = srcLp.topToBottom bottomToBottom = srcLp.bottomToBottom bottomToTop = srcLp.bottomToTop baselineToBaseline = srcLp.baselineToBaseline } } is RelativeLayout.LayoutParams -> { RelativeLayout.LayoutParams(srcLp).apply { width = srcLp.width height = srcLp.height leftMargin = srcLp.leftMargin topMargin = srcLp.topMargin rightMargin = srcLp.rightMargin bottomMargin = srcLp.bottomMargin // ✅ 复制所有相对规则 addRule(RelativeLayout.ALIGN_PARENT_LEFT, srcLp.getRules()[RelativeLayout.ALIGN_PARENT_LEFT]) addRule(RelativeLayout.ALIGN_PARENT_TOP, srcLp.getRules()[RelativeLayout.ALIGN_PARENT_TOP]) addRule(RelativeLayout.ALIGN_PARENT_RIGHT, srcLp.getRules()[RelativeLayout.ALIGN_PARENT_RIGHT]) addRule(RelativeLayout.ALIGN_PARENT_BOTTOM, srcLp.getRules()[RelativeLayout.ALIGN_PARENT_BOTTOM]) addRule(RelativeLayout.CENTER_IN_PARENT, srcLp.getRules()[RelativeLayout.CENTER_IN_PARENT]) addRule(RelativeLayout.CENTER_HORIZONTAL, srcLp.getRules()[RelativeLayout.CENTER_HORIZONTAL]) addRule(RelativeLayout.CENTER_VERTICAL, srcLp.getRules()[RelativeLayout.CENTER_VERTICAL]) // 可继续添加其他常用规则(按需扩展) addRule(RelativeLayout.LEFT_OF, srcLp.getRules()[RelativeLayout.LEFT_OF]) addRule(RelativeLayout.RIGHT_OF, srcLp.getRules()[RelativeLayout.RIGHT_OF]) addRule(RelativeLayout.ABOVE, srcLp.getRules()[RelativeLayout.ABOVE]) addRule(RelativeLayout.BELOW, srcLp.getRules()[RelativeLayout.BELOW]) addRule(RelativeLayout.ALIGN_BASELINE, srcLp.getRules()[RelativeLayout.ALIGN_BASELINE]) addRule(RelativeLayout.ALIGN_LEFT, srcLp.getRules()[RelativeLayout.ALIGN_LEFT]) addRule(RelativeLayout.ALIGN_TOP, srcLp.getRules()[RelativeLayout.ALIGN_TOP]) addRule(RelativeLayout.ALIGN_RIGHT, srcLp.getRules()[RelativeLayout.ALIGN_RIGHT]) addRule(RelativeLayout.ALIGN_BOTTOM, srcLp.getRules()[RelativeLayout.ALIGN_BOTTOM]) } } is ViewGroup.MarginLayoutParams -> { ViewGroup.MarginLayoutParams(lp).apply { width = lp.width height = lp.height leftMargin = lp.leftMargin topMargin = lp.topMargin rightMargin = lp.rightMargin bottomMargin = lp.bottomMargin } } else -> { ViewGroup.LayoutParams(lp).apply { width = lp.width height = lp.height } } }不需要传宽高
12-03
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值