关于android layout_weight的疑问

layout_weight

linearLayout布局中,有一个属性为layout_weight,代表着权重。例如代码

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"

    android:orientation="horizontal"

    android:layout_width="fill_parent"

    android:layout_height="fill_parent"

    >

<TextView 

    android:layout_width="wrap_content"

    android:layout_height="wrap_content"

    android:text="@string/hello"

    />

<Button

    android:layout_width="wrap_content"

    android:layout_height="wrap_content"

    android:text="@string/button1"

    android:layout_weight="1"

/>

<Button

    android:layout_width="wrap_content"

    android:layout_height="wrap_content"

    android:text="@string/button2"

    android:layout_weight="1"

/>

从代码中我们可以看出,布局应该是先让textView展开,然后对于剩余的空间,按照权重1:1分配给两个Button

(权重数字越小,说明占的空间越大,如果button1layout_weight=1,button2layout_weight=2,则说明剩余的空间2/3button1,1/3button2)。

但是,经过测试发现,这种说法并不是完全正确的。上面的代码,执行的当,@string/button1@string/button1长度相同时,确实正确。如图:

现在,我们将按钮2的字符串加长,出现的结果为:

我们明显的可以看到,textview的长度是没有任何变化的,但是两个按钮的长度却发生了很大的变化,这在代码编写过程中势必会引起误会。权重失效了吗?

从目测的结果来看,基本上是1/3的分配给了按钮1,2/3分配给了按钮2.造成这种现象的问题究竟是什么呢?

猜测:有按钮上字符串的个数我们可以明确的看到,如果都按照wrap_content都显示出来的话,按钮2一定是按钮1长度的两倍(这里假设手机屏幕足够长)。而这里权重的1:1应该是这种意思:

       假如剩余屏幕长度为a,按钮1wrap_content长度为b1,按钮2wrap_content长度为b2。那么这里的权重一比一,对按钮1来说应该是b1/a,对按钮2来说应该是b2/a,至于b1b2是否相等,那就不重要了。重要的是权重11的理解方式。

等待高人帮忙解答!

 

 

 

<?xml version="1.0" encoding="utf-8"?> <androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" android:layout_width="match_parent" android:layout_height="match_parent"> <androidx.swiperefreshlayout.widget.SwipeRefreshLayout android:id="@+id/home_swiperefresh" android:layout_width="match_parent" android:layout_height="match_parent" > <androidx.recyclerview.widget.RecyclerView android:id="@+id/home_recyclerview" android:layout_width="match_parent" android:layout_height="match_parent" /> </androidx.swiperefreshlayout.widget.SwipeRefreshLayout> <androidx.appcompat.widget.Toolbar android:layout_width="match_parent" android:layout_height="80dp" app:layout_constrainTop_toTopOf="parent" > <LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" android:gravity="center_vertical" android:orientation="horizontal" > <ImageView android:layout_width="wrap_content" android:layout_height="wrap_content" android:src="@drawable/ic_home_scan_24"/> <TextView android:layout_width="0dp" android:layout_height="wrap_content" android:layout_marginStart="8dp" android:layout_marginEnd="18dp" android:layout_weight="1" android:background="@color/white" android:cursorVisible="false" android:focusable="false" android:hint="搜索" android:minHeight="30dp" android:textSize="16dp" /> </LinearLayout> </androidx.appcompat.widget.Toolbar> </androidx.constraintlayout.widget.ConstraintLayout>
07-17
### 回答1: `layout_weight` 是在 Android 中用于布局的一个属性,它用于指定一个视图在布局中所占用的权重。布局中每个视图都有一个默认的权重为 `0`,当设置了 `layout_weight` 属性后,系统会根据视图的权重和所在容器的剩余空间来计算视图的实际大小。一个视图的实际大小会先根据自身的宽度或高度计算出来,然后再根据它的权重和其他视图的权重来分配剩余的空间。因此,通过设置 `layout_weight` 属性,可以实现在布局中更灵活的视图排列和分配。 ### 回答2: layout_weightAndroid布局中的一个属性,用于控制视图在父布局中的相对权重。 在LinearLayout中,父布局必须为水平或垂直方向,子视图的layout_weight属性决定它们在父布局中所占的比例。例如,如果有两个子视图,一个layout_weight为1,另一个为2,那么第一个子视图将占据父布局的1/3,而第二个子视图将占据2/3。 在RelativeLayout中,layout_weight属性无效,这是因为RelativeLayout是根据视图之间的关系来布局的。不过,可以结合使用其他属性来达到类似的效果。 layout_weight属性常用于构建灵活的布局,例如等分屏幕的两个或多个部分,或者按比例调整视图的大小。通过合理设置layout_weight,可以实现适应不同屏幕尺寸和方向的布局。 需要注意的是,更高的layout_weight并不一定意味着更大的视图,而是表示相对权重的增加。要实现适应不同分辨率的布局,还需要考虑使用dp和match_parent等属性。 综上所述,layout_weight是一种用于控制视图在父布局中相对权重属性,可以帮助实现灵活的布局。了解并熟练使用该属性,可以更好地适配不同屏幕和实现更好的用户界面体验。 ### 回答3: layout_weightandroid中用于布局控制的一个属性。该属性只能在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中根据所设置的权重值来分配剩余的空间,从而实现不同比例的布局效果。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值