如何在Android中使工具栏不重叠其他内容?

27

我正在开发一个带有工具栏的活动(示例大致来自教程),但是工具栏总是会重叠其他内容的一部分。这是一个截图:

enter image description here

蓝色的工具栏覆盖了其他内容的一部分。我尝试在SO上搜索类似的问题,但只找到了无关的内容。我还尝试更改一些元素的顺序并替换wrap_content <-> match_parent,但最多只能恶化布局。

我确信我错过了一些非常基础的东西,但我看不出来是什么。

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

    <android.support.design.widget.AppBarLayout
        android:layout_height="wrap_content"
        android:layout_width="match_parent"
        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"/>

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

    <include layout="@layout/content_main" />

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

content_main.xml的代码:

<?xml version="1.0" encoding="utf-8"?>
  <GridLayout
        xmlns:android="http://schemas.android.com/apk/res/android"

        android:layout_width="wrap_content"
        android:layout_height="match_parent"

        android:useDefaultMargins="true"
        android:alignmentMode="alignBounds"
        android:columnOrderPreserved="false"

        android:columnCount="4"
        >

    <TextView
            android:text="@string/MainTitle"
            android:textSize="32dip"
            android:layout_columnSpan="4"
            android:layout_gravity="center_horizontal"
            android:id="@+id/textView1"
            />

    <TextView
            android:text="You can configure email in just a few steps:"
            android:textSize="16dip"

            android:layout_columnSpan="4"
            android:layout_gravity="left"
            />

    <TextView
            android:text="Email address:"

            android:layout_gravity="right"
            />

    <EditText
            android:ems="10"
            />

    <TextView
            android:text="Password:"

            android:layout_column="0"
            android:layout_gravity="right"
            />

    <EditText
            android:ems="8"
            />

    <Space
            android:layout_row="4"
            android:layout_column="0"
            android:layout_columnSpan="3"
            android:layout_gravity="fill"
            />

    <Button
            android:text="Next"
            android:id="@+id/imageButton1"
            android:layout_row="5"
            android:layout_column="3"
            />
</GridLayout>

看我的回答。你仍然可以使用<include>标签。不要在主布局中替换整个内容。 - Henry
6个回答

87

<include layout="@layout/content_main"/>替换为以下内容:

   <include layout="@layout/content_main" 
      android:layout_width="match_parent" 
      android:layout_height="match_parent"
      app:layout_behavior="@string/appbar_scrolling_view_behavior"/>

这对我起作用了。在“content_main”中添加layout_behavior的东西也可以,我的意思是,在包含的文件中添加,而不是在activity_main中添加。 - Jahaziel
完美地工作了。我最初忘记了包括compile 'com.android.support:design:26.0.1',所以找不到app:layout_behaviour。 - Yuliwee

25

将以下内容添加到工具栏下方的视图中

app:layout_behavior="@string/appbar_scrolling_view_behavior"

我不得不将这个添加到内容布局文件中。谢谢。 - Usama Saeed US

8

在你的布局中尝试这个:

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

    <android.support.design.widget.AppBarLayout
        android:layout_height="wrap_content"
        android:layout_width="match_parent"
        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"/>

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

    <GridLayout
        xmlns:android="http://schemas.android.com/apk/res/android"
        app:layout_behavior="@string/appbar_scrolling_view_behavior"
        android:layout_width="match_parent"
        android:layout_height="match_parent"

        android:useDefaultMargins="true"
        android:alignmentMode="alignBounds"
        android:columnOrderPreserved="false"

        android:columnCount="4"
        >

        <TextView
            android:text="MainTitle"
            android:textSize="32dip"
            android:layout_columnSpan="4"
            android:layout_gravity="center_horizontal"
            android:id="@+id/textView1"
            />

        <TextView
            android:text="You can configure email in just a few steps:"
            android:textSize="16dip"

            android:layout_columnSpan="4"
            android:layout_gravity="left"
            />

        <TextView
            android:text="Email address:"

            android:layout_gravity="right"
            />

        <EditText
            android:ems="10"
            />

        <TextView
            android:text="Password:"

            android:layout_column="0"
            android:layout_gravity="right"
            />

        <EditText
            android:ems="8"
            />

        <Space
            android:layout_row="4"
            android:layout_column="0"
            android:layout_columnSpan="3"
            android:layout_gravity="fill"
            />

        <Button
            android:text="Next"
            android:id="@+id/imageButton1"
            android:layout_row="5"
            android:layout_column="3"
            />
    </GridLayout>

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

我猜这个要放到 activity_main.xml 里面吧? - Alex
是的,你肯定应该这样做。如果使用Android Studio,请刷新预览一次。 - Aakash
哇,看起来终于可以工作了!但是 app:layout_behavior 到底是做什么的? - Alex
让我们在聊天中继续这个讨论 - Alex
我知道那个,只是想向Alex澄清一下。 - Aakash
显示剩余3条评论

6
只是一个简单的修改就解决了问题。
我的之前的代码:
activity_device_scan.xml
    <include layout="@layout/content_device_scan"/>

New

activity_device_scan.xml:

    <include layout="@layout/content_device_scan"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:layout_behavior="@string/appbar_scrolling_view_behavior"/>

0

我将activity_main中的CoordinatorLayout更改为垂直线性布局,它起作用了。我让Android Studio为我转换了视图类型,一开始它破坏了我的content_main的包含。我在转换过程中恢复了include调用。


0

如果

"@string/appbar_scrolling_view_behavior"

如果不起作用,尝试直接调用它,例如

app:layout_behavior="android.support.design.widget.AppBarLayout$ScrollingViewBehavior"

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接