Android 抽屉布局中的工具栏占据整个区域?
我一直在尝试使用新的设计库,我有一个工具栏,而不是不推荐的操作栏。问题是工具栏占据了活动中的整个区域。我尝试了不同的示例,并用它们替换了布局文件,我尝试了不同的宽度和高度值。我不知道为什么会这样。没有一个是有效的!这可能是什么原因造成的 非常感谢您的帮助 activity_main.xmlAndroid 抽屉布局中的工具栏占据整个区域?,android,android-layout,android-actionbar,android-toolbar,Android,Android Layout,Android Actionbar,Android Toolbar,我一直在尝试使用新的设计库,我有一个工具栏,而不是不推荐的操作栏。问题是工具栏占据了活动中的整个区域。我尝试了不同的示例,并用它们替换了布局文件,我尝试了不同的宽度和高度值。我不知道为什么会这样。没有一个是有效的!这可能是什么原因造成的 非常感谢您的帮助 activity_main.xml <android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/drawer_layout"
android:layout_width="match_parent"
android:fitsSystemWindows="true"
android:layout_height="match_parent">
<include
android:id="@+id/tool_bar"
layout="@layout/app_bar"
></include>
<RelativeLayout
android:id="@+id/container"
android:layout_width="match_parent"
android:layout_height="match_parent"
>
</RelativeLayout>
<android.support.design.widget.NavigationView
android:id="@+id/nav_draw"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="start"
app:headerLayout="@layout/drawer_header"
app:menu="@menu/drawer" />
</android.support.v4.widget.DrawerLayout>
应用程序工具栏布局文件
<?xml version="1.0" encoding="utf-8"?>
<android.support.v7.widget.Toolbar
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:background="?attr/colorPrimary"
android:elevation="4dp"
android:theme="@style/ThemeOverlay.AppCompat.ActionBar"
app:popupTheme="@style/ThemeOverlay.AppCompat.Light"/>
只需将此工具栏添加到您的容器中,下面的代码对我来说非常有用:
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="match_parent">
<FrameLayout
android:id="@+id/fragmentContainer"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
<android.support.v7.widget.Toolbar
android:id="@+id/mainToolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:layout_alignParentTop="true">
</android.support.v7.widget.Toolbar>
</RelativeLayout>
只需将此工具栏添加到您的容器中,下面的代码对我非常有用:
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="match_parent">
<FrameLayout
android:id="@+id/fragmentContainer"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
<android.support.v7.widget.Toolbar
android:id="@+id/mainToolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:layout_alignParentTop="true">
</android.support.v7.widget.Toolbar>
</RelativeLayout>
您可以像普通视图一样使用工具栏。所以您不需要使用settoolbar方法。
只需在布局中编写以下代码:
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.v7.widget.Toolbar
android:id="@+id/mainToolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:layout_alignParentTop="true"
android:background="@drawable/bottom_line_shape">
//here you can add as many views as you want just like a simple layout can
</android.support.v7.widget.Toolbar>
</RelativeLayout>
//在这里,您可以添加任意多的视图,就像简单的布局一样
您可以像普通视图一样使用工具栏。所以您不需要使用settoolbar方法。
只需在布局中编写以下代码:
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.v7.widget.Toolbar
android:id="@+id/mainToolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
android:layout_alignParentTop="true"
android:background="@drawable/bottom_line_shape">
//here you can add as many views as you want just like a simple layout can
</android.support.v7.widget.Toolbar>
</RelativeLayout>
//在这里,您可以添加任意多的视图,就像简单的布局一样
抽屉布局
s应该有两个孩子:
- 内容儿童李>
- 导航抽屉的孩子
按照这个特定的顺序。通过
关闭工具栏,您正在添加第三个子项,这是不允许的。应将工具栏和内容框架合并到一个布局中:
<android.support.v4.widget.DrawerLayout>
<LinearLayout
android:id="@+id/main_container"
android:orientation="vertical">
<include
android:id="@+id/tool_bar"
layout="@layout/app_bar" />
<RelativeLayout android:id="@+id/container" />
</LinearLayout>
<android.support.design.widget.NavigationView />
</android.support.v4.widget.DrawerLayout>
抽屉布局
s应该有两个孩子:
- 内容儿童李>
- 导航抽屉的孩子
按照这个特定的顺序。通过
关闭工具栏,您正在添加第三个子项,这是不允许的。应将工具栏和内容框架合并到一个布局中:
<android.support.v4.widget.DrawerLayout>
<LinearLayout
android:id="@+id/main_container"
android:orientation="vertical">
<include
android:id="@+id/tool_bar"
layout="@layout/app_bar" />
<RelativeLayout android:id="@+id/container" />
</LinearLayout>
<android.support.design.widget.NavigationView />
</android.support.v4.widget.DrawerLayout>
谢谢您的完整回答。现在修好了。它只有一个问题。没有海拔高度。尽管我添加了立面和AppBarLayout作为其父项。你猜为什么会这样吗?从棒棒糖开始,仰角只起作用。你正在Kitkat上测试,所以你不会有任何阴影。虽然你可以添加一个假阴影,但有很多问题。我在棒棒糖模拟器上测试过。它也没有海拔高度。不知道,抱歉。尝试将android:elevation添加到include标记。谢谢您的完整回答。现在修好了。它只有一个问题。没有海拔高度。尽管我添加了立面和AppBarLayout作为其父项。你猜为什么会这样吗?从棒棒糖开始,仰角只起作用。你正在Kitkat上测试,所以你不会有任何阴影。虽然你可以添加一个假阴影,但有很多问题。我在棒棒糖模拟器上测试过。它也没有海拔高度。不知道,抱歉。尝试将android:elevation添加到include标记。