(1)TableLayout:
可以使用
android:stretchColumns="0,3"使左右最边上两个列允许别拉伸
例如:
<?xml version="1.0" encoding="utf-8"?>
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/tablelayout1"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/loginbg"
android:gravity="center_vertical"
android:stretchColumns="0,3" >
<!--
android:stretchColumns="0,3"
第一列和第四列设置允许被拉伸,是为了让用户登录表单在水平方向上居住显示
-->
<!-- 第一行 -->
<TableRow
android:id="@+id/tablerow1"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
<TextView />
<TextView
android:id="@+id/textview1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="用户名:" />
<EditText
android:id="@+id/edittext1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:minWidth="200px"
android:textSize="24px" />
<TextView />
</TableRow>
<!-- 第二行 -->
<TableRow
android:id="@+id/tablerow2"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
<TextView />
<TextView
android:id="@+id/textview2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="密码"
android:textSize="24px" />
<EditText
android:id="@+id/edittext2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:inputType="textPassword"
android:minWidth="200px"
android:textSize="24px" />
<TextView />
</TableRow>
<TableRow
android:id="@+id/tablerow2"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
<TextView />
<TextView />
<Button
android:id="@+id/button1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="登录"
android:textSize="24px" />
<TextView />
</TableRow>
</TableLayout>
RelativeLayout 内容居中解决办法:
使用Linearlayout本来利用父控件的gravity属性是很好解决的。
但是对应RelativeLayout虽然有gravity属性,
但是如果你使用,你会发现实际他是不能生效的。
解决办法:
在RelativeLayout的子空间里,使用以下3个属性就行了。
gravity 一般是针对linearlayout会使用很方便。