Как остановить переполнение панели приложений?

#android #android-layout #android-toolbar #android-coordinatorlayout

#Android #android-макет #android-панель инструментов #android-coordinatorlayout

Вопрос:

Я пытаюсь реализовать CoordinatorLayout . Но когда я пытаюсь применить приведенный ниже код для определения XML-файла, он также перекрывает панель приложений. Что я должен сделать, чтобы остановить перекрытие на панели приложений?

Вот 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"
    tools:ignore="RtlHardcoded">

    <android.support.design.widget.AppBarLayout
        android:id="@ id/main.appbar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">

        <android.support.design.widget.CollapsingToolbarLayout
            android:id="@ id/main.collapsing"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            app:layout_scrollFlags="scroll|exitUntilCollapsed|snap">

            <ImageView
                android:id="@ id/main.imageview.placeholder"
                android:layout_width="match_parent"
                android:layout_height="300dp"
                android:scaleType="centerCrop"
                android:src="@drawable/quila2"
                android:tint="#11000000"
                app:layout_collapseMode="parallax"
                app:layout_collapseParallaxMultiplier="0.9" />

            <FrameLayout
                android:id="@ id/main.framelayout.title"
                android:layout_width="match_parent"
                android:layout_height="100dp"
                android:layout_gravity="bottom|center_horizontal"
                android:background="#00838F"
                android:orientation="vertical"
                app:layout_collapseMode="parallax"
                app:layout_collapseParallaxMultiplier="0.3">

                <LinearLayout
                    android:id="@ id/main.linearlayout.title"
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:layout_gravity="center"
                    android:orientation="vertical">

                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_gravity="center_horizontal"
                        android:gravity="bottom|center"
                        android:text="Subbu kummithi"
                        android:textColor="@android:color/white"
                        android:textSize="30sp" />

                    <TextView
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_gravity="center_horizontal"
                        android:layout_marginTop="4dp"
                        android:text="@string/role_name"
                        android:textColor="@android:color/white" />

                </LinearLayout>
            </FrameLayout>
        </android.support.design.widget.CollapsingToolbarLayout>
    </android.support.design.widget.AppBarLayout>


    <android.support.v4.widget.NestedScrollView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:scrollbars="none"
        app:behavior_overlapTop="30dp"
        app:layout_behavior="@string/appbar_scrolling_view_behavior">

        <android.support.v7.widget.CardView
            android:id="@ id/card_id"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_margin="8dp"
            app:cardElevation="8dp"
            app:contentPadding="16dp">

            <TextView
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:lineSpacingExtra="8dp"
                android:text="This is for new activity This is for new activity This is for new activity"
                android:textSize="18sp" />
        </android.support.v7.widget.CardView>


    </android.support.v4.widget.NestedScrollView>

    <android.support.v7.widget.Toolbar
        android:id="@ id/main.toolbar"
        android:layout_width="match_parent"
        android:layout_height="?attr/actionBarSize"
        android:background="#00838F"
        app:layout_anchor="@id/main.framelayout.title"
        app:theme="@style/ThemeOverlay.AppCompat.Dark"
        app:title="">

        <LinearLayout
            android:layout_width="wrap_content"
            android:layout_height="match_parent"
            android:orientation="horizontal">

            <Space
                android:layout_width="@dimen/image_final_width"
                android:layout_height="@dimen/image_final_width" />

            <TextView
                android:id="@ id/main.textview.title"
                android:layout_width="wrap_content"
                android:layout_height="match_parent"
                android:layout_marginLeft="8dp"
                android:gravity="center_vertical"
                android:text="Welcome Mr. Subbu"
                android:textColor="@android:color/white"
                android:textSize="20sp" />

        </LinearLayout>
    </android.support.v7.widget.Toolbar>

    <de.hdodenhof.circleimageview.CircleImageView
        android:layout_width="@dimen/image_width"
        android:layout_height="@dimen/image_width"
        android:layout_gravity="center_horizontal"
        android:src="@drawable/quila"
        app:border_color="@android:color/white"
        app:border_width="2dp"
        app:finalHeight="@dimen/image_final_width"
        app:finalYPosition="2dp"
        app:layout_behavior="com.realmilk.activities.AvatarImageBehavior"
        app:startHeight="2dp"
        app:startToolbarPosition="2dp"
        app:startXPosition="2dp" />
</android.support.design.widget.CoordinatorLayout>
  

И вот результат, когда я запускаю приведенный выше код:

Наложение на панель приложений

Есть идеи?

Комментарии:

1. Как насчет добавления android:fitsSystemWindows="true" в AppBarLayout и нет CoordinatorLayout ? Это должно устранить проблему..

2. На самом деле… Почему у вас есть Toolbar элемент вне AppBarLayout и под a NestedScrollView ?

3. Я не могу понять.. вы имеете в виду, что я должен поместить внутри AppBarLayout или NestedScrollView. Где я должен разместить?

Ответ №1:

попробуйте добавить атрибут android:fitsSystemWindows="true" в свой CoordinatorLayout

 <?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:ignore="RtlHardcoded">
.....
  

Комментарии:

1. после добавления android:fitsSystemWindows =»true» появляется половина панели, что означает, что оставшаяся часть снова перекрывается.

2. @KiranRaju Я думаю, что это также нужно добавить в AppBarLayout

3. я добавил, но бесполезно, все равно он ведет себя как раньше.

Ответ №2:

Установите android:fitsSystemWindows="true" в CoordinatorLayout, AppBarLayout и CollapsingToolbarLayout, чтобы зарезервировать место сверху.

Если вы хотите, чтобы фоновое изображение начиналось за прозрачной строкой состояния, также установленной android:fitsSystemWindows="true" в main.imageview.placeholder.

Комментарии:

1. Я добавил в ImageView, но результат такой же, как и раньше .. ничего не меняется, он снова перекрывает половину прозрачной панели.

2. Поскольку панель инструментов находится вне CollapsingToolbarLayout и привязана к main.framelayout.title, она не имеет защиты от верхней вставки. Одним из способов может быть добавление верхнего поля на панель инструментов и настройка математики в поведении аватара.