Relativelayout没有包装其内容

时间:2016-01-27 10:55:18

标签: android xml android-layout android-relativelayout android-wrap-content

我希望我的内心RelativeLayout能够包含它的内容并保持在View元素之下。为什么它的行为不像下图?

我的layout.xml

<?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">
    <View
        android:id="@+id/linearLayout"
        android:layout_above="@+id/input_layout"
        android:layout_width="match_parent"
        android:layout_height="match_parent"/>

    <RelativeLayout
        android:id="@+id/input_layout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:background="#ebebeb">

        <EditText
            android:id="@+id/editText"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentBottom="true"
            android:layout_alignParentLeft="true"
            android:layout_alignParentStart="true"
            android:layout_toLeftOf="@+id/imageView13"
            android:layout_toStartOf="@+id/imageView13"
            android:background="@android:color/white"
            android:padding="8dp" />

        <ImageView
            android:id="@+id/imageView13"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_alignParentBottom="true"
            android:layout_alignParentEnd="true"
            android:layout_alignParentRight="true"
            android:src="@drawable/ic_m_send" />

    </RelativeLayout>

</RelativeLayout>

enter image description here

2 个答案:

答案 0 :(得分:10)

android:layout_alignParentBottom="true"EditText移除ImageView将解决您的问题。

您的RelativeLayout已经拥有android:layout_alignParentBottom="true",如果您为其孩子设置相同内容,它也会将布局高度设置为全屏。

  

请注意,您不能在大小之间具有循环依赖关系   RelativeLayout及其子女的位置。例如,你   不能将RelativeLayout的高度设置为WRAP_CONTENT和a   子项设置为ALIGN_PARENT_BOTTOM

Class Document

答案 1 :(得分:0)

使用这种方式

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

   <View
    android:id="@+id/relChart"
    android:layout_above="@+id/input_layout"
    android:layout_width="match_parent"
    android:layout_height="match_parent"/>

   <RelativeLayout
    android:id="@+id/relChart"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:background="@color/background"
   >

    <EditText
        android:id="@+id/editText1"
        android:layout_width="match_parent"
        android:layout_height="80dp"
        android:layout_centerVertical="true"
        android:layout_margin="5dp"
        android:layout_toLeftOf="@+id/ivSend"
        android:background="@drawable/border_round_white3"
        android:gravity="right|center_vertical"
        android:paddingRight="10dp"
        android:textColor="@android:color/black"
        android:textCursorDrawable="@null"
        android:maxLength="140"
        />

    <ImageView
        android:id="@+id/ivSend"
        android:layout_width="40dp"
        android:layout_height="35dp"
        android:layout_alignParentRight="true"
        android:layout_centerVertical="true"
        android:contentDescription="@null"
        android:padding="5dp"
        android:src="@mipmap/send_icon" />
</RelativeLayout>
    </RelativeLayout>