先看如下布局 :
上图中,按钮的大小为屏幕的一半,然后居中显示在布局中央,每个人心中都有自己的答案,看看我的方法吧,布局布局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 * 整个屏幕的宽度 = 半屏宽度。