为什么我的元素不像所谓的那样停留在底部?

时间:2015-02-08 08:34:55

标签: android xml android-layout relativelayout

我有这个布局xml文件:

<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:fillViewport="true">

    <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:paddingBottom="@dimen/activity_vertical_margin"
        android:paddingLeft="@dimen/activity_horizontal_margin"
        android:paddingRight="@dimen/activity_horizontal_margin"
        android:paddingTop="@dimen/activity_vertical_margin"
        tools:context=".MainActivity">

        <TextView
            android:layout_marginTop="40dp"
            android:id="@+id/emalLbl"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerHorizontal="true"
            android:text="@string/test" />

        <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
            android:id="@+id/testTxtLay"
            android:layout_marginTop="10dp"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_below="@id/emalLbl"
            android:orientation="horizontal"
            android:padding="10dp"
            android:weightSum="1">

            <EditText
                android:id="@+id/testTxt"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_weight="1.0"
                android:background="@drawable/edit_text_design" />
        </LinearLayout>

        <TextView
            android:layout_marginTop="60dp"
            android:id="@+id/reminderLbl"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_below="@id/testTxtLay"
            android:layout_centerHorizontal="true"
            android:text="@string/reminder" />

        <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
            android:layout_marginTop="10dp"
            android:id="@+id/reminderTxtLay"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_below="@id/reminderLbl"
            android:orientation="horizontal"
            android:padding="10dp"
            android:weightSum="1">

            <EditText
                android:id="@+id/reminderTxt"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_weight="1.0"
                android:lines="2"
                android:background="@drawable/edit_text_design" />
        </LinearLayout>

        <View
            android:id="@+id/spacer"
            android:layout_width="0dp"
            android:layout_height="0dp"
            android:layout_below="@id/reminderTxtLay"
            android:layout_centerHorizontal="true" />

        <Button
            android:layout_marginTop="200dp"
            android:id="@+id/pickDateBtn"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentLeft="true"
            android:layout_below="@id/reminderTxtLay"
            android:layout_toLeftOf="@+id/spacer"
            android:onClick="showDatePickerDialog"
            android:text="@string/datePickerBtnTxt" />

        <Button
            android:id="@+id/pickTimeBtn"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignBaseline="@id/pickDateBtn"
            android:layout_alignParentRight="true"
            android:layout_toRightOf="@+id/pickDateBtn"
            android:onClick="showTimePickerDialog"
            android:text="@string/pickTimeBtn" />

        <View
            android:id="@+id/spacerTxt"
            android:layout_width="0dp"
            android:layout_height="0dp"
            android:layout_below="@id/reminderTxtLay"
            android:layout_centerHorizontal="true" />

        <EditText
            android:layout_marginTop="15dp"
            android:id="@+id/selectedDate"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignBaseline="@id/spacerTxt"
            android:layout_below="@id/pickDateBtn"
            android:layout_toLeftOf="@+id/spacerTxt" />

        <EditText
            android:id="@+id/selectedTime"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignBaseline="@id/selectedDate"
            android:layout_below="@id/pickTimeBtn"
            android:layout_toRightOf="@+id/selectedDate" />

        <Button
            android:id="@+id/submitBtn"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_alignParentBottom="true"
            android:layout_centerInParent="true"
            android:onClick="submitData"
            android:text="@string/submitBtn" />

    </RelativeLayout>
</ScrollView>

这是7英寸平板电脑的自定义设计,放置在res\layout-sw600dp

无论如何在android studio环境预览中看起来很不错:

enter image description here

但是在模拟器中出现问题,这就是它看起来很奇怪的方式。我的意思是提交按钮不在底部,pickDatepickTime按钮位于布局的底部。

enter image description here enter image description here

我知道我在这里错过了一个基本点,但作为Android开发人员,我无法发现它。

你能帮我推吗?

2 个答案:

答案 0 :(得分:1)

这是完成您似乎尝试完成的工作的完整方式。您不需要为“空格”等创建任何视图。您只需要在视图的任一侧添加边距或填充,以使其远离另一个视图。

<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:fillViewport="true">

<RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:paddingBottom="@dimen/activity_vertical_margin"
    android:paddingLeft="@dimen/activity_horizontal_margin"
    android:paddingRight="@dimen/activity_horizontal_margin"
    android:paddingTop="@dimen/activity_vertical_margin">
    <LinearLayout
        android:id="@+id/linear_wrapper"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical"
        android:gravity="center_horizontal"
        >

        <TextView
            android:layout_marginTop="40dp"
            android:id="@+id/emalLbl"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@string/test" />


        <EditText
            android:id="@+id/testTxt"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:background="@drawable/edit_text_design" />

        <TextView
            android:layout_marginTop="60dp"
            android:id="@+id/reminderLbl"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@string/reminder" />


        <EditText
            android:id="@+id/reminderTxt"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:lines="2"
            android:background="@drawable/edit_text_design" />

        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="horizontal"
            android:layout_marginTop="200dp"
            >
            <Button
                android:id="@+id/pickDateBtn"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_weight="1"
                android:onClick="showDatePickerDialog"
                android:text="@string/datePickerBtnTxt" />

            <Button
                android:id="@+id/pickTimeBtn"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_weight="1"
                android:onClick="showTimePickerDialog"
                android:text="@string/pickTimeBtn" />
        </LinearLayout>


        <LinearLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:orientation="horizontal">
            <EditText
                android:id="@+id/selectedDate"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_weight="1"/>

            <EditText
                android:id="@+id/selectedTime"
                android:layout_width="0dp"
                android:layout_height="wrap_content"
                android:layout_weight="1"/>
        </LinearLayout>

    </LinearLayout>

    <Button
        android:id="@+id/submitBtn"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:layout_centerHorizontal="true"
        android:layout_below="@+id/linear_wrapper"
        android:onClick="submitData"
        android:text="@string/submitBtn" />
</RelativeLayout>

答案 1 :(得分:0)

你可以将2个按钮放在一起!

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        android:padding="10dp"
        android:weightSum="1">

        <Button
            android:id="@+id/btn1"
            android:layout_width="wrap_content"
            android:gravity="left"
            android:layout_height="wrap_content"
            android:lines="2" />

        <Button
            android:id="@+id/btn2"
            android:layout_width="fill_parent"    
            android:gravity="right"
            android:layout_height="wrap_content" />

    </LinearLayout>