打开屏幕键盘导致工具栏滚动出视线

时间:2016-01-19 14:16:14

标签: android android-fragments android-toolbar android-coordinatorlayout

在屏幕键盘弹出时,我们Activity的其中一个滚动屏幕已损坏。

如果内容适合屏幕并且没有键盘可见,则Activity如下所示:

View with closed keyboard

如果键盘打开且用户输入几行,则工具栏开始滚动显示:

Keyboard open with content underneath status & toolbar

在某些时候工具栏完全消失了:

Keyboard open with content even more underneath status & toolbar

如果键盘未打开,则滚动效果正常:

Scrolling without keyboard works fine

Activity仅包含FrameLayout,其他所有内容均由Fragment提供。

<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:id="@+id/task_detail_container"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="@android:color/white"
    android:fitsSystemWindows="true"
    tools:context=".TaskDetailActivity"
    tools:ignore="MergeRootFrame" />

Fragment使用CoordinatorLayout,如下所示:

<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:fitsSystemWindows="true" >

    <android.support.design.widget.AppBarLayout
        android:id="@+id/appbar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:fitsSystemWindows="true"
        android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
        app:elevation="0dp" >

        <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"
            android:minHeight="?attr/actionBarSize" >

            <org.dmfs.tasks.widget.TaskView
                xmlns:android="http://schemas.android.com/apk/res/android"
                xmlns:app="http://schemas.android.com/apk/res-auto"
                android:id="@+id/toolbar_content"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                app:layout_collapseMode="parallax"
                android:orientation="vertical"
                android:paddingTop="?attr/actionBarSize" >

                <org.dmfs.tasks.widget.TextFieldView
                    android:id="@+id/task_title"
                    android:layout_width="match_parent"
                    android:layout_height="wrap_content"
                    android:layout_margin="8dp"
                    app:layout_behavior="@string/appbar_scrolling_view_behavior"
                    app:layout_scrollFlags="scroll|enterAlways"
                    android:gravity="center_vertical"
                    android:minHeight="?attr/actionBarSize"
                    android:paddingEnd="48dp"
                    android:paddingLeft="48dp"
                    android:paddingRight="48dp"
                    android:paddingStart="48dp"
                    app:fieldDescriptor="@id/task_field_title" >

                    <TextView
                        android:id="@+id/text"
                        android:layout_width="match_parent"
                        android:layout_height="wrap_content"
                        android:autoLink="none"
                        android:ellipsize="end"
                        android:lineSpacingMultiplier="1.1"
                        android:maxLines="3"
                        android:textColor="#ffffffff"
                        android:textColorLink="#d0ffffff"
                        android:textSize="28sp" >
                    </TextView>
                </org.dmfs.tasks.widget.TextFieldView>

                <org.dmfs.tasks.widget.TimeFieldView
                    xmlns:android="http://schemas.android.com/apk/res/android"
                    style="@style/task_widget"
                    app:layout_behavior="@string/appbar_scrolling_view_behavior"
                    app:layout_scrollFlags="scroll"
                    android:orientation="vertical"
                    android:paddingEnd="56dp"
                    android:paddingLeft="56dp"
                    android:paddingStart="56dp"
                    android:visibility="gone"
                    app:fieldDescriptor="@id/task_field_due" >

                    <TextView
                        android:id="@android:id/text1"
                        style="@style/field_view_text_value"
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:drawableLeft="@drawable/ic_tab_due"
                        android:drawablePadding="12dp"
                        android:drawableStart="@drawable/ic_tab_due"
                        android:gravity="center_vertical"
                        android:includeFontPadding="false"
                        android:textColor="#ffffffff"
                        android:textSize="18sp" >
                    </TextView>

                    <TextView
                        android:id="@android:id/text2"
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_marginLeft="44dp"
                        android:textColor="#ffffffff" >
                    </TextView>

                    <LinearLayout
                        android:id="@+id/buttons"
                        android:layout_width="match_parent"
                        android:layout_height="wrap_content"
                        android:layout_marginLeft="44dp"
                        android:orientation="horizontal"
                        android:visibility="gone" >

                        <TextView
                            android:id="@+id/button_add_one_day"
                            style="@style/time_forward_button"
                            android:layout_width="wrap_content"
                            android:layout_height="wrap_content"
                            android:drawableLeft="@drawable/ic_detail_delay_1d"
                            android:drawablePadding="8dp"
                            android:drawableStart="@drawable/ic_detail_delay_1d"
                            android:text="@string/button_add_one_day"
                            android:textColor="#a0ffffff" />

                        <TextView
                            android:id="@+id/button_add_one_hour"
                            style="@style/time_forward_button"
                            android:layout_width="wrap_content"
                            android:layout_height="wrap_content"
                            android:layout_marginLeft="24dp"
                               android:drawableLeft="@drawable/ic_detail_delay_1h"
                            android:drawablePadding="8dp"
                            android:drawableStart="@drawable/ic_detail_delay_1h"
                            android:text="@string/button_add_one_hour"
                            android:textColor="#a0ffffff" />
                    </LinearLayout>
                </org.dmfs.tasks.widget.TimeFieldView>
            </org.dmfs.tasks.widget.TaskView>
        </android.support.design.widget.CollapsingToolbarLayout>
    </android.support.design.widget.AppBarLayout>

    <android.support.v4.widget.NestedScrollView
        xmlns:android="http://schemas.android.com/apk/res/android"
        xmlns:tools="http://schemas.android.com/tools"
        android:id="@+id/scrollView"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        app:layout_behavior="@string/appbar_scrolling_view_behavior" >

        <LinearLayout
            android:id="@+id/content"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:orientation="vertical" >
        </LinearLayout>
    </android.support.v4.widget.NestedScrollView>

    <android.support.design.widget.FloatingActionButton
        android:id="@+id/floating_action_button"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:layout_margin="16dp"
        app:layout_anchor="@id/appbar"
        app:layout_anchorGravity="bottom|right|end"
        android:src="@drawable/ic_action_complete" />

    <android.support.v7.widget.Toolbar
        android:id="@+id/toolbar"
        android:layout_width="match_parent"
        android:layout_height="?attr/actionBarSize"
        app:layout_anchor="@id/toolbar_content"
        android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"
        app:popupTheme="@style/ThemeOverlay.AppCompat.Light" >

        <TextView
            android:id="@+id/toolbar_title"
            android:layout_width="wrap_content"
            android:layout_height="match_parent"
            android:ellipsize="end"
            android:gravity="center_vertical"
            android:maxLines="1"
            android:singleLine="true"
            android:text=""
            android:textColor="@android:color/white"
            android:textSize="24sp" />
    </android.support.v7.widget.Toolbar>

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

@+id/content LinearLayout在运行时填充。

我们有另一项活动既不使用CoordinatorLayout也不使用Toolbar,而是使用ScrollView代替并显示完全相同的症状。您可以在此处查看:https://github.com/dmfs/opentasks/blob/master/res/layout/activity_task_editor.xmlhttps://github.com/dmfs/opentasks/blob/master/res/layout/fragment_task_edit_detail.xml

我们使用以下依赖项:

compile 'com.android.support:appcompat-v7:23.1.1'
compile 'com.android.support:design:23.1.1'

任何可能导致这种情况的提示都表示赞赏。

0 个答案:

没有答案