How to align views at the bottom of the screen?

2019-01-01 06:32发布

问题:

Here\'s my layout code;

<?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\">

    <TextView android:text=\"@string/welcome\" 
        android:id=\"@+id/TextView\" 
        android:layout_width=\"fill_parent\" 
        android:layout_height=\"wrap_content\">
    </TextView>

    <LinearLayout android:id=\"@+id/LinearLayout\" 
        android:orientation=\"horizontal\"
        android:layout_width=\"wrap_content\" 
        android:layout_height=\"wrap_content\" 
        android:gravity=\"bottom\">

            <EditText android:id=\"@+id/EditText\" 
                android:layout_width=\"fill_parent\" 
                android:layout_height=\"wrap_content\">
            </EditText>

            <Button android:text=\"@string/label_submit_button\" 
                android:id=\"@+id/Button\" 
                android:layout_width=\"wrap_content\" 
                android:layout_height=\"wrap_content\">
            </Button>

    </LinearLayout>

</LinearLayout>

What this looks like is on the left and what I want it to look like is on the right.

\"Android

The obvious answer is to set the TextView to fill_parent on height but this causes no room to be left for the button or entry field. Essentially the issue is that I want the submit button and the text entry to be a fixed height at the bottom and the text view to fill the rest of the space, similarly in the horizontal Linear layout I want the submit button to wrap its content and for the text entry to fill the rest of the space.

If the first item in a Linear Layout is told to fill_parent it does exactly that, leaving no room for other items, how do I get an item which is first in a linear layout to fill all space apart from the minimum required by the rest of the items in the layout?

EDIT:

Relative Layouts were indeed the answer - Thank you!

    <?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\">

    <TextView 
        android:text=\"@string/welcome\" 
        android:id=\"@+id/TextView\"
        android:layout_width=\"fill_parent\" 
        android:layout_height=\"wrap_content\"
        android:layout_alignParentTop=\"true\">
    </TextView>

    <RelativeLayout 
        android:id=\"@+id/InnerRelativeLayout\"
        android:layout_width=\"wrap_content\"
        android:layout_height=\"wrap_content\"
        android:layout_alignParentBottom=\"true\" >

        <Button 
            android:text=\"@string/label_submit_button\" 
            android:id=\"@+id/Button\"
            android:layout_alignParentRight=\"true\" 
            android:layout_width=\"wrap_content\"
            android:layout_height=\"wrap_content\">
        </Button>

        <EditText 
            android:id=\"@+id/EditText\" 
            android:layout_width=\"fill_parent\"
            android:layout_toLeftOf=\"@id/Button\"
            android:layout_height=\"wrap_content\">
        </EditText>

    </RelativeLayout>

</RelativeLayout>

回答1:

The modern way to do this is to have a ConstraintLayout and constrain the bottom of the view to the bottom of the ConstraintLayout with app:layout_constraintBottom_toBottomOf=\"parent\"

The example below creates a FloatingActionButton that will be aligned to the end and the bottom of the screen.

<android.support.constraint.ConstraintLayout 
   xmlns:android=\"http://schemas.android.com/apk/res/android\"
   xmlns:app=\"http://schemas.android.com/apk/res-auto\"
   xmlns:tools=\"http://schemas.android.com/tools\"
   android:layout_height=\"match_parent\"
   android:layout_width=\"match_parent\">

<android.support.design.widget.FloatingActionButton
    android:layout_height=\"wrap_content\"
    android:layout_width=\"wrap_content\"

    app:layout_constraintBottom_toBottomOf=\"parent\"

    app:layout_constraintEnd_toEndOf=\"parent\" />

</android.support.constraint.ConstraintLayout>

For reference I will keep my old answer.
Before the introduction of ConstraintLayout the answer was a relative layout.


If you have a relative layout that fills the whole screen you should be able to use android:layout_alignParentBottom to move the button to the bottom of the screen.

If your views at the bottom are not shown in a relative layout then maybe the layout above it takes all the space. In this case you can put the view that should be at the bottom, first in your layout file and position the rest of the layout above the views with android:layout_above. This enable the bottom view to take as much space as it needs and the rest of the layout can fill all the rest of the screen.



回答2:

In a ScrollView this doesn\'t work, as the RelativeLayout would then overlap whatever is in the ScrollView at the bottom of the page.

I fixed it using a dynamically stretching FrameLayout :

<ScrollView 
    xmlns:android=\"http://schemas.android.com/apk/res/android\"
    android:layout_height=\"match_parent\" 
    android:layout_width=\"match_parent\"
    android:fillViewport=\"true\">
    <LinearLayout 
        android:id=\"@+id/LinearLayout01\"
        android:layout_width=\"match_parent\" 
        android:layout_height=\"match_parent\"
        xmlns:android=\"http://schemas.android.com/apk/res/android\"
        android:orientation=\"vertical\">

                <!-- content goes here -->

                <!-- stretching frame layout, using layout_weight -->
        <FrameLayout
            android:layout_width=\"match_parent\" 
            android:layout_height=\"0dp\"
            android:layout_weight=\"1\">
        </FrameLayout>

                <!-- content fixated to the bottom of the screen -->
        <LinearLayout 
            android:layout_width=\"match_parent\" 
            android:layout_height=\"wrap_content\"
            android:orientation=\"horizontal\">
                                   <!-- your bottom content -->
        </LinearLayout>
    </LinearLayout>
</ScrollView>


回答3:

You can keep your initial linear layout by nesting the relative layout within the linear layout:

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

    <TextView android:text=\"welcome\" 
        android:id=\"@+id/TextView\" 
        android:layout_width=\"fill_parent\" 
        android:layout_height=\"wrap_content\">
    </TextView>

    <RelativeLayout
        android:layout_width=\"match_parent\"
        android:layout_height=\"match_parent\">
        <Button android:text=\"submit\" 
            android:id=\"@+id/Button\" 
            android:layout_width=\"wrap_content\" 
            android:layout_height=\"wrap_content\"
            android:layout_alignParentBottom=\"true\"
            android:layout_alignParentRight=\"true\">
        </Button>
        <EditText android:id=\"@+id/EditText\" 
            android:layout_width=\"match_parent\" 
            android:layout_height=\"wrap_content\"
            android:layout_toLeftOf=\"@id/Button\"
            android:layout_alignParentBottom=\"true\">
        </EditText>
    </RelativeLayout>
</LinearLayout>


回答4:

The answer above (by Janusz) is quite correct, but I personnally don\'t feel 100% confortable with RelativeLayouts, so I prefer to introduce a \'filler\', empty TextView, like this:

<!-- filler -->
<TextView android:layout_height=\"0dip\" 
          android:layout_width=\"fill_parent\"
          android:layout_weight=\"1\" />

before the element that should be at the bottom of the screen.



回答5:

You can do this with a LinearLayout or a ScrollView, too. Sometimes it is easier to implement then a RelativeLayout. The only thing you need to do is to add the following view before the Views you want to align to the bottom of the screen:

<View
        android:layout_width=\"wrap_content\"
        android:layout_height=\"0dp\"
        android:layout_weight=\"1\" />

This creates an empty view, filling the empty space and pushing the next views to the bottom of the screen.



回答6:

This also works.

<LinearLayout 
    android:id=\"@+id/linearLayout4\"
    android:layout_width=\"wrap_content\"
    android:layout_height=\"fill_parent\"
    android:layout_below=\"@+id/linearLayout3\"
    android:layout_centerHorizontal=\"true\"
    android:orientation=\"horizontal\" 
    android:gravity=\"bottom\"
    android:layout_alignParentBottom=\"true\"
    android:layout_marginTop=\"20dp\"
>

    <Button
        android:id=\"@+id/button1\"
        android:layout_width=\"wrap_content\"
        android:layout_height=\"wrap_content\"
        android:text=\"Button\" 

    />

    <Button
        android:id=\"@+id/button2\"
        android:layout_width=\"wrap_content\"
        android:layout_height=\"wrap_content\"
        android:text=\"Button\" 


    />

</LinearLayout>

\"gravity="bottom"



回答7:

Following up on Timores\'s elegant solution, I have found that the following creates a vertical fill in a vertical LinearLayout and a horizontal fill in a horizontal LinearLayout:

<Space
    android:layout_width=\"match_parent\"
    android:layout_height=\"match_parent\"
    android:layout_weight=\"1\" />


回答8:

You don\'t even need to nest the second relative layout inside the first one. Simply use the android:layout_alignParentBottom=\"true\" in the Button and EditText.



回答9:

1.Use ConstraintLayout in your root Layout

And set app:layout_constraintBottom_toBottomOf=\"parent\" to let the Layout on the bottom of the screen

<LinearLayout
    android:id=\"@+id/LinearLayout\"
    android:layout_width=\"match_parent\"
    android:layout_height=\"wrap_content\"
    android:orientation=\"horizontal\"
    app:layout_constraintBottom_toBottomOf=\"parent\">
</LinearLayout>

2.Use FrameLayout in your root Layout

Just set android:layout_gravity=\"bottom\" in your layout

<LinearLayout
    android:id=\"@+id/LinearLayout\"
    android:layout_width=\"match_parent\"
    android:layout_height=\"wrap_content\"
    android:layout_gravity=\"bottom\"
    android:orientation=\"horizontal\">
</LinearLayout>

3.Use LinearLayout in your root Layout (android:orientation=\"vertical\")

(1)Set a layout android:layout_weight=\"1\" on the top of the your Layout

<TextView
    android:id=\"@+id/TextView\"
    android:layout_width=\"match_parent\"
    android:layout_height=\"0dp\"
    android:layout_weight=\"1\"
    android:text=\"welcome\" />

(2)Set the child LinearLayout for android:layout_width=\"match_parent\" android:layout_height=\"match_parent\" android:gravity=\"bottom\"

The main attribute is ndroid:gravity=\"bottom\" ,let the child View on the bottom of Layout .

<LinearLayout
    android:id=\"@+id/LinearLayout\"
    android:layout_width=\"match_parent\"
    android:layout_height=\"match_parent\"
    android:gravity=\"bottom\"
    android:orientation=\"horizontal\">
</LinearLayout>

4.Use RelativeLayout in the root Layout

And set android:layout_alignParentBottom=\"true\" to let the Layout on the bottom of the screen

<LinearLayout
    android:id=\"@+id/LinearLayout\"
    android:layout_width=\"match_parent\"
    android:layout_height=\"wrap_content\"
    android:layout_alignParentBottom=\"true\"
    android:orientation=\"horizontal\">
</LinearLayout>

OUTPUT

\"enter



回答10:

If you don\'t wish to make many changes, then you could just put:

android:layout_weight=\"1\"

for the TextView having ID as @+id/TextView i.e

<TextView android:text=\"@string/welcome\" 
    android:id=\"@+id/TextView\" 
    android:layout_width=\"fill_parent\" 
    android:layout_height=\"wrap_content\"
    android:layout_weight=\"1\">
</TextView>


回答11:

Creating both HEADER and FOOTER, here is an example

[ Layout XML ]

<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\"
    android:background=\"@color/backgroundcolor\"
    tools:context=\".MainActivity\">

    <RelativeLayout
        android:layout_width=\"fill_parent\"
        android:layout_height=\"40dp\"
        android:background=\"#FF0000\">
    </RelativeLayout>

    <RelativeLayout
        android:layout_width=\"fill_parent\"
        android:layout_height=\"40dp\"
        android:layout_alignParentBottom=\"true\"
        android:background=\"#FFFF00\">
    </RelativeLayout>

</RelativeLayout>

[ Screenshot ]

\"enter

Hope this is helpful. Thanks!!



回答12:

use below code align button to bottem its working

    <?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:orientation=\"vertical\" >

    <Button
        android:id=\"@+id/btn_back\"
        android:layout_width=\"100dp\"
        android:layout_height=\"80dp\"
        android:text=\"Back\" />

    <TextView
        android:layout_width=\"match_parent\"
        android:layout_height=\"0dp\"
        android:layout_weight=\"0.97\"
        android:gravity=\"center\"
        android:text=\"Payment Page\" />

    <LinearLayout
        android:layout_width=\"match_parent\"
        android:layout_height=\"wrap_content\" >

        <EditText
            android:layout_width=\"wrap_content\"
            android:layout_height=\"wrap_content\" 
            android:layout_weight=\"1\"/>

        <Button
            android:layout_width=\"wrap_content\"
            android:layout_height=\"wrap_content\" 
            android:text=\"Submit\"/>
    </LinearLayout>

</LinearLayout>


回答13:

For a case like this always use RelativeLayouts. A LinearLayout is not intended for such a usage.

<?xml version=\"1.0\" encoding=\"utf-8\"?>
<RelativeLayout
xmlns:android=\"http://schemas.android.com/apk/res/android\"
          android:id=\"@+id/db1_root\"
          android:layout_width=\"match_parent\"
          android:layout_height=\"match_parent\"
          android:orientation=\"vertical\" >

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

    <!-- Place your layout here -->

</LinearLayout>

<LinearLayout
    android:layout_width=\"match_parent\"
    android:layout_height=\"wrap_content\"
    android:layout_alignParentBottom=\"true\"
    android:layout_gravity=\"bottom\"
    android:orientation=\"horizontal\"
    android:paddingLeft=\"20dp\"
    android:paddingRight=\"20dp\" >

    <Button
        android:id=\"@+id/setup_macroSavebtn\"
        android:layout_width=\"0dp\"
        android:layout_height=\"wrap_content\"
        android:layout_weight=\"1\"
        android:text=\"Save\" />

    <Button
        android:id=\"@+id/setup_macroCancelbtn\"
        android:layout_width=\"0dp\"
        android:layout_height=\"wrap_content\"
        android:layout_weight=\"1\"
        android:text=\"Cancel\" />

    </LinearLayout>

</RelativeLayout>


回答14:

Use android:layout_alignParentBottom=\"true\" in your <RelativeLayout>.

This will definitely help.



回答15:

In case you have a hierarchy like this:

<ScrollView> 
  |-- <RelativeLayout> 
    |-- <LinearLayout>

First, apply android:fillViewport=\"true\" to the ScrollView and then apply android:layout_alignParentBottom=\"true\" to the LinearLayout.

This worked for me perfectly.

<ScrollView
    android:layout_height=\"match_parent\"
    android:layout_width=\"match_parent\"
    android:scrollbars=\"none\"
    android:fillViewport=\"true\">
    <RelativeLayout
        android:layout_width=\"match_parent\"
        android:layout_height=\"wrap_content\">
        <LinearLayout
            android:orientation=\"horizontal\"
            android:layout_width=\"match_parent\"
            android:layout_height=\"wrap_content\"
            android:gravity=\"center\"
            android:id=\"@+id/linearLayoutHorizontal\"
            android:layout_alignParentBottom=\"true\">
        </LinearLayout>
    </RelativeLayout>
</ScrollView>


回答16:

You can just give your top child view (the TextView @+id/TextView) an attribute: android:layout_weight=\"1\".

This will force all other elements below it to the bottom.



回答17:

I used the solution Janusz posted, but added padding to the last View since the top part of my layout was a ScrollView. The ScrollView will be partly hidden as it grows with content. Using android:paddingBottom on the last View helps show all the content in the ScrollView.



回答18:

This can be done with linear layout too Just provide Height = 0dp and weight = 1 to the layout above and the one you want in the bottom just write height = wrap content and no weight. What it does is it provides wrap content for the layout (the one that contains your edit text and button) and then the one that has weight occupies the rest of the layout. I discovered this by accident.