先看如下布局 :
上图中,按钮的大小为屏幕的一半,然后居中显示在布局中央,每个人心中都有自己的答案,看看我的方法吧,布局布局xml如下 :
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/main_layout" android:layout_width="match_parent" android:layout_height="match_parent" android:baselineAligned="false" android:gravity="center" android:orientation="horizontal" android:weightSum="1" > <!-- 1.将LinearLayout的layout_weight设置为1 --> <!-- 2.将Button的layout_width设为0dp, 并且将layout_weight设置为0.5 --> <Button android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="0.5" android:textSize="13sp" android:text="@string/button_text" > </Button> </LinearLayout>
这里有几个关键点:
- 布局为LinearLayout,以便可以设置layout_weight;
- 设置LinearLayout的android:weightSum的值为1;
- 将Button的layout_width设置为0dp;
- 将Button的layout_weight的值设置为0.5, 即上面的android:weightSum的一半。
通过上面的设置就可以实现上图中的布局了。子空间的宽度算法可以参考如下公式, 子控件宽度 = 子控件layout_width + 子控件的layout_weight * 父控件的宽度 / 父控件的layout_weight, 对比上面的例子就是子控件的宽度 = 0.5 * 父控件的宽度 / 1 = 父控件宽度 * 0.5, 因为父控件的宽度为match_parent,所以父控件宽度的宽度为整个屏幕的宽度,所以子控件的宽度 = 0.5 * 整个屏幕的宽度 = 半屏宽度。
Android中设置半个屏幕大小且居中的按钮布局 (layout_weight属性)
时间: 2024-10-05 00:33:33