【问题标题】:EditText & Button Not Showing Up Above ListViewListView 上方未显示 EditText 和按钮
【发布时间】: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_width="match_parent"
        android:layout_height="match_parent"
        tools:context=".BookListFragment"/>

    <RelativeLayout
    android:id="@+id/container1"
    android:layout_width="0dp"
    android:layout_height="0dp"
    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_width="241dp"
        android:layout_height="wrap_content"
        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_width="98dp"
        android:layout_height="39dp"
        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>

【问题讨论】:

    标签: android listview android-fragments android-edittext android-button


    【解决方案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_width="match_parent"
        android:layout_height="match_parent"
        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_width="241dp"
            android:layout_height="wrap_content"
            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_width="98dp"
            android:layout_height="39dp"
            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_width="match_parent"
            android:layout_height="wrap_content"
            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_width="match_parent"
      android:layout_height="match_parent"
          android:orientation="vertical">
      
          <RelativeLayout
              android:id="@+id/container1"
              android:layout_width="match_parent"
              android:layout_height="wrap_content"
              android:layout_marginStart="16dp"
              android:layout_marginTop="16dp"
              android:layout_marginEnd="16dp"
              android:layout_marginBottom="16dp">
      
      
              <EditText
                  android:id="@+id/searchBox"
                  android:layout_width="241dp"
                  android:layout_height="wrap_content"
                  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_width="98dp"
                  android:layout_height="39dp"
                  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_width="match_parent"
              android:layout_height="0px"
              android:layout_weight="1"
              android:layout_marginStart="24dp"
              android:layout_marginEnd="24dp"/>
      </LinearLayout>

      它可能有效,但不是制作此布局的最佳方式。你应该看到更多关于 Layout Xml Official Description

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 2011-03-22
        • 2018-10-05
        • 1970-01-01
        • 2014-08-10
        • 2015-06-14
        • 2017-07-08
        • 1970-01-01
        • 1970-01-01
        相关资源
        最近更新 更多