我们可以看到这里最后一项是部分可见的。我怎样才能解决这个问题? layout.xml
<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout
android:id="@+id/coordinator_layout"
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:fitsSystemWindows="true">
<android.support.design.widget.AppBarLayout
android:id="@+id/app_bar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:fitsSystemWindows="true"
android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">
<android.support.design.widget.CollapsingToolbarLayout
android:id="@+id/collapsing_toolbar"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
app:contentScrim="?attr/colorPrimary"
app:layout_scrollFlags="scroll|exitUntilCollapsed">
<include
layout="@layout/header"
android:fitsSystemWindows="true"
app:layout_collapseMode="parallax"/>
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
app:layout_collapseMode="pin"
app:popupTheme="@style/ThemeOverlay.AppCompat.Light"/>
</android.support.design.widget.CollapsingToolbarLayout>
</android.support.design.widget.AppBarLayout>
<android.support.v7.widget.RecyclerView
android:id="@+id/recycler_view"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:layout_behavior="@string/appbar_scrolling_view_behavior"/>
</android.support.design.widget.CoordinatorLayout>
list_item.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:background="@color/grey_background">
<ImageView
android:id="@+id/image"
android:layout_width="@dimen/thumbnail_width"
android:layout_height="@dimen/thumbnail_height"
android:layout_gravity="center"
android:adjustViewBounds="true"
android:scaleType="fitCenter"/>
<LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerVertical="true"
android:layout_toRightOf="@id/image"
android:orientation="vertical"
android:padding="@dimen/participant_left_padding">
<TextView
android:id="@+id/participants_name"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="name"
android:textColor="@android:color/white"/>
<TextView
android:id="@+id/total_view"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="view"
android:textColor="@android:color/white"/>
<TextView
android:id="@+id/ranking"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="ranking"
android:textColor="@android:color/white"/>
</LinearLayout>
<ImageView
android:id="@+id/overflow"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true"
android:layout_alignParentRight="true"
android:src="@drawable/ic_action_overflow"/>
</RelativeLayout>
答案 0 :(得分:10)
我也有同样的问题。在我看来,这是因为您设置了AppBarLayout XML属性android:fitsSystemWindows =&#34; true&#34;。为了解决这个问题,我将RecyclerView边距底部等于操作栏尺寸
<android.support.v7.widget.RecyclerView
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
android:id="@+id/recyclerView"
android:layout_marginBottom="?attr/actionBarSize">
答案 1 :(得分:9)
<fragment
android:id="@+id/fragment"
android:name="com.example.fragment"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
答案 2 :(得分:4)
我在RecyclerView
内部遇到ConstraintLayout
这个问题,我将我的回收者观点改为&#34; 0dp&#34; (match_constraint)并没有进一步的麻烦。
看看
<android.support.constraint.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
>
<!-- Title -->
<TextView
android:id="@+id/title"
android:layout_width="wrap_content"
android:layout_height="@dimen/view_with_press_height"
android:text="@string/taxes_fees_charges"
android:gravity="center_vertical"
android:layout_marginStart="@dimen/general_side_margin"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
/>
<!-- Details Recyclerview-->
<android.support.v7.widget.RecyclerView
android:id="@+id/recycler_view"
android:layout_width="0dp"
android:layout_height="0dp"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toBottomOf="@+id/title"
app:layout_constraintBottom_toBottomOf="parent"
android:layout_marginBottom="@dimen/general_bottom_margin"
app:layout_constraintVertical_bias="0.0"
tools:itemCount="28"
tools:listitem="@layout/tax_details_row" />
</android.support.constraint.ConstraintLayout>
如果您想使用tools:itemCount="28"
,则必须在xmlns:tools="http://schemas.android.com/tools"
文件中导入XML
。
答案 3 :(得分:1)
我正在展示一些解决方案,但没有奏效 现在我找到了一个简单的解决方案来切断回收站视图中的最后一项
将您的回收器视图添加到 LinearLaout 中
在Linearlayout中添加recycler view后,将这两个Attributes添加到recycler view中。
android:paddingBottom="?attr/actionBarSize"
android:clipToPadding="false"
现在,您的 Recyclerview 看起来像这样,
<androidx.recyclerview.widget.RecyclerView
android:id="@+id/rvQuotes"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_marginStart="@dimen/_10sdp"
android:layout_marginEnd="@dimen/_10sdp"
android:background="@color/white"
android:paddingBottom="?attr/actionBarSize"
android:paddingTop="@dimen/_10sdp"
android:clipChildren="false"
app:layoutManager="androidx.recyclerview.widget.LinearLayoutManager"
tools:listItem="@layout/item_dessert"
android:clipToPadding="false"/>
答案 4 :(得分:0)
使用RelativeLayout代替ConstraintLayout。它对我有用。
答案 5 :(得分:0)
对于其他人。在recyclerview中禁用嵌套滚动也会在具有可滚动工具栏或TabLayout的CoordinatorLayout中导致此问题。因为当您滚动recyclerview时,工具栏或布局不会滚动。
答案 6 :(得分:0)
我尝试了大多数可能的站点中所有可用的选项,但没有得到解决方案。 然后,我想可以使用底部填充吗?是的,这对我有用。
我正在与您共享代码。 除了高度,宽度和填充之外,不需要任何其他属性。
android:paddingBottom =“?attr / actionBarSize”
<android.support.v7.widget.RecyclerView
android:id="@+id/your id name"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:paddingBottom="?attr/actionBarSize"
app:layout_constraintTop_toBottomOf="@+id/your field" />
答案 7 :(得分:-1)
最简单但不是最好的解决方案。仍然有效;
在您的getItemCount()
实现的RecyclerView.Adapter
方法中返回+1,并将代码包装在onBindViewHolder
方法覆盖的try-catch
块中。