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。
我正在尝试使用 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。