android - 带 TableView 的图标菜单(类似 Google+)

标签 android android-tablelayout

我正在为我的 Android 应用程序开发基于图标的主菜单(参见附图 - Google+)。显而易见的布局是 TableLayout。

Google+ Android App

但是,我不知道也找不到关于如何将表格本身和里面的图标居中的信息。我想出的代码如下(结果图像在代码下方):

<TableLayout android:layout_width="fill_parent" android:id="@+id/tableLayout1" android:layout_height="fill_parent" android:stretchColumns="1" android:padding="20dp">
    <TableRow android:id="@+id/tableRow1" android:layout_width="fill_parent" android:layout_height="fill_parent" android:padding="20dp"  >
        <Button android:text="Button" android:id="@+id/button1" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center"></Button>
        <Button android:text="Button" android:id="@+id/button2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center"></Button>
    </TableRow>
    <TableRow android:id="@+id/tableRow2" android:layout_width="fill_parent" android:layout_height="fill_parent" android:padding="20dp" >
        <Button android:text="Button" android:id="@+id/button3" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center" ></Button>
        <Button android:text="Button" android:id="@+id/button2" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center"></Button>
    </TableRow>
</TableLayout>

TableLayout

我将不胜感激任何提示和想法。

最佳答案

我刚做了一个你需要的程序主菜单。它与密度无关,但我把它放在 ScrollView 上只是为了确保它在任何地方都可用。 如果愿意,您可以将按钮更改为图像按钮,这样您就可以获得所需的菜单。

对代码的一点解释:

  • 每一行在左边和右边都有一个 TextView ,作为占位符。 tablelayout'a android:stretchColumns="0,3"拉伸(stretch) TextView 以填充按钮旁边的空间。
  • 您可以更改边距,使按钮之间的距离更近或更远。

现在这是 xml:

<?xml version="1.0" encoding="utf-8"?>
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
    <TableLayout android:layout_gravity="center" 
        android:layout_width="match_parent" android:layout_height="match_parent"
        android:stretchColumns="0,3">
        <TableRow android:layout_gravity="center">
            <TextView />
            <Button android:text="1" android:layout_margin="15dp"
                android:layout_gravity="center_vertical"
                android:width="100dip" android:height="100dip" />
            <Button android:layout_gravity="center_vertical" 
                android:text="2" android:layout_margin="15dp"
                android:width="100dip" android:height="100dip" />
            <TextView />
        </TableRow>

        <TableRow android:layout_gravity="center">
            <TextView />
            <Button android:text="3"  android:layout_margin="15dp"
                android:layout_gravity="center_vertical"
                android:width="100dip" android:height="100dip" />
            <Button android:text="4"  android:layout_margin="15dp"
                android:layout_gravity="center_vertical"
                android:width="100dip" android:height="100dip" />
            <TextView />
        </TableRow>

        <TableRow android:layout_gravity="center">
            <TextView />
                <Button android:text="5"  android:layout_margin="15dp"
                android:layout_gravity="center_vertical"
                android:width="100dip" android:height="100dip" />
            <Button android:text="6"  android:layout_margin="15dp"
                android:layout_gravity="center_vertical"
                android:width="100dip" android:height="100dip" />
            <TextView />
        </TableRow>
    </TableLayout>
</ScrollView>

这就是它的样子: http://db.tt/yQ5NFhmk

关于android - 带 TableView 的图标菜单(类似 Google+),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7788034/

相关文章:

Android ACTION_VIEW 多张图片

android - Facebook Android SDK - 应用程序请求不会重定向到 Google Play 商店

android - 无法在表格布局中居中 TextView

Android tablelayout 行填充

java - fragment 中级 (II) :Dynmically adding row in a fragment, Android

android - 如何删除 Android 上 ListView 之间的线条?

android - 如何有效地在 gridview 中加载互联网图像?

android - Activity 开始时黑屏 5-10 秒

java - 获取焦点单元格的索引并以编程方式设置焦点

android - 如何根据大小在表格行中显示图像