android - 如何填充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>
图片:
解决方案
这个想法是您必须创建一个填充所有可用空间的视图,即在 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" />
推荐阅读
- c++ - 有没有办法追溯原始源代码中内存崩溃地址所指的位置?
- c++ - Poco SocketAddress 不喜欢定义了预处理器宏的 IPv4 地址
- android - xamarin - 避免在 android 标记上打开 InfoWindow
- eclipse - maven deployin 从命令行工作,但不在 Eclipse 中
- vue.js - Vue CLI 3 vue.config.js 编译“未知单词”错误
- spring-boot - GCP Stackdriver Logging 中的平面应用程序日志视图(springboot 应用程序)
- angular - 一个没有共享和实例化参数的 Angular 服务
- parameters - Ada:在过程调用后检查 OUT 参数是否已更改(从 NULL)
- java - java代码从access_log文件中提取请求到sql数据库
- kinvey - kinvey loginwithMIC 方法无法在移动设备中打开 webview