ListView 上方未显示 EditText 和按钮
Posted
技术标签:
【中文标题】ListView 上方未显示 EditText 和按钮【英文标题】:EditText & Button Not Showing Up Above ListView 【发布时间】:2020-07-13 18:31:46 【问题描述】:我有这个包含列表视图的片段。我现在添加了一个按钮和一个编辑文本以用作搜索栏。该应用程序运行良好并显示列表视图,但我在任何地方都看不到按钮或编辑文本。我不确定我做错了什么,这是我的代码:
<?xml version="1.0" encoding="utf-8"?>
<ListView xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_
android:layout_
tools:context=".BookListFragment"/>
<RelativeLayout
android:id="@+id/container1"
android:layout_
android:layout_
android:layout_marginStart="16dp"
android:layout_marginTop="16dp"
android:layout_marginEnd="16dp"
android:layout_marginBottom="16dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.0"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintVertical_bias="0.0">
<EditText
android:id="@+id/searchBox"
android:layout_
android:layout_
android:layout_alignParentStart="true"
android:layout_alignParentTop="true"
android:layout_alignParentEnd="true"
android:layout_alignParentBottom="true"
android:layout_marginStart="24dp"
android:layout_marginTop="15dp"
android:layout_marginEnd="113dp"
android:layout_marginBottom="639dp"
android:autofillHints="@string/search"
android:ems="10"
android:inputType="textPersonName"
android:visibility="visible" />
<Button
android:id="@+id/searchButton"
android:layout_
android:layout_
android:layout_alignParentStart="true"
android:layout_alignParentTop="true"
android:layout_alignParentEnd="true"
android:layout_alignParentBottom="true"
android:layout_marginStart="279dp"
android:layout_marginLeft="16dp"
android:layout_marginTop="13dp"
android:layout_marginEnd="1dp"
android:layout_marginRight="16dp"
android:layout_marginBottom="646dp"
android:text="@string/search" />
</RelativeLayout>
【问题讨论】:
【参考方案1】:你有以下问题
您有两个根布局:ListView 和 RelativeLayout,所以我将 RelativeLayout 中的 ListView 以保持单个顶部根视图。 您的 RelativeLayout 的宽度和高度为 0dp,因此其内容不会 显示 修复了 Button & EditText 下的 ListView 使用android:layout_alignParentBottom
从 Button 和 EditText 的底部删除了太大的边距
已移除
删除了与 ConstraintLayout 相关的不可用约束
尝试使用下面的布局
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/container1"
android:layout_
android:layout_
android:layout_marginStart="16dp"
android:layout_marginTop="16dp"
android:layout_marginEnd="16dp"
android:layout_marginBottom="16dp"
tools:context=".BookListFragment">
<EditText
android:id="@+id/searchBox"
android:layout_
android:layout_
android:layout_alignParentStart="true"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:layout_alignParentEnd="true"
android:layout_alignParentRight="true"
android:layout_marginStart="24dp"
android:layout_marginLeft="24dp"
android:layout_marginTop="15dp"
android:layout_marginEnd="113dp"
android:layout_marginRight="113dp"
android:autofillHints="@string/search"
android:ems="10"
android:inputType="textPersonName"
android:visibility="visible" />
<Button
android:id="@+id/searchButton"
android:layout_
android:layout_
android:layout_alignParentStart="true"
android:layout_alignParentLeft="true"
android:layout_alignParentTop="true"
android:layout_alignParentEnd="true"
android:layout_alignParentRight="true"
android:layout_marginStart="279dp"
android:layout_marginLeft="16dp"
android:layout_marginTop="13dp"
android:layout_marginEnd="1dp"
android:layout_marginRight="16dp"
android:text="@string/search" />
<ListView
android:layout_
android:layout_
android:layout_below="@+id/searchBox"
android:layout_alignParentBottom="true" />
</RelativeLayout>
【讨论】:
【参考方案2】:您的 ListView 有一个匹配父级高度,在这种情况下它将填满整个屏幕。当您想在屏幕上放置许多细线时,您应该使用布局管理器来组织它。尝试类似:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_
android:layout_
android:orientation="vertical">
<RelativeLayout
android:id="@+id/container1"
android:layout_
android:layout_
android:layout_marginStart="16dp"
android:layout_marginTop="16dp"
android:layout_marginEnd="16dp"
android:layout_marginBottom="16dp">
<EditText
android:id="@+id/searchBox"
android:layout_
android:layout_
android:layout_alignParentStart="true"
android:layout_alignParentTop="true"
android:layout_alignParentEnd="true"
android:layout_marginStart="24dp"
android:layout_marginTop="15dp"
android:layout_marginEnd="113dp"
android:autofillHints="search"
android:ems="10"
android:inputType="textPersonName"
android:visibility="visible" />
<Button
android:id="@+id/searchButton"
android:layout_
android:layout_
android:layout_alignParentStart="true"
android:layout_alignParentTop="true"
android:layout_alignParentEnd="true"
android:layout_marginStart="279dp"
android:layout_marginLeft="16dp"
android:layout_marginTop="13dp"
android:layout_marginEnd="1dp"
android:layout_marginRight="16dp"
android:text="search" />
</RelativeLayout>
<!-- Your List View Come Here -->
<ListView
android:layout_
android:layout_
android:layout_weight="1"
android:layout_marginStart="24dp"
android:layout_marginEnd="24dp"/>
</LinearLayout>
它可能有效,但不是制作此布局的最佳方式。你应该看到更多关于 Layout Xml Official Description
【讨论】:
以上是关于ListView 上方未显示 EditText 和按钮的主要内容,如果未能解决你的问题,请参考以下文章
ListView + EditText => 糟糕的键盘行为
Android 根据EditText搜索框ListView动态显示数据
Android 依据EditText搜索框ListView动态显示数据
点击Button将EditText的内容显示到另外一个页面的Listview中