以下是我的XML for LAND格式的一部分:
<TableLayout
android:layout_height="wrap_content"
android:layout_width="wrap_content"
android:layout_gravity="center"
android:stretchColumns="*">
<TableRow>
<Button
android:id="@+id/countbutton"
android:text="@string/plus1"/>
<Button
android:id="@+id/resetbutton"
android:text="@string/reset"
/>
</TableRow>
</TableLayout>
现在我得到的东西 - 一行的宽度和按钮的宽度取决于按钮内的TEXT。如果这两个文本都是等长的,那就说:TEXT它没关系 - 表格的一半位于屏幕中间。但如果它们有不同的尺寸 - 让我们说“A”和“这就是长按钮”,桌子的中心不再在屏幕的中间,所以按钮的宽度不一样......
答案 0 :(得分:89)
要在按钮大小相同的行中设置按钮,需要执行此操作。
<LinearLayout android:orientation="horizontal"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
<Button android:layout_weight="1"
android:layout_height="wrap_content"
android:layout_width="0dip"/>
<Button android:layout_weight="1"
android:layout_height="wrap_content"
android:layout_width="0dip"/>
</LinearLayout>
并填写按钮的其他xml属性。
魔术在layout_weight和width属性中。您不需要表格布局。这些属性告诉布局您的视图应占用父布局中相等的空间。
答案 1 :(得分:4)
很好的例子(最初来自http://androidadvice.blogspot.com/2010/10/tablelayout-columns-equal-width.html)
经过测试和工作:
<TableRow>
<!-- Column 1 -->
<TextView
android:id="@+id/tbl_txt1"
android:layout_width="0dip"
android:layout_height="wrap_content"
android:background="@color/red"
android:textColor="@color/white"
android:padding="10dip"
android:layout_margin="4dip"
android:layout_weight="1"
android:text="Column 1" />
<!-- Column 2 -->
<TextView
android:id="@+id/tbl_txt2"
android:layout_width="0dip"
android:layout_height="wrap_content"
android:background="@color/red"
android:textColor="@color/white"
android:padding="10dip"
android:layout_margin="4dip"
android:layout_weight="1"
android:text="Column 2" />
<!-- Column 3 -->
<TextView
android:id="@+id/tbl_txt3"
android:layout_width="0dip"
android:layout_height="wrap_content"
android:background="@color/red"
android:textColor="@color/white"
android:padding="10dip"
android:layout_margin="4dip"
android:layout_weight="1"
android:text="Column 3" />
</TableRow>
答案 2 :(得分:2)
除了接受的答案:
我遇到了类似的问题,我在网格中需要多个图像,列宽相等,所以我使用了表格布局。它工作正常,但是当图像异步加载时,相应的列将占据整个宽度,直到所有列中都包含至少一个图像。
我使用Robby Pond的解决方案解决了这个问题,但它最后一行没有用,它不一定拥有与其他行一样多的图像,当我想要它们时,将这些图像拉伸以占用所有可用空间适合与上面相同的列。为了解决这个问题,我用常规的View对象
填充了该行的剩余空列使用与所有其他图像相同的布局参数:
width = 0, weight = 1.
这就解决了!
答案 3 :(得分:1)
首先,您需要将android:stretchColumns="*"
添加到TableLayout。
每个TableRow必须具有android:layout_weight="1"
才能相等。
TableRow中的每个按钮都必须具有android:layout_width="0dp"
。
这是一些例子
<TableLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:stretchColumns="*"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent">
<TableRow
android:layout_height="wrap_content"
android:layout_weight="1">
<Button
android:id="@+id/button1"
android:layout_width="0dp"
android:layout_height="match_parent"
android:onClick="onButtonClick"
android:text="@string/button1" />
<Button
android:id="@+id/button2"
android:layout_width="0dp"
android:layout_height="match_parent"
android:onClick="onButtonClick"
android:text="@string/button2" />
</TableRow>
<TableRow
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1">
<Button
android:id="@+id/button3"
android:layout_width="0dp"
android:layout_height="match_parent"
android:onClick="onButtonClick"
android:text="@string/button3" />
<Button
android:id="@+id/button4"
android:layout_width="0dp"
android:layout_height="match_parent"
android:onClick="onButtonClick"
android:text="@string/button4" />
</TableRow>
</TableLayout>
答案 4 :(得分:0)
布局代码段
<TableLayout
android:id="@+id/tablelayout"
android:layout_width="match_parent"
android:layout_height="match_parent" />
以编程方式设置表格中按钮布局属性的代码:
public void addButtons(View view) {
TableLayout tableLayout = (TableLayout) findViewById(R.id.tablelayout);
Context context = getApplicationContext();
tableLayout.removeAllViews();
for (int rowIndex = 0; rowIndex < ROWS; rowIndex++) {
TableRow row = new TableRow(context);
for (int columnIndex = 0; columnIndex < COLUMNS; columnIndex++) {
Button btn = new Button(context);
LayoutParams buttonParams = new LayoutParams(0,
LayoutParams.WRAP_CONTENT, 1f);
btn.setLayoutParams(buttonParams);
row.addView(btn);
}
tableLayout.addView(row);
}
}
答案 5 :(得分:0)
尝试一下:经过测试并可以正常工作:
1)对于 tablelayout ,设置 android:stretchColumns =“ 1”
2)还设置每个项目(列) layout_width =“ 0dip”和layout_weight =“ 1”
3)并且不要设置 tablerow
的layout_width <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent"
android:layout_height="match_parent" android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:paddingBottom="@dimen/activity_vertical_margin"
tools:context="inext.smartshop.CustomerProfile.CustomerProfileView">
<RelativeLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content">
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/tablelayout"
android:stretchColumns="1"
android:layout_above="@+id/userProfilebtnsignout"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true"
android:layout_alignParentRight="true"
android:layout_alignParentEnd="true"
android:layout_below="@+id/relativeLayout">
<TableRow
android:layout_height="fill_parent"
android:padding="5dp"
android:id="@+id/detailsTableRow"
android:gravity="center_horizontal">
<TextView
android:layout_height="wrap_content"
android:textAppearance="?android:attr/textAppearanceSmall"
android:text="Full Name : "
android:layout_width="0dip"
android:layout_weight="1"
android:id="@+id/textView8"
android:gravity="right" />
<TextView
android:layout_width="0dip"
android:layout_weight="1"
android:layout_height="wrap_content"
android:textAppearance="?android:attr/textAppearanceSmall"
android:text="Ram Chhabra"
android:id="@+id/userProfilename"
android:gravity="left" />
</TableRow>
<TableRow android:padding="5dp"
android:layout_height="wrap_content">
<TextView
android:layout_width="0dip"
android:layout_weight="1"
android:layout_height="wrap_content"
android:textAppearance="?android:attr/textAppearanceSmall"
android:text="Email Address : "
android:id="@+id/textView10"
android:gravity="right" />
<TextView
android:layout_width="0dip"
android:layout_weight="1"
android:layout_height="wrap_content"
android:textAppearance="?android:attr/textAppearanceSmall"
android:text="RAMCHHABRA0012@GMAIL.COM"
android:id="@+id/userProfileemail"
android:gravity="left"
/>
</TableRow>
<TableRow android:padding="5dp">
<TextView
android:layout_width="0dip"
android:layout_weight="1"
android:layout_height="wrap_content"
android:textAppearance="?android:attr/textAppearanceSmall"
android:text="Contact No 1 : "
android:id="@+id/textView12"
android:gravity="right" />
<TextView
android:layout_width="0dip"
android:layout_weight="1"
android:layout_height="wrap_content"
android:textAppearance="?android:attr/textAppearanceSmall"
android:text="8130032232"
android:id="@+id/userProfilecontactone"
/>
</TableRow>
</TableLayout>
</RelativeLayout>
</RelativeLayout>