【发布时间】:2019-08-13 01:07:59
【问题描述】:
我想制作如下屏幕所示的表格布局:
我可以使用代码制作这个 UI。但我想使用 XML 来实现。我尝试了以下方法。
我尝试制作一个包含标题和标题的表格布局。现在我在标题下方有两行重复。
所以我在名为 row1 和 row2 的单独 XML 文件中创建了这两行。但是现在我不知道如何将这三个集成到代码中。我知道有方法LayoutInflater.inflate() 可以做到这一点,但我有两行布局不同。请参阅下面的两行代码。请建议我应该遵循什么方法来制作这种 UI。
ROW_1.xml:
<?xml version="1.0" encoding="utf-8"?>
<TableRow xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/table_row"
android:minHeight="30dip"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@color/light_grey"
android:clickable="true"
>
<TextView android:id="@+id/tv1"
android:text="column1"
android:gravity="center"
android:textColor="@color/black"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingLeft="5dip"
android:paddingRight="5dip"
/>
<TextView android:id="@+id/tv2"
android:text="column2"
android:gravity="center"
android:textColor="@color/black"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingLeft="5dip"
android:paddingRight="5dip"
/>
<TextView android:id="@+id/tv3"
android:text="column3"
android:gravity="center"
android:textColor="@color/black"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:paddingLeft="5dip"
android:paddingRight="5dip"
/>
</TableRow>
ROW_2.xml
<?xml version="1.0" encoding="utf-8"?>
<TableRow xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/table_row"
android:minHeight="30dip"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:background="@color/light_grey"
android:clickable="true"
>
<TextView android:id="@+id/tv1"
android:text="short description text for Title 0 comes here"
android:paddingLeft="5dip"
android:paddingRight="5dip"
android:gravity="center"
android:textColor="@color/black"
/>
</TableRow>
【问题讨论】:
-
你不能用 ListView 代替。您可以为不同的行提供不同的 xml。
-
我可以在哪里粘贴我的图片以提供链接?与表格布局相比,gridview 有什么好处。我可以使用代码制作 UI 但我认为使用 xml 制作它会更好,因为将来 UI 的任何更改都只需要更改 xml 部分。但不知道如何使用xml。
-
@Sam Quest:列表视图是否提供与表格相同的外观。我需要制作一个表格,其中第一行包含 3 列。第二行包含跨越所有三行的一列。现在我需要将这两行视为一个元素。它继续重复。列表视图是否适合这种视图。
-
那么您可以将两行视为一个ListItem(一行)。行数是已知的吗?
-
@Sam Quest:最初不知道行数。数据将来自服务器。