Макет Android с ListView и кнопками - PullRequest
101 голосов
/ 05 марта 2010

Хорошо, этот конкретный макет меня просто раздражает. И я не могу найти способ иметь listView с рядом кнопок в нижней части, чтобы представление списка не выходило за верхнюю часть кнопок, и чтобы кнопки всегда были привязаны к нижней части экрана. Вот что я хочу:

удалена мертвая ссылка ImageShack

Кажется, это должно быть так просто, но все, что я пробовал, провалилось. Любая помощь?

Вот мой текущий код:

    RelativeLayout container = new RelativeLayout(this);
    container.setLayoutParams(new RelativeLayout.LayoutParams(LayoutParams.FILL_PARENT,LayoutParams.FILL_PARENT));

    //** Add LinearLayout with button(s)

    LinearLayout buttons = new LinearLayout(this);

    RelativeLayout.LayoutParams bottomNavParams = new RelativeLayout.LayoutParams(LayoutParams.WRAP_CONTENT, LayoutParams.WRAP_CONTENT);
    bottomNavParams.addRule(RelativeLayout.ALIGN_PARENT_BOTTOM);
    bottomNavParams.addRule(RelativeLayout.CENTER_HORIZONTAL);
    buttons.setLayoutParams(bottomNavParams);


    ImageButton newLayer = new ImageButton(this);
    newLayer.setImageResource(R.drawable.newlayer);
    newLayer.setLayoutParams(new LinearLayout.LayoutParams(45, LayoutParams.FILL_PARENT));
    buttons.addView(newLayer);

    container.addView(buttons);

    //** Add ListView

    layerview = new ListView(this);

    RelativeLayout.LayoutParams listParams = new RelativeLayout.LayoutParams(LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT);
    listParams.addRule(RelativeLayout.ABOVE, buttons.getId());

    layerview.setLayoutParams(listParams);

    container.addView(layerview);

Ответы [ 7 ]

135 голосов
/ 05 марта 2010

Я думаю, это то, что вы ищете.

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent" android:layout_height="fill_parent">

    <Button android:layout_width="fill_parent"
        android:layout_height="wrap_content" android:id="@+id/testbutton"
        android:text="@string/hello" android:layout_alignParentBottom="true" />

    <ListView android:layout_width="fill_parent"
        android:layout_height="fill_parent" android:id="@+id/list"
        android:layout_alignParentTop="true" android:layout_above="@id/testbutton" />

</RelativeLayout>
57 голосов
/ 07 октября 2010

У меня была такая же проблема целую вечность.

Решение для сохранения ListView над кнопками, но не позволяя ему скрывать их, когда список длинный, состоит в том, чтобы установить android: layout_weight = "1.0" в ListView. Оставьте layout_weight на кнопках неустановленными, чтобы они оставались в своем естественном размере, в противном случае кнопки будут масштабироваться. Это работает с LinearLayout.

В Android ApiDemos есть пример: ApiDemos / Рез / макет / linear_layout_9.xml

20 голосов
/ 05 декабря 2010

Я просто искал ответ на этот вопрос, и это был один из первых результатов.Мне кажется, что все ответы, включая тот, который в настоящее время выбран в качестве «лучшего ответа», не касаются вопроса, о котором спрашивают.Проблема, о которой говорится, состоит в том, что существует два компонента Button и ListView, которые перекрывают друг друга, поскольку ListView занимает весь экран, а кнопка визуально перемещается над (перед) ListView (блокируя).просмотр / доступ к последнему элементу в ListView)

Основываясь на ответах, которые я видел здесь и на других форумах, я наконец пришел к выводу о том, как решить эту проблему.

Первоначально у меня было:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:orientation="vertical"
  android:layout_width="fill_parent"
  android:layout_height="fill_parent"
  android:background="#FF394952">

  <ListView
    android:id="@+id/game_list"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:layout_alignParentTop="true"
    />

  <LinearLayout
    android:orientation="horizontal"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    style="@android:style/ButtonBar">

    <Button
      android:id="@+id/new_game"
      android:layout_width="fill_parent"
      android:layout_height="wrap_content"
      android:text="@string/new_game"
      android:textColor="#FFFFFFFF"
      android:background="@drawable/button_background" />
  </LinearLayout>

</RelativeLayout>

Обратите внимание на использование RelativeLayout в качестве корневого узла.

Это окончательная рабочая версия, в которой кнопка не перекрывает ListView:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
  xmlns:android="http://schemas.android.com/apk/res/android"
  android:orientation="vertical"
  android:layout_width="fill_parent"
  android:layout_height="fill_parent"
  android:background="#FF394952">

  <ListView
    android:id="@+id/game_list"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:layout_alignParentTop="true"
    android:layout_weight="1.0" />

  <LinearLayout
    android:orientation="horizontal"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    style="@android:style/ButtonBar">

    <Button
      android:id="@+id/new_game"
      android:layout_width="fill_parent"
      android:layout_height="wrap_content"
      android:text="@string/new_game"
      android:textColor="#FFFFFFFF"
      android:background="@drawable/button_background" />
  </LinearLayout>

</LinearLayout>

Есть только два различия.Во-первых, я переключился на использование LinearLayout.Это поможет со следующим битом, который добавляет android:layout_weight к моему ListView

Надеюсь, это поможет.

8 голосов
/ 05 марта 2010

Лучший способ - это относительная раскладка, которая устанавливает кнопки под списком.В этом примере кнопки также имеют линейную компоновку, потому что их легче разместить рядом с одинаковым размером.

<RelativeLayout android:id="@+id/RelativeLayout01" 
android:layout_width="fill_parent" 
android:layout_height="fill_parent">

<ListView android:id="@+id/ListView01" 
android:layout_alignParentTop="true"
android:layout_width="fill_parent" 
android:layout_height="fill_parent">
</ListView>

<LinearLayout android:id="@+id/LinearLayout01" 
android:layout_below="@+id/ListView01" 
android:layout_width="fill_parent" 
android:layout_height="wrap_content" 
android:layout_alignParentBottom="true">
<Button android:id="@+id/ButtonJoin" 
android:text="Join"
android:layout_width="fill_parent" 
android:layout_height="wrap_content"
android:layout_weight="1"
android:layout_alignParentBottom="true">
</Button>
<Button android:id="@+id/ButtonJoin" 
android:layout_alignRight="@id/ButtonCancel" 
android:layout_width="fill_parent" 
android:layout_height="wrap_content"
android:layout_weight="1"
android:text="Cancel"
android:layout_alignParentBottom="true">
</Button>
</LinearLayout>

</RelativeLayout>
1 голос
/ 15 сентября 2010

Я знаю, что это сообщение довольно старое, но, чтобы ответить на оригинальный вопрос автора, причина, по которой код не работал, заключалась в кнопках. Если вы собираетесь это сделать, вам нужно установить что-то вроде call buttons.setId (10). Если вы сделаете это, код работает просто отлично.

0 голосов
/ 09 января 2012

самое простое решение - создать две линейные компоновки, одну с кнопкой, а другую с представлением списка (обернуть содержимое по высоте кнопки и сопоставить родительский элемент по высоте макета списка). тогда только сделайте вид прокрутки по макету с представлением списка, и макет кнопки будет проигнорирован. надеюсь, это поможет, извините, мне не хотелось писать код.

0 голосов
/ 08 января 2012

это должно работать. чтобы над списком тоже были кнопки, поместите кнопки в другой линейный макет.

<LinearLayout> main container // vertical

<LinearLayout> scrollview must be contained in a linear layout //vertical - height to fill parent

    <ScrollView> set the height of this to fill parent

        <ListView> will be contained in the scrollview
        </ListView>

    </ScrollView>

</LinearLayout>

<LinearLayout> //horizontal - height to wrap content

<Button>

</Button>

</LinearLayout>

</LinearLayout>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...