1.进行复杂页面布局时,最外层的根布局不要用ConstraintLayout.
示例布局:
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.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:id="@+id/root"android:layout_width="match_parent"android:layout_height="match_parent"tools:background="@drawable/common_bg"><androidx.swiperefreshlayout.widget.SwipeRefreshLayoutandroid:id="@+id/srl_drama"android:layout_width="match_parent"android:layout_height="match_parent"android:layout_marginTop="73dp"><androidx.coordinatorlayout.widget.CoordinatorLayoutandroid:layout_width="match_parent"android:layout_height="wrap_content"><com.google.android.material.appbar.AppBarLayoutandroid:id="@+id/abl_drama"android:layout_width="match_parent"android:layout_height="wrap_content"android:layout_marginStart="13dp"android:layout_marginEnd="13dp"android:background="@android:color/transparent"android:elevation="0dp"app:elevation="0dp"><FrameLayoutandroid:layout_width="match_parent"android:layout_height="wrap_content"app:layout_scrollFlags="scroll"><FrameLayoutandroid:id="@+id/fl_normal_layout"android:layout_width="match_parent"android:layout_height="wrap_content"><ImageViewandroid:id="@+id/iv_banner"android:layout_width="match_parent"android:layout_height="wrap_content"android:adjustViewBounds="true"android:src="@drawable/tab1_banner"app:layout_constraintLeft_toLeftOf="parent"app:layout_constraintRight_toRightOf="parent"app:layout_constraintTop_toTopOf="parent" /><TextViewandroid:id="@+id/tv_drama_vip"android:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_gravity="bottom|start"android:layout_marginStart="16dp"android:layout_marginBottom="12dp"android:background="@drawable/bg_purchase"android:paddingStart="18dp"android:paddingTop="8dp"android:paddingEnd="18dp"android:paddingBottom="8dp"android:text="30元开通"android:textColor="#FFFFFFFF"android:textSize="18sp"android:textStyle="bold" /></FrameLayout><includeandroid:id="@+id/fl_vip_layout"layout="@layout/include_vip_banner"android:layout_width="match_parent"android:layout_height="wrap_content"android:visibility="gone" /></FrameLayout><includeandroid:id="@+id/include_drama_history"layout="@layout/header_drama"android:layout_width="match_parent"android:layout_height="wrap_content"android:layout_marginTop="18dp"android:layout_marginBottom="18dp"app:layout_scrollFlags="scroll" /><includelayout="@layout/include_drama_category"android:layout_width="match_parent"android:layout_height="wrap_content" /></com.google.android.material.appbar.AppBarLayout><TableLayoutandroid:id="@+id/tablayout"android:layout_width="match_parent"android:layout_height="wrap_content"/><androidx.viewpager2.widget.ViewPager2android:layout_width="match_parent"android:layout_height="match_parent"/></androidx.coordinatorlayout.widget.CoordinatorLayout></androidx.swiperefreshlayout.widget.SwipeRefreshLayout></androidx.constraintlayout.widget.ConstraintLayout>
并且viewpaer的内容用的fragment,fragment布局里是RecyclerView
在这种复杂布局中,就遇到RecyclerView内容拉不到底部的问题。通过分析界面,发现是因为viewpager的布局已经超出屏幕了。
如何解决:
外层的根布局用RelativeLayout 或者 LinearLayout 就能解决RecyclerView内容拉不到底部的问题
2.ConstraintLayout内嵌套NestedScrollView
注意:也会遇到内容显示不全的问题