android应用程序中listview下的按钮

时间:2013-10-24 00:05:34

标签: android listview android-listview

我需要在列表视图下方显示按钮。任何帮助将不胜感激。我已经尝试了不同的方法让这个特定的布局在android上正确显示,但到目前为止我还没有弄清楚这一点。我希望能够在应用程序中间显示列表视图,并在列表视图下方有按钮。问题是我还需要在列表视图顶部的屏幕上显示其他内容,例如制表符和微调器。列表视图中的所有项目都将包含图像和图像右侧的一些文本。我想要实现的图像就像这张图片......

android layout image

到目前为止,这是我的代码......

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:maxLines="100"
    android:orientation="vertical"
    android:scrollbars="vertical" >

    <Button
        android:id="@+id/readWebpage"
        android:layout_width="match_parent"
        android:layout_height="40dp"
        android:onClick="onClick"
        android:text="Load Webpage" >
    </Button>

    <LinearLayout
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:maxLines="100"
        android:gravity="center"
        android:layout_centerHorizontal="true"
        android:layout_centerInParent="true"
        android:orientation="horizontal">

        <Spinner
            android:id="@+id/genre"
            android:entries="@array/genre_list"
            android:layout_weight="0.40"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_centerHorizontal="true"
            android:layout_marginTop="1dp" />

        <Spinner
            android:id="@+id/sort"
            android:entries="@array/sort_list"
            android:layout_weight="0.40"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_centerHorizontal="true"
            android:layout_marginTop="1dp" />

        <Spinner
            android:id="@+id/page"
            android:entries="@array/page_list"
            android:layout_weight="0.20"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_centerHorizontal="true"
            android:layout_marginTop="1dp" />

    </LinearLayout>

    <LinearLayout
          android:orientation="vertical"
          android:layout_width="fill_parent"
          android:layout_height="fill_parent">

        <ListView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:id="@+id/listView" />

        <Button
            android:id="@+id/previousPage"
            android:layout_weight="0.50"
            android:layout_width="0dp"
            android:layout_height="40dp"
            android:onClick="onClick"
            android:layout_alignParentBottom="true"
            android:text="Previous Page" >
        </Button>

        <Button
            android:id="@+id/nextPage"
            android:layout_weight="0.50"
            android:layout_width="0dp"
            android:layout_height="40dp"
            android:onClick="onClick"
            android:layout_alignParentBottom="true"
            android:text="Next Page" >
        </Button>

    </LinearLayout>

</LinearLayout>

3 个答案:

答案 0 :(得分:0)

使用RelativeLayout来控制ListView

的位置
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent" >
    <Button
        android:id="@+id/readWebpage"
        android:layout_width="match_parent"
        android:layout_height="40dp"
        android:onClick="onClick"
        android:text="Load Webpage" >
    </Button>
    <LinearLayout
        android:id="@+id/spinner"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_below="@+id/readWebpage"
        android:layout_marginTop="1dp"
        android:orientation="horizontal" >
        <Spinner
            android:id="@+id/genre"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="0.40"
            android:entries="@array/genre_list" />
        <Spinner
            android:id="@+id/sort"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="0.40"
            android:entries="@array/sort_list" />
        <Spinner
            android:id="@+id/page"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_weight="0.20"
            android:entries="@array/page_list" />
    </LinearLayout>
    <ListView
        android:id="@+id/listView"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_above="@+id/button"
        android:layout_below="@+id/spinner" />
    <LinearLayout
        android:id="@+id/button"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:orientation="horizontal" >
        <Button
            android:id="@+id/previousPage"
            android:layout_width="0dp"
            android:layout_height="40dp"
            android:layout_weight="0.50"
            android:onClick="onClick"
            android:text="Previous Page" >
        </Button>
        <Button
            android:id="@+id/nextPage"
            android:layout_width="0dp"
            android:layout_height="40dp"
            android:layout_weight="0.50"
            android:onClick="onClick"
            android:text="Next Page" >
        </Button>
    </LinearLayout>
</RelativeLayout>

答案 1 :(得分:0)

将按钮的layout_weight设置为0,然后将listview的layout_weight设置为1. layout_weight用于分配额外的空间,因此按钮将保持40dip高度,listview将展开以占用剩余空间

答案 2 :(得分:0)

使用以下代码;

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:maxLines="100"
    android:orientation="vertical"
    android:scrollbars="vertical" >

    <Button
        android:id="@+id/readWebpage"
        android:layout_width="match_parent"
        android:layout_height="40dp"
        android:onClick="onClick"
        android:text="Load Webpage" >
    </Button>

    <LinearLayout
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_centerHorizontal="true"
        android:layout_centerInParent="true"
        android:gravity="center"
        android:maxLines="100"
        android:orientation="horizontal" >

        <Spinner
            android:id="@+id/genre"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_centerHorizontal="true"
            android:layout_marginTop="1dp"
            android:layout_weight="0.40"
            android:entries="@array/genre_list" />

        <Spinner
            android:id="@+id/sort"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_centerHorizontal="true"
            android:layout_marginTop="1dp"
            android:layout_weight="0.40"
            android:entries="@array/sort_list" />

        <Spinner
            android:id="@+id/page"
            android:layout_width="0dp"
            android:layout_height="wrap_content"
            android:layout_centerHorizontal="true"
            android:layout_marginTop="1dp"
            android:layout_weight="0.20"
            android:entries="@array/page_list" />
    </LinearLayout>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical" >

        <ListView
            android:id="@+id/listView"
            android:layout_weight="3"
            android:layout_width="match_parent"
            android:layout_height="match_parent" />

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="horizontal"
            android:layout_weight="1" >

            <Button
                android:id="@+id/previousPage"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_alignParentBottom="true"
                android:layout_weight="1"
                android:onClick="onClick"
                android:text="Previous Page" >
            </Button>

            <Button
                android:id="@+id/nextPage"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_alignParentBottom="true"
                android:layout_weight="1"
                android:onClick="onClick"
                android:text="Next Page" >
            </Button>
        </LinearLayout>
    </LinearLayout>

</LinearLayout>