Android 系统按钮与 ListView 重叠
Android system buttons are overlapping ListView
我有带选项卡式片段的主activity..在片段中我有列表视图,但是当我滚动到底部的最后一个项目时,这个项目被系统按钮覆盖:
screenshot
这是我的 activity xml:
<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout 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/main_content"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
tools:context="com.example.martin.fitnessapp.MainActivity">
<android.support.design.widget.AppBarLayout
android:id="@+id/appbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:paddingTop="@dimen/appbar_padding_top"
android:theme="@style/AppTheme.AppBarOverlay">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:background="?attr/colorPrimary"
app:layout_scrollFlags="scroll|enterAlways"
app:popupTheme="@style/AppTheme.PopupOverlay">
</android.support.v7.widget.Toolbar>
<android.support.design.widget.TabLayout
android:id="@+id/tabs"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
</android.support.design.widget.AppBarLayout>
<android.support.v4.view.ViewPager
android:id="@+id/container"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior" />
<android.support.design.widget.FloatingActionButton
android:id="@+id/fab"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="end|bottom"
android:layout_margin="@dimen/fab_margin"
android:src="@android:drawable/ic_dialog_email" />
</android.support.design.widget.CoordinatorLayout>
这是我当前的标签页 xml:
<RelativeLayout 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"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin">
<!--tools:context="com.example.martin.fitnessapp.MainActivity$PlaceholderFragment">-->
<ListView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/listViewMuscleGroups"
android:layout_alignParentStart="true" />
</RelativeLayout>
我为每个片段创建了单独的 class,它们扩展了片段 class。如果您需要,我也可以添加这个 class,但我认为这无关紧要。
android:layout_alignParentStart="true"
是左边的(或者右边取决于你是否使用 RTL 语言),你可能还想要 alignParentTop
因为 ListView.The listview 可能想要 match_parent
宽度也是。
无论如何,我不确定发生了什么,但我会尝试将 app:layout_behavior="@string/appbar_scrolling_view_behavior"
移动到包含 ListView 的 RelativeLayout,因为这就是导致 ViewPager 的片段内容被绘制成这样的原因。
郑重声明,我没有多少协调器布局经验。
我有带选项卡式片段的主activity..在片段中我有列表视图,但是当我滚动到底部的最后一个项目时,这个项目被系统按钮覆盖:
screenshot
这是我的 activity xml:
<?xml version="1.0" encoding="utf-8"?>
<android.support.design.widget.CoordinatorLayout 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/main_content"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
tools:context="com.example.martin.fitnessapp.MainActivity">
<android.support.design.widget.AppBarLayout
android:id="@+id/appbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:paddingTop="@dimen/appbar_padding_top"
android:theme="@style/AppTheme.AppBarOverlay">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:background="?attr/colorPrimary"
app:layout_scrollFlags="scroll|enterAlways"
app:popupTheme="@style/AppTheme.PopupOverlay">
</android.support.v7.widget.Toolbar>
<android.support.design.widget.TabLayout
android:id="@+id/tabs"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
</android.support.design.widget.AppBarLayout>
<android.support.v4.view.ViewPager
android:id="@+id/container"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior" />
<android.support.design.widget.FloatingActionButton
android:id="@+id/fab"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="end|bottom"
android:layout_margin="@dimen/fab_margin"
android:src="@android:drawable/ic_dialog_email" />
</android.support.design.widget.CoordinatorLayout>
这是我当前的标签页 xml:
<RelativeLayout 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"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin">
<!--tools:context="com.example.martin.fitnessapp.MainActivity$PlaceholderFragment">-->
<ListView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/listViewMuscleGroups"
android:layout_alignParentStart="true" />
</RelativeLayout>
我为每个片段创建了单独的 class,它们扩展了片段 class。如果您需要,我也可以添加这个 class,但我认为这无关紧要。
android:layout_alignParentStart="true"
是左边的(或者右边取决于你是否使用 RTL 语言),你可能还想要 alignParentTop
因为 ListView.The listview 可能想要 match_parent
宽度也是。
无论如何,我不确定发生了什么,但我会尝试将 app:layout_behavior="@string/appbar_scrolling_view_behavior"
移动到包含 ListView 的 RelativeLayout,因为这就是导致 ViewPager 的片段内容被绘制成这样的原因。
郑重声明,我没有多少协调器布局经验。