【问题标题】:RecyclerView in ConstraintLayout overlapping other elementsConstraintLayout 中的 RecyclerView 与其他元素重叠
【发布时间】:2018-05-07 09:39:03
【问题描述】:

我正在使用以下组件进行简单的列表活动:EditText、RecyclerView、ProgressBar 和 Textview。一切都很好,除了 RecyclerView 与 EditText 重叠并“超出”屏幕底部,因此最后一项被部分切除(参见屏幕截图)。 我做错了什么?

主活动:

<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout 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:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="jacopo.com.flickrgallery.GalleryActivity">

    <EditText
        android:id="@+id/search_text"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginEnd="8dp"
        android:layout_marginStart="8dp"
        android:layout_marginTop="8dp"
        android:hint="search by tag..."
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent" />

    <ProgressBar
        android:id="@+id/gallery_progress"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginBottom="8dp"
        android:layout_marginEnd="8dp"
        android:layout_marginStart="8dp"
        android:layout_marginTop="8dp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/search_text" />

    <android.support.v7.widget.RecyclerView
        android:id="@+id/gallery_list"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginBottom="8dp"
        android:layout_marginEnd="8dp"
        android:layout_marginStart="8dp"
        android:layout_marginTop="8dp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/search_text" />

    <TextView
        android:id="@+id/gallery_error"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_marginBottom="8dp"
        android:layout_marginEnd="8dp"
        android:layout_marginStart="8dp"
        android:layout_marginTop="8dp"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toBottomOf="@+id/search_text"
        tools:text="error" />

</android.support.constraint.ConstraintLayout>

【问题讨论】:

    标签: android android-layout android-recyclerview android-constraintlayout


    【解决方案1】:

    您将android:layout_height="wrap_content" 用于RecyclerView 但看起来你需要限制高度。试试android:layout_height="0dp"。在这种情况下,它等于app:layout_constraintTop_toBottomOf="@+id/search_text"app:layout_constraintBottom_toBottomOf="parent"

    【讨论】:

    【解决方案2】:

    我有完全相同的问题,并添加

    app:layout_constrainedHeight="true"
    

    到 RecyclerView 解决了。

    【讨论】:

      【解决方案3】:

      尝试关注,您必须将recyclerviewtopConstraint 设置为edittext

      <?xml version="1.0" encoding="utf-8"?>
      <android.support.constraint.ConstraintLayout 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:layout_width="match_parent"
          android:layout_height="match_parent"  >
      
          <EditText
              android:id="@+id/search_text"
              android:layout_width="match_parent"
              android:layout_height="wrap_content"
              android:layout_marginEnd="8dp"
              android:layout_marginStart="8dp"
              android:layout_marginTop="8dp"
              android:hint="search by tag..."
              app:layout_constraintEnd_toEndOf="parent"
              app:layout_constraintStart_toStartOf="parent"
              app:layout_constraintTop_toTopOf="parent" />
      
          <ProgressBar
              android:id="@+id/gallery_progress"
              android:layout_width="wrap_content"
              android:layout_height="wrap_content"
              android:layout_marginBottom="8dp"
              android:layout_marginEnd="8dp"
              android:layout_marginStart="8dp"
              android:layout_marginTop="8dp"
              app:layout_constraintBottom_toBottomOf="parent"
              app:layout_constraintEnd_toEndOf="parent"
              app:layout_constraintStart_toStartOf="parent"
              app:layout_constraintTop_toBottomOf="@+id/search_text" />
      
          <android.support.v7.widget.RecyclerView
              android:id="@+id/gallery_list"
              android:layout_width="0dp"
              android:layout_height="0dp"
              android:layout_marginBottom="8dp"
              android:layout_marginEnd="8dp"
              android:layout_marginStart="8dp"
              android:layout_marginTop="8dp"
              app:layout_constraintBottom_toBottomOf="parent"
              app:layout_constraintEnd_toEndOf="parent"
              app:layout_constraintStart_toStartOf="parent"
              app:layout_constraintTop_toBottomOf="@+id/search_text" />
      
          <TextView
              android:id="@+id/gallery_error"
              android:layout_width="wrap_content"
              android:layout_height="wrap_content"
              android:layout_marginBottom="8dp"
              android:layout_marginEnd="8dp"
              android:layout_marginStart="8dp"
              android:layout_marginTop="8dp"
              app:layout_constraintBottom_toBottomOf="parent"
              app:layout_constraintEnd_toEndOf="parent"
              app:layout_constraintStart_toStartOf="parent"
              app:layout_constraintTop_toBottomOf="@+id/search_text"
              tools:text="error" />
      
      </android.support.constraint.ConstraintLayout>
      

      输出:

      【讨论】:

        【解决方案4】:

        在 RecyclerView 中添加:

        app:layout_constraintStart_toEndOf="@+id/search_text"

        【讨论】:

          【解决方案5】:

          你将相同的 id 传递给每个视图,用这个修改你的代码。

           <?xml version="1.0" encoding="utf-8"?>
          <android.support.constraint.ConstraintLayout 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:layout_width="match_parent"
              android:layout_height="match_parent">
          
              <EditText
                  android:id="@+id/search_text"
                  android:layout_width="0dp"
                  android:layout_height="wrap_content"
                  android:layout_marginTop="8dp"
                  android:hint="search by tag..."
                  app:layout_constraintEnd_toEndOf="parent"
                  app:layout_constraintStart_toStartOf="parent"
                  app:layout_constraintTop_toTopOf="parent"/>
          
              <ProgressBar
                  android:id="@+id/gallery_progress"
                  android:layout_width="wrap_content"
                  android:layout_height="wrap_content"
                  android:layout_marginBottom="8dp"
                  android:layout_marginTop="8dp"
                  app:layout_constraintBottom_toBottomOf="parent"
                  app:layout_constraintEnd_toEndOf="parent"
                  app:layout_constraintStart_toStartOf="parent"
                  app:layout_constraintTop_toBottomOf="@+id/search_text"
                  tools:layout_editor_absoluteX="376dp" />
          
              <android.support.v7.widget.RecyclerView
                  android:id="@+id/gallery_list"
                  android:layout_width="0dp"
                  android:layout_height="0dp"
                  android:layout_marginBottom="8dp"
                  android:layout_marginTop="8dp"
                  app:layout_constraintBottom_toBottomOf="parent"
                  app:layout_constraintTop_toBottomOf="@+id/search_text"
                  app:layout_constraintLeft_toLeftOf="parent"
                  app:layout_constraintRight_toRightOf="parent" />
          
              <TextView
                  android:id="@+id/gallery_error"
                  android:layout_width="wrap_content"
                  android:layout_height="wrap_content"
                  android:layout_marginBottom="8dp"
                  android:layout_marginTop="8dp"
                  app:layout_constraintBottom_toBottomOf="parent"
                  app:layout_constraintEnd_toEndOf="parent"
                  app:layout_constraintStart_toStartOf="parent"
                  app:layout_constraintTop_toBottomOf="@+id/search_text"
                  tools:text="error"
                  tools:layout_editor_absoluteX="385dp" />
          
          </android.support.constraint.ConstraintLayout>
          

          编码愉快!!

          【讨论】:

            【解决方案6】:

            随便用

            app:layout_constraintVertical_bias="0.0"

            在 recyclerView 标签中。

            希望这会有所帮助。

            【讨论】:

              【解决方案7】:

              由于某种原因,添加适当的约束并将高度设置为 0dp 对我不起作用(即使它应该适用于大多数情况)

              所以我添加了一个框架布局作为回收器视图的父级,并将回收器视图的高度和宽度设置为match_parent 为框架布局添加了约束。

              这停止了重叠问题

              【讨论】:

              • 你是救命稻草。
              【解决方案8】:

              将您的 XML 文件更改为以下代码。

              <?xml version="1.0" encoding="utf-8"?>
              <android.support.constraint.ConstraintLayout 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:layout_width="match_parent"
                  android:layout_height="match_parent">
              
                  <EditText
                      android:id="@+id/search_text"
                      android:layout_width="match_parent"
                      android:layout_height="wrap_content"
                      android:layout_marginEnd="8dp"
                      android:layout_marginStart="8dp"
                      android:layout_marginTop="8dp"
                      android:hint="search by tag..."
                      app:layout_constraintEnd_toEndOf="parent"
                      app:layout_constraintStart_toStartOf="parent"
                      app:layout_constraintTop_toTopOf="parent" />
              
                  <ProgressBar
                      android:id="@+id/gallery_progress"
                      android:layout_width="wrap_content"
                      android:layout_height="wrap_content"
                      android:layout_marginBottom="8dp"
                      android:layout_marginEnd="8dp"
                      android:layout_marginStart="8dp"
                      android:layout_marginTop="8dp"
                      app:layout_constraintBottom_toBottomOf="parent"
                      app:layout_constraintEnd_toEndOf="parent"
                      app:layout_constraintStart_toStartOf="parent"
                      app:layout_constraintTop_toBottomOf="@+id/search_text" />
              
                  <android.support.v7.widget.RecyclerView
                      android:id="@+id/gallery_list"
                      android:layout_width="match_parent"
                      android:layout_height="wrap_content"
                      android:layout_marginBottom="8dp"
                      android:layout_marginEnd="8dp"
                      android:layout_marginStart="8dp"
                      android:layout_marginTop="8dp"
                      app:layout_constraintStart_toEndOf="@+id/search_text" />
              
                  <TextView
                      android:id="@+id/gallery_error"
                      android:layout_width="wrap_content"
                      android:layout_height="wrap_content"
                      android:layout_marginBottom="8dp"
                      android:layout_marginEnd="8dp"
                      android:layout_marginStart="8dp"
                      android:layout_marginTop="8dp"
                      app:layout_constraintBottom_toBottomOf="parent"
                      app:layout_constraintEnd_toEndOf="parent"
                      app:layout_constraintStart_toStartOf="parent"
                      app:layout_constraintTop_toBottomOf="@+id/search_text"
                      tools:text="error" />
              
              </android.support.constraint.ConstraintLayout>
              

              试试这个,让我知道这是否适合你。

              【讨论】:

                【解决方案9】:

                我在构建音乐播放器应用程序时遇到了这个问题我解决了我的问题以给出 recyclerview 0dp IDK 的高度它是如何工作的,但我的问题已经解决了

                【讨论】:

                  猜你喜欢
                  • 2017-03-16
                  • 2020-03-02
                  • 1970-01-01
                  • 2012-08-06
                  • 1970-01-01
                  • 1970-01-01
                  • 2018-02-04
                  • 1970-01-01
                  • 1970-01-01
                  相关资源
                  最近更新 更多