Android 协调器布局:AppBarLayout 下方的工具栏

Android Coordinator Layout: Toolbar below AppBarLayout

我正在尝试使用 android 设计支持库开发一个简单的测试应用程序,但我不明白为什么工具栏出现在 AppBarLayout 下方:

我的 styles.xml 是:

<resources>

<!-- Base application theme. -->
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
    <!-- Customize your theme here. -->
    <item name="colorPrimary">@color/colorPrimary</item>
    <item name="colorPrimaryDark">@color/colorPrimaryDark</item>
    <item name="colorAccent">@color/colorAccent</item>

    <!-- ActionMode -->
    <item name="windowActionModeOverlay">true</item>
    <item name="android:windowActionModeOverlay">true</item>
    <item name="android:actionModeBackground">@color/colorAccent</item>
    <item name="android:actionModeSplitBackground">@color/colorPrimary</item>
    <item name="android:actionModeStyle">@style/AppTheme.ActionMode</item>
</style>

<style name="AppTheme.NoActionBar">
    <item name="windowActionBar">false</item>
    <item name="windowNoTitle">true</item>
    <item name="android:windowDrawsSystemBarBackgrounds">true</item>
</style>

<style name="AppTheme.ActionMode" parent="@style/Widget.AppCompat.ActionMode">
    <item name="android:background">?android:attr/actionModeBackground</item>
    <item name="android:backgroundSplit">?android:attr/actionModeSplitBackground</item>
    <item name="android:height">?android:attr/actionBarSize</item>
    <!--<item name="android:titleTextStyle">@android:style/TextAppearance.Widget.ActionMode.Title</item>
    <item name="android:subtitleTextStyle">@android:style/TextAppearance.Widget.ActionMode.Subtitle</item>-->
</style>

<style name="AppTheme.AppBarOverlay" parent="ThemeOverlay.AppCompat.Dark.ActionBar" />

<style name="AppTheme.PopupOverlay" parent="ThemeOverlay.AppCompat.Light" />

</resources>

我的布局是:

<?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/coordinator"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true"
tools:context=".MainActivity">

<android.support.design.widget.AppBarLayout
    android:id="@+id/app_bar"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    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:popupTheme="@style/AppTheme.PopupOverlay" />

</android.support.design.widget.AppBarLayout>

<fragment android:id="@+id/items_fragment"
    app:layout_behavior="@string/appbar_scrolling_view_behavior"
    class="it.bmsoftware.advancedrecyclerapp.MainFragment"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:tag="items_fragment"
    tools:layout="@layout/fragment_recycler" />

</android.support.design.widget.CoordinatorLayout>

有人知道我错过了什么吗?

提前致谢:)

AppbarLayout 只是包裹了Toolbar 使其固定在Actionbar 上。 并再次查看代码。

另一个问题是您在 Android studio 的编辑器预览中使用 AppTheme,如果您使用工具栏然后选择 NoActionBar 主题,那么您将首先看到工具栏,这是不正确的。 我认为您假设 Appbarlayout 位于工具栏顶部,但实际上是它的 Actionbar。