通过RelativeLayout.LayoutParams.addRule()方法在代码中设置RelativeLayout相关属性

本文介绍如何使用RelativeLayout.LayoutParams.addRule()方法动态调整布局属性。通过两种重载方式,可以在不同条件下设置节点的位置关系。

1. 原理说明:

      我们知道,在 RelativeLayout 布局中有很多特殊的属性,通常在载入布局之前,在相关的xml文件中进行静态设置即可。

      但是,在有些情况下,我们需要动态设置布局的属性,在不同的条件下设置不同的布局排列方式,这时候就需要用到 RelativeLayout.LayoutParams.addRule() 方法,该方法有两种重载方式:

  • addRule(int verb) :用此方法时,所设置节点的属性不能与其它兄弟节点相关联或者属性值为布尔值(布尔值的属性,设置时表示该属性为 true,不设置就默认为 false),比如:addRule(RelativeLayout.CENTER_VERTICAL)  就表示在 RelativeLayout 中的相应节点是垂直居中的。
  • addRule(int verb, int anchor) :该方法所设置节点的属性必须关联其它的兄弟节点或者属性为布尔值( 属性为布尔值时,anchor 为 RelativeLayout.TRUE 表示 true,anchor 为0表示 false),比如:addRule(RelativeLayout.ALIGN_LEFT, R.id.date) 就表示 RelativeLayout 中的相应节点放置在一个 id 值为 date 的兄弟节点的左边。

 2. 基本流程实例:

        // ... ...
        View view = parentView.findViewById(R.id.subject);
        RelativeLayout.LayoutParams params = (RelativeLayout.LayoutParams) view
                .getLayoutParams();
        params.addRule(RelativeLayout.ALIGN_RIGHT, R.id.date);
        // params.addRule(RelativeLayout.CENTER_IN_PARENT);
        view.setLayoutParams(params);

         //... ...


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、付费专栏及课程。

余额充值