我想制作一个表格布局,如下面的屏幕所示:
http://i53.tinypic.com/16hso6t.jpg
我可以使用代码创建此UI。但我想使用XML来实现它。我尝试了以下方法。
我尝试制作一个包含标题和标题的tablelayout。现在我有两行标题正在重复。
所以我在名为row1和row2的单独XML文件中创建了这两行。但是现在我不知道如何在代码中集成这三个。我知道有方法LayoutInflater.inflate()
来做,但我有两行diff类型的布局。请参阅下面的两行代码。请建议我应该采用什么方法来制作这种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>
答案 0 :(得分:0)
为什么你需要两个不同的行?
您可以在一个Xml中集成两行,因此在表视图中只能添加一行
答案 1 :(得分:0)
从查看图像我建议采取列表视图路线。将您的布局设为
R1Col1 R1Col2 R1Col3
R2 Looooong Col1
这应该适合你。
<强>更新强>
你list_item.xml看起来应该是这样的。
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/wrapper"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical">
<LinearLayout android:id="@+id/wrapper"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="horizontal">
<TextView android:id="@+id/tv1"
android:text="column1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>
<TextView android:id="@+id/tv2"
android:text="column2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>
<TextView android:id="@+id/tv3"
android:text="column3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>
</LinearLayout>
<TextView android:id="@+id/tv1"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:text="short description text for Title 0 comes here" />
</LinearLayout>
这是一个学习如何填充ListView
的示例