首页 > 解决方案 > 如何填充RelativeLayout中两个视图之间的布局?

问题描述

我有这个简单的布局,它们之间有 2 个图标和 SearchView。我希望 SearchView 位于这两个图标之间(与 ConstraintLayout 中的 match_constraint 相同)。我想使用RelativeLayout,因为负边距在ConstraintLayout 中不起作用(你必须使用对我来说无效的间隔)。

此解决方案不起作用。在这种情况下,它会将第二个图标推离视图,SearchView 将 match_parent。负边距的原因:应用中 Icon 和 SearchView 之间的差距很大,即使没有边距。所以我想对图标使用负边距,使它们更接近 SearchView 的边缘(EditText inside)

<RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="horizontal"
        android:layout_marginBottom="16dp"
        android:layout_marginTop="32dp">

        <ImageButton
            android:id="@+id/icon_1"
            android:layout_width="32dp"
            android:layout_height="32dp"
            android:layout_alignParentStart="true"
            android:layout_centerVertical="true"
            android:adjustViewBounds="true"
            android:background="@android:color/transparent"
            android:layout_gravity="center_horizontal"
            android:src="@drawable/ico_1" />

        <android.support.v7.widget.SearchView
            android:id="@+id/action_search"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_toEndOf="@id/icon_1"
            android:background="@color/colorTransparent"
            android:backgroundTint="@color/colorTransparent"
            android:focusedByDefault="false"
            app:closeIcon="@null"
            app:iconifiedByDefault="false"
            app:searchHintIcon="@null"
            app:searchIcon="@null">

        </android.support.v7.widget.SearchView>

        <ImageButton
            android:id="@+id/icon_2"
            android:layout_width="32dp"
            android:layout_height="32dp"
            android:layout_toEndOf="@id/action_search"
            android:layout_centerVertical="true"
            android:layout_alignParentEnd="true"
            android:layout_marginEnd="15dp"
            android:adjustViewBounds="true"
            android:background="@android:color/transparent"
            android:scaleType="fitCenter"
            android:src="@drawable/ico_2" />
    </RelativeLayout>

图片:

在此处输入图像描述

标签: androidandroid-layoutandroid-relativelayout

解决方案


这个想法是您必须创建一个填充所有可用空间的视图,即在 layout_width 中使用 match_parent。

然后你告诉视图它将从第一个图标结束的地方开始,并在第二个图标结束的地方结束,这是用 layout_toEndOf 和 layout_toStartOf 制作的(你错过了最后一个)

最后,当您引用尚未在此范围内声明的名称时,您应该将第二个名称称为“@+id/icon_2”,并在您的视图声明中设置名称而不创建新的 id “@ id/icon_2",最后,您的代码将如下所示:

<android.support.v7.widget.SearchView
        android:id="@+id/action_search"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_toEndOf="@id/icon_1"
        android:layout_toStartOf="@+id/icon_2"
        android:background="@color/colorTransparent"
        android:backgroundTint="@color/colorTransparent"
        android:focusedByDefault="false"
        app:closeIcon="@null"
        app:iconifiedByDefault="false"
        app:searchHintIcon="@null"
        app:searchIcon="@null">
</android.support.v7.widget.SearchView>

<ImageButton
        android:id="@id/icon_2"
        android:layout_width="32dp"
        android:layout_height="32dp"
        android:layout_toEndOf="@id/action_search"
        android:layout_centerVertical="true"
        android:layout_alignParentEnd="true"
        android:layout_marginEnd="15dp"
        android:adjustViewBounds="true"
        android:background="@android:color/transparent"
        android:scaleType="fitCenter"
        android:src="@drawable/ico_2" />

推荐阅读