【问题标题】:How to fill layout between two views in RelativeLayout?如何填充RelativeLayout中两个视图之间的布局?
【发布时间】:2018-09-06 10:58:13
【问题描述】:

我有这个简单的布局,其中有 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>

图片:

【问题讨论】:

  • 如果您可以将预期的输出分享为图像,那就太好了
  • 以上是您当前的输出或预期
  • 预计。当前的输出是您看不到 Icon2,因为它被 Searchview 推出了显示

标签: android android-layout android-relativelayout


【解决方案1】:

试试这个

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

    <ImageButton
        android:layout_width="32dp"
        android:layout_height="32dp"
        android:adjustViewBounds="true"
        android:layout_gravity="center_vertical"
        android:background="@android:color/transparent"
        android:src="@drawable/ic_menu_send" />


    <android.support.v7.widget.SearchView
        android:layout_width="0dp"
        android:layout_weight="1"
        android:layout_height="wrap_content"
        app:closeIcon="@null"
        android:layout_gravity="center"
        app:iconifiedByDefault="false"
        app:searchHintIcon="@null"
        app:searchIcon="@null"/>

    <ImageButton
        android:layout_width="32dp"
        android:layout_height="32dp"
        android:adjustViewBounds="true"
        android:layout_gravity="center_vertical"
        android:background="@android:color/transparent"
        android:scaleType="fitCenter"
        android:src="@drawable/ic_menu_send" />


</LinearLayout>

【讨论】:

  • 因为这个图标没有垂直居中于 searchView。这就是为什么我想使用RelativeLayout 来设置centerVertical=true。 searchView 的高度与图标的高度不同
【解决方案2】:

这个想法是,您必须创建一个填充所有可用空间的视图,即在 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" />

【讨论】:

    【解决方案3】:

    这个对你有用,试试这个

        <?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="wrap_content"
        xmlns:app="http://schemas.android.com/apk/res-auto"
        android:layout_marginBottom="16dp"
        android:layout_marginTop="32dp"
        android:orientation="horizontal">
    
        <ImageButton
        android:id="@+id/icon_1"
        android:layout_width="32dp"
        android:layout_height="32dp"
        android:layout_alignParentStart="true"
        android:layout_centerVertical="true"
        android:layout_gravity="center_horizontal"
        android:adjustViewBounds="true"
        android:background="@android:color/transparent"
        android:src="@drawable/ico_1"
        android:layout_alignParentLeft="true" />
    
        <android.support.v7.widget.SearchView
        android:id="@+id/action_search"
        app:closeIcon="@null"
        app:iconifiedByDefault="false"
        app:searchHintIcon="@null"
        app:searchIcon="@null"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_toEndOf="@id/icon_1"
        android:background="@android:color/transparent"
        android:backgroundTint="@android:color/transparent"
        android:focusedByDefault="false"
        android:layout_toRightOf="@id/icon_1">
    
        </android.support.v7.widget.SearchView>
    
        <ImageButton
        android:id="@+id/icon_2"
        android:layout_width="32dp"
        android:layout_height="32dp"
        android:layout_alignParentEnd="true"
        android:layout_centerVertical="true"
        android:layout_marginEnd="15dp"
        android:layout_toEndOf="@id/action_search"
        android:adjustViewBounds="true"
        android:background="@android:color/transparent"
        android:scaleType="fitCenter"
        android:src="@drawable/ico_2"
        android:layout_alignParentRight="true"
        android:layout_marginRight="15dp"
        android:layout_toRightOf="@id/action_search" />
        </RelativeLayout>
    

    【讨论】:

      猜你喜欢
      • 2012-10-08
      • 1970-01-01
      • 2017-12-31
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多