相对布局的AndroidStudio问题

时间:2018-11-10 11:38:32

标签: android

我对RelativeLayout有疑问。在设计视图中,我可以看到我的布局工作正常,但是在运行时,一个EditText从屏幕上移了下来。

以下是我的布局代码:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    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_width="match_parent"
    android:layout_height="match_parent">

<TextView
    android:id="@+id/tvInicio"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentTop="true"
    android:layout_centerHorizontal="true"
    android:layout_marginTop="23dp"
    android:text="@string/dialog_titulo"
    android:textColor="@color/colorPrimary"
    android:textSize="24sp"
    android:textStyle="bold" />

<TextView
    android:id="@+id/tvPrimero"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentStart="true"
    android:layout_alignParentTop="true"
    android:layout_marginTop="85dp"
    android:text="@string/dialog_max"
    android:textColor="@color/colorPrimary"
    android:layout_alignParentLeft="true" />

<EditText
    android:id="@+id/etMaximo"
    android:layout_width="111dp"
    android:layout_height="wrap_content"
    android:layout_alignBaseline="@+id/tvPrimero"
    android:layout_alignParentEnd="true"
    android:ems="10"
    android:hint="@string/dialog_etMax"
    android:inputType="number"
    android:layout_alignParentRight="true" />

<EditText
    android:id="@+id/etMinimo"
    android:layout_width="111dp"
    android:layout_height="wrap_content"
    android:layout_alignParentEnd="true"
    android:layout_alignParentTop="true"
    android:layout_marginTop="151dp"
    android:ems="10"
    android:hint="@string/dialog_etMin"
    android:inputType="number"
    android:layout_alignParentRight="true" />

<TextView
    android:id="@+id/tvSegundo"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentStart="true"
    android:layout_below="@+id/etMinimo"
    android:text="@string/dialog_maxmin"
    android:textColor="@color/colorPrimary"
    android:layout_alignParentLeft="true" />

<EditText
    android:id="@+id/etMaximo2"
    android:layout_width="111dp"
    android:layout_height="wrap_content"
    android:layout_alignParentEnd="true"
    android:layout_below="@+id/tvSegundo"
    android:ems="10"
    android:hint="@string/dialog_etMax"
    android:inputType="number"
    android:layout_alignParentRight="true" />

<TextView
    android:id="@+id/tvTexto"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignBaseline="@+id/etTexto"
    android:layout_alignParentStart="true"
    android:text="@string/diaog_textoTitulo"
    android:textColor="@color/colorPrimary"
    android:layout_alignParentLeft="true" />

<EditText
    android:id="@+id/etTexto"
    android:layout_width="193dp"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    android:layout_alignParentEnd="true"
    android:layout_marginBottom="180dp"
    android:ems="10"
    android:hint="@string/diaog_etTextoTitulo"
    android:inputType="textPersonName"
    android:layout_alignParentRight="true" />

<LinearLayout
    android:layout_width="360dp"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    android:layout_centerHorizontal="true">

    <Button
        android:id="@+id/btnCancelar"
        android:layout_width="176dp"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:layout_marginBottom="19dp"
        android:layout_toLeftOf="@+id/etTexto"
        android:layout_toStartOf="@+id/etTexto"
        android:background="@drawable/boton_redondeado2"
        android:text="@string/iniciar_sesion_cancelar"
        android:textColor="@android:color/background_light" />

    <Button
        android:id="@+id/btnGuardar"
        android:layout_width="178dp"
        android:layout_height="wrap_content"
        android:layout_alignParentEnd="true"
        android:layout_alignParentRight="true"
        android:layout_alignTop="@+id/btnCancelar"
        android:layout_marginEnd="9dp"
        android:layout_marginRight="9dp"
        android:background="@drawable/boton_redondeado"
        android:text="@string/diaog_guardar"
        android:textColor="@android:color/background_light" />

</LinearLayout>

See here

运行时视图看起来像this

有人因为我感到绝望而可以帮助我。我的英语不好,所以我接受编辑

4 个答案:

答案 0 :(得分:0)

尝试删除android:layout_alignParentEnd="true",然后在清理后清理项目,然后再次运行。 确保线性布局结束后立即关闭相对布局  </LinearLayout> </RelativeLayout>

现在可以使用吗?

我使用了这个xml,并在Nexus 5模拟器上运行了

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
 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_width="match_parent"
 android:layout_height="match_parent">

 <TextView
    android:id="@+id/tvInicio"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentTop="true"
    android:layout_centerHorizontal="true"
    android:layout_marginTop="23dp"
    android:text="TEST"
    android:textColor="@color/colorPrimary"
    android:textSize="24sp"
    android:textStyle="bold" />

<TextView
    android:id="@+id/tvPrimero"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentStart="true"
    android:layout_alignParentTop="true"
    android:layout_marginTop="85dp"
    android:text="test"
    android:textColor="@color/colorPrimary"
    android:layout_alignParentLeft="true" />

<EditText
    android:id="@+id/etMaximo"
    android:layout_width="111dp"
    android:layout_height="wrap_content"
    android:layout_alignBaseline="@+id/tvPrimero"
    android:layout_alignParentEnd="true"
    android:ems="10"
    android:hint="test"
    android:inputType="number"
    android:layout_alignParentRight="true" />

<EditText
    android:id="@+id/etMinimo"
    android:layout_width="111dp"
    android:layout_height="wrap_content"
    android:layout_alignParentEnd="true"
    android:layout_alignParentTop="true"
    android:layout_marginTop="151dp"
    android:ems="10"
    android:hint="test"
    android:inputType="number"
    android:layout_alignParentRight="true" />

<TextView
    android:id="@+id/tvSegundo"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignParentStart="true"
    android:layout_below="@+id/etMinimo"
    android:text="test"
    android:textColor="@color/colorPrimary"
    android:layout_alignParentLeft="true" />

<EditText
    android:id="@+id/etMaximo2"
    android:layout_width="111dp"
    android:layout_height="wrap_content"
    android:layout_alignParentEnd="true"
    android:layout_below="@+id/tvSegundo"
    android:ems="10"
    android:hint="test"
    android:inputType="number"
    android:layout_alignParentRight="true" />

<TextView
    android:id="@+id/tvTexto"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignBaseline="@+id/etTexto"
    android:layout_alignParentStart="true"
    android:text="test"
    android:textColor="@color/colorPrimary"
    android:layout_alignParentLeft="true" />

<EditText
    android:id="@+id/etTexto"
    android:layout_width="193dp"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"

    android:layout_marginBottom="180dp"
    android:ems="10"
    android:hint="this should stay right here"
    android:inputType="textPersonName"
    android:layout_alignParentRight="true" />

<LinearLayout
    android:layout_width="360dp"
    android:layout_height="wrap_content"
    android:layout_alignParentBottom="true"
    android:layout_centerHorizontal="true">

    <Button
        android:id="@+id/btnCancelar"
        android:layout_width="176dp"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:layout_marginBottom="19dp"
        android:layout_toLeftOf="@+id/etTexto"
        android:layout_toStartOf="@+id/etTexto"
        android:background="@color/colorPrimary"
        android:text="button"
        android:textColor="@android:color/background_light" />

    <Button
        android:id="@+id/btnGuardar"
        android:layout_width="178dp"
        android:layout_height="wrap_content"
        android:layout_alignParentEnd="true"
        android:layout_alignParentRight="true"
        android:layout_alignTop="@+id/btnCancelar"
        android:layout_marginEnd="9dp"
        android:layout_marginRight="9dp"
        android:background="@color/colorAccent"
        android:text="button"
        android:textColor="@android:color/background_light" />

</LinearLayout>
</RelativeLayout>

答案 1 :(得分:0)

将此id赋予LinearLayout

android:id="@+id/layout"

并将此属性添加到etTexto

android:layout_above="@+id/layout"

还可以根据需要调整底部边距。

答案 2 :(得分:0)

也许您应该尝试将其放在其上方的EditText下方?

删除

android:layout_alignParentBottom="true"
android:layout_marginBottom="180dp"

添加

android:layout_below="@+id/etMaximo2"

结果

<EditText
    android:id="@+id/etTexto"
    android:layout_width="193dp"
    android:layout_height="wrap_content"
    android:layout_alignParentEnd="true"
    android:layout_below="@+id/etMaximo2"
    android:ems="10"
    android:hint="@string/diaog_etTextoTitulo"
    android:inputType="textPersonName"
    android:layout_alignParentRight="true" />

然后设置一些最高边距android:layout_marginTop="{some value}dp",使其看起来像您想要的。

答案 3 :(得分:0)

使用RelativeLayout而不是

android:layout_alignParentBottom="true"
android:layout_marginBottom="180dp"

就像您在ID为@+id/etTexto的EditText中所做的一样,您只需编写以下代码即可:android:layout_below="@id/etMaximo2" 如果要在两个视图之间添加更多空间,甚至可以放置一些android:layout_marginTop

P.S。要在设计视图中进行测试,请知道您可以更改要测试的设备的尺寸,因此您可以在“预览”窗口中看到在具有不同屏幕尺寸的设备上的外观。您可以在预览窗口的顶部工具栏中进行更改。

希望对您有所帮助! :)