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中

listview点击控件显示EditText,键盘弹出消失的解决方法:

EditText 现在显示在 ListView 下