如何在 RelativeLayout 中的两个视图之间填充布局?
How to fill layout between two views in RelativeLayout?
我有这个简单的布局,其中有 2 个图标和它们之间的 SearchView。我希望 SearchView 位于这两个图标之间(与 ConstraintLayout 中的 match_constraint 相同)。我想使用 RelativeLayout,因为负边距在 ConstraintLayout 中不起作用(你必须使用在我的情况下无效的垫片)。
此解决方案无效。它会将第二个图标推出视图,在这种情况下,SearchView 将 match_parent。负边距的原因:即使没有边距,应用程序中的 Icon 和 SearchView 之间的差距也很大。所以我想对图标使用负边距,使它们更靠近 SearchView 的边缘(里面有 EditText)
<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>
图片:
这个想法是你必须制作一个视图来填充所有可用的 space,这是用 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" />
试试这个
<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>
这个对你有用,试试这个
<?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>
我有这个简单的布局,其中有 2 个图标和它们之间的 SearchView。我希望 SearchView 位于这两个图标之间(与 ConstraintLayout 中的 match_constraint 相同)。我想使用 RelativeLayout,因为负边距在 ConstraintLayout 中不起作用(你必须使用在我的情况下无效的垫片)。
此解决方案无效。它会将第二个图标推出视图,在这种情况下,SearchView 将 match_parent。负边距的原因:即使没有边距,应用程序中的 Icon 和 SearchView 之间的差距也很大。所以我想对图标使用负边距,使它们更靠近 SearchView 的边缘(里面有 EditText)
<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>
图片:
这个想法是你必须制作一个视图来填充所有可用的 space,这是用 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" />
试试这个
<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>
这个对你有用,试试这个
<?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>