Подтвердить что ты не робот

Android: выровнять исходный снизу + нижний край

Я использовал относительную компоновку, и я хочу установить кнопку внизу экрана. Однако это ставит все ниже, и я хотел бы иметь некоторый запас, чтобы там было некоторое пространство между концом экран/представление и кнопку. Однако, что бы я ни делал, край кнопки просто ничего не делает по 2.1+ по какой-то причине. Относительная компоновка содержит фон, поэтому я не могу, но на этом поле.

Кто-нибудь знает исправление для этого?

<?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"
android:layout_marginBottom="0dp"
android:background="@drawable/background" >

    <Button
        android:id="@+id/confirm_mobile_button_next"
        android:layout_width="fill_parent"
        android:layout_height="40dip"
        android:layout_alignParentBottom="true"
        android:layout_alignParentLeft="false"
        android:layout_centerHorizontal="false"
        android:layout_centerInParent="false"
        android:layout_margin="15dp"
        android:background="@drawable/button_shape_selector"
        android:paddingLeft="10dip"
        android:paddingRight="10dip"
        android:text="@string/confirm_mobile_no_continue"
        android:textColor="@color/white"
        android:textStyle="bold" />

</RelativeLayout>
4b9b3361

Ответ 1

Вы можете просто добавить дополнение к RelativeLayout вместо поля к кнопке, например. android:paddingBottom="15dp".

В общем, я всегда проверяю свой макет в предварительном просмотре Exclipse, используя настройку уровня API 8. Это дает довольно точные результаты для большинства устройств, включая ICS и JB.

Ответ 2

Другое, что вы можете сделать, это положить View, который выровнен по нижней части RelativeLayout, и установить его высоту в нижнее поле, которое вы хотели бы использовать (или просто указать значение для layout_marginBottom). так:

 <RelativeLayout
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"        
    > 
    <ImageView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:src="@drawable/some_image"
        android:adjustViewBounds="true"

         />
    <TextView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="Some Overlay"
        android:padding="3dip"
        android:gravity="center_vertical|center_horizontal"

        android:layout_above="@+id/empty_view"
        android:layout_marginBottom="35dip"
        />
    <View 
        android:id = "@+id/empty_view"
        android:layout_height = "30dip"
        android:layout_width = "match_parent"
        android:visibility="invisible"
        android:layout_alignParentBottom="true"
        />

    </RelativeLayout>

Этот пример заполняет RelativeLayout с помощью ImageView и позиционирует a TextView по ImageView.

Ответ 3

Юй может использовать атрибут translateY

translateY="-16dp"

Конечный код

<?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"
    android:layout_marginBottom="0dp"
    android:background="@drawable/background">

    <Button
        android:id="@+id/confirm_mobile_button_next"
        android:layout_width="fill_parent"
        android:layout_height="40dip"
        android:layout_alignParentBottom="true"
        android:layout_alignParentLeft="false"
        android:layout_centerHorizontal="false"
        android:layout_centerInParent="false"
        android:layout_margin="15dp"
        android:background="@drawable/button_shape_selector"
        android:paddingLeft="10dip"
        android:paddingRight="10dip"
        android:text="@string/confirm_mobile_no_continue"
        android:textColor="@color/white"
        android:textStyle="bold"
        android:translateY="-16dp" />

</RelativeLayout>

Ответ 4

Я думаю, что лучший способ - установить android: layout_alignParentBottom в XML затем в java-коде позади:

Button confirm_mobile_button_next = (Button)findViewById(R.id.confirm_mobile_button_next)

и

confirm_mobile_button_next.setTransitionY(-THE_VALUE) or setTransitionX(-THE_VALUE)

Ответ 5

Так как я наткнулся на эту проблему и не видел ответов, подходящих для моей ситуации, я начал думать за полсекунды и разрешил ее, установив отрицательный запас на представление внутри образца RelativeLayout:

<RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent">
    <ImageView
    android:layout_width="48dp"
    android:layout_height="48dp"
        android:layout_marginTop="-8dp"
        android:layout_marginStart="-8dp">
</RelativeLayout>

Это должно оказаться полезным для некоторых людей.

Ответ 6

Я думаю, что лучший способ - установить:

<...
android:layout_alignParentBottom="true" />

затем в java-коде позади:

Button confirm_mobile_button_next = (Button)findViewById(R.id.confirm_mobile_button_next)
confirm_mobile_button_next.setTransitionY(-THE_VALUE) or setTransitionX(-THE_VALUE)

Ответ 7

Вы можете использовать ViewGroup (например, FrameLayout или LinearLayout), чтобы обернуть представление. Установите alignParentBottom во внешнюю ViewGroup, затем marginBottom может работать во внутреннем представлении.

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content">

    <FrameLayout
        android:id="@+id/fl_layout"
        android:layout_alignParentBottom="true"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content">
        <TextView
            android:id="@+id/tv_layout"
            android:text="hello world"
            android:layout_marginBottom="50dp"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />
    </FrameLayout>
</RelativeLayout>

Ответ 8

только рабочее решение, предложенное @franny zhao, ниже.

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content">

    <FrameLayout
        android:id="@+id/fl_layout"
        android:layout_alignParentBottom="true"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content">
        <TextView
            android:id="@+id/tv_layout"
            android:text="hello world"
            android:layout_marginBottom="50dp"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content" />
    </FrameLayout>
</RelativeLayout>

Если вы добавите дополнение к нижнему выровненному представлению, как предложено другими, фон представления также будет расширяться. Если у вас цветной фон, то вид будет выглядеть так, как будто он приклеен к нижней части. Отступы и поля совершенно разные, добавление является частью вида, но маржа оставляет пространство между представлениями.

Ответ 9

Попробуйте следующим образом:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
         xmlns:tools="http://schemas.android.com/tools"
         android:layout_width="fill_parent"
         android:layout_height="fill_parent" >

<Button
    android:id="@+id/button1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    android:layout_centerHorizontal="true"
    android:layout_marginBottom="17dp"
    android:text="Button" />

Ответ 10

Вот еще одна альтернатива. Если вы хотите установить дочернее поле вместо родительского дополнения, вы должны установить значение android:layout_marginTop в два раза из требуемого поля, а затем установить для параметра android:layout_centerVertical значение true. Верхнему краю присваивается удвоенное значение, чтобы компенсировать нижний предел. Таким образом, у вашего ребенка будет одинаковое верхнее и нижнее поле.

<Button
    android:id="@+id/confirm_mobile_button_next"
    android:layout_width="fill_parent"
    android:layout_height="40dip"
    android:layout_alignParentBottom="true"
    android:layout_alignParentLeft="false"
    android:layout_centerVertical="true"
    android:layout_centerInParent="false"
    android:layout_marginLeft="15dp"
    android:layout_marginRight="15dp"
    android:layout_marginTop="30dp"
    android:background="@drawable/button_shape_selector"
    android:paddingLeft="10dip"
    android:paddingRight="10dip"
    android:text="@string/confirm_mobile_no_continue"
    android:textColor="@color/white"
    android:textStyle="bold" />

Это даст вам тот же результат.