LinearLayout的child中layout_weight的使用(会 绘制俩次)

linearLayout中包含有weight的child时,linearLayout会measure两次:

第一次 测量 child 的 原始值:

第二次 测量 child 的 比重值:

然后将2次测量的值相加,得到child 的具体的宽 或 高。

//-----------------------------------------------------------------------------

我们假设 一个LinearLayout方向为横向android:orientation="horizontal" ,它有2个child,分别为 child_1 和 child_2。

我们来分析下 这2个child的宽度在带有layout_weight属性的情况下,值是怎么计算的。

第一次测量时:有自己的layout_width参数决定

首先,child的宽度(layout_width)有3种情况:0dp(具体值,可以随意设置,例如 100dp)、wrap_content、match_parent。

这3种情况,当应用加载到具体的手机上时,都会在测量时,变为具体的值,分别如下:

1,当child_1 的 layout_width 为 0dp,它的width_orginal 原始宽度为0pix;(100dp,则 width_orginal 为 屏幕密度density * 100 pix = X_1 pix)

  (其中手机屏幕密度 通过 context.getResources().getDisplayMetrics().density 获取)

2,当child_1 的 layout_width 为 wrap_content,它的width_orginal 原始宽度为 int_wrap_cotent(在具体的手机上是一个固定值,假设为 X_1  pix) ;

3,当child_1 的 layout_width 为 match_parent,它的width_orginal 原始宽度为手机屏幕的宽度(在具体的手机上是一个固定值,假设为 X_1 pix) ;

(child_2 的 原始宽度为  X_2)

第二次测量时:由所有的child 的 layout_weight 参数共同决定

假设 2个child的 layout_weight 分别为 weight_1 和 weight_2 (layout_weight 参数 是一个int类型值,可以为0):

那么 child_1 和 child_2 的最终宽度为:

child_1的宽度:X_1 + (手机屏幕宽度 - (X_1 + X_2))  * weight_1 / (weight_1+weight_2) = 最终宽度。

以下是几个例子:

demo1:child_1 和 child_2 的layout_width都为0dp,layout_weight分别为 1 和 2

 

 1 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 2     xmlns:tools="http://schemas.android.com/tools"
 3     android:id="@+id/root"
 4     android:layout_width="match_parent"
 5     android:layout_height="match_parent"
 6     android:orientation="horizontal" >
 7 
 8     <TextView
 9         android:id="@+id/tv_left"
10         android:layout_width="0dp"
11         android:layout_height="wrap_content"
12         android:layout_weight="1"
13         android:background="#00ff00"
15         android:text="child_1"
16         android:textSize="24sp" />
17 
18     <TextView
19         android:id="@+id/tv_right"
20         android:layout_width="0dp"
21         android:layout_height="wrap_content"
22         android:layout_weight="2"
23         android:background="#ff0000"
24 
25         android:text="child_2"
26         android:textSize="24sp" />
27 
28 </LinearLayout>

 

此时,child_1 的最终宽度为:0 pix + 屏幕宽度 * 1/3 = 1/3 的屏幕宽度。child_2 最终宽度为 2/3 的屏幕宽度。

所以想要按比例分配LinearLayout的children的宽(高)值,可以用次方法。

demo2:child_1 和 child_2 的layout_width都为100dp,layout_weight分别为 1 和 2。

 

 1 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 2     xmlns:tools="http://schemas.android.com/tools"
 3     android:id="@+id/root"
 4     android:layout_width="match_parent"
 5     android:layout_height="match_parent"
 6     android:orientation="horizontal" >
 7 
 8     <TextView
 9         android:id="@+id/tv_left"
10         android:layout_width="100dp"
11         android:layout_height="wrap_content"
12         android:layout_weight="1"
13         android:background="#00ff00"
14 
15         android:text="child_1"
16         android:textSize="24sp" />
17 
18     <TextView
19         android:id="@+id/tv_right"
20         android:layout_width="100dp"
21         android:layout_height="wrap_content"
22         android:layout_weight="2"
23         android:background="#ff0000"
24 
25         android:text="child_2"
26         android:textSize="24sp" />
27 
28 </LinearLayout>

 

此时,child_1 的最终宽度为:100 * density pix + (屏幕宽度 - 200 dp * density) * 1/3 = 。。。

demo2:child_1 和 child_2 的layout_width都为match_parent,layout_weight分别为 1 和 2。

 

 1 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
 2     xmlns:tools="http://schemas.android.com/tools"
 3     android:id="@+id/root"
 4     android:layout_width="match_parent"
 5     android:layout_height="match_parent"
 6     android:orientation="horizontal" >
 7 
 8     <TextView
 9         android:id="@+id/tv_left"
10         android:layout_width="match_parent"
11         android:layout_height="wrap_content"
12         android:layout_weight="1"
13         android:background="#00ff00"
14 
15         android:text="child_1"
16         android:textSize="24sp" />
17 
18     <TextView
19         android:id="@+id/tv_right"
20         android:layout_width="match_parent"
21         android:layout_height="wrap_content"
22         android:layout_weight="2"
23         android:background="#ff0000"
24 
25         android:text="child_2"
26         android:textSize="24sp" />
27 
28 </LinearLayout>

 

此时,child_1 的最终宽度为:屏幕宽度 + (屏幕宽度 - 2倍的屏幕宽度) * 1/3 = 2/3 的 屏幕宽度,child_2为 1/3 的屏幕宽度。

当 child 的 layout_width 都为 match_parent时,想要 child_1 : child_2 = 1 : 2(即 1/3 : 2/3),可以设置 child_1 child_2 的 layout_weight 为 (分母 - 1) : (分母 - 2).

当 child 的 layout_width 都为 match_parent时,想要child_1 : child_2 : child_3 = 3 : 4 : 5 (即 3/12 : 4/12: 5/12),可以设置layout_weight 分别为 (12-3):(12-4):(12-5)

 

转载:https://www.cnblogs.com/wangziqiang/p/4185208.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: `layout_weight` 是在 Android 用于布局的一个属性,它用于指定一个视图在布局所占用的权重。布局每个视图都有一个默认的权重为 `0`,当设置了 `layout_weight` 属性后,系统根据视图的权重和所在容器的剩余空间来计算视图的实际大小。一个视图的实际大小先根据自身的宽度或高度计算出来,然后再根据它的权重和其他视图的权重来分配剩余的空间。因此,通过设置 `layout_weight` 属性,可以实现在布局更灵活的视图排列和分配。 ### 回答2: layout_weight是Android布局的一个属性,用于控制视图在父布局的相对权重。 在LinearLayout,父布局必须为水平或垂直方向,子视图的layout_weight属性决定它们在父布局所占的比例。例如,如果有两个子视图,一个layout_weight为1,另一个为2,那么第一个子视图将占据父布局的1/3,而第二个子视图将占据2/3。 在RelativeLayoutlayout_weight属性无效,这是因为RelativeLayout是根据视图之间的关系来布局的。不过,可以结合使用其他属性来达到类似的效果。 layout_weight属性常用于构建灵活的布局,例如等分屏幕的两个或多个部分,或者按比例调整视图的大小。通过合理设置layout_weight,可以实现适应不同屏幕尺寸和方向的布局。 需要注意的是,更高的layout_weight并不一定意味着更大的视图,而是表示相对权重的增加。要实现适应不同分辨率的布局,还需要考虑使用dp和match_parent等属性。 综上所述,layout_weight是一种用于控制视图在父布局相对权重的属性,可以帮助实现灵活的布局。了解并熟练使用该属性,可以更好地适配不同屏幕和实现更好的用户界面体验。 ### 回答3: layout_weight是android用于布局控制的一个属性。该属性只能在LinearLayout使用layout_weight用于控制View在父容器的分配空间比例。在LinearLayout,如果某个方向的width或height设置为0dp(match_parent也可以),并且设置了layout_weight属性,那么这个View将根据layout_weight的值来分配父容器剩余的空间。 假设有一个水平方向的LinearLayout,其包含了两个子View:View1和View2。如果View1的layout_weight设置为1,View2的layout_weight设置为2,那么View1将占据1/3的水平空间,而View2将占据2/3的水平空间。 另外,如果在设置了layout_weight的View,将width或height设置为0dp,它将以所占比例的形式拉伸或压缩来填充剩余空间。例如,如果View1的layout_weight设置为1,width设置为0dp,而View2的layout_weight设置为2,width设置为wrap_content,那么View1将占据1/3的水平空间,并且被拉伸或压缩以填充剩余的空间,而View2将根据内容自动调整宽度。 总结来说,layout_weight属性允许我们在LinearLayout根据所设置的权重值来分配剩余的空间,从而实现不同比例的布局效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值