0

ブログ投稿のように、recylerview を使用してツールバーを実装しました。しかし、ナビゲーション ドロワーも追加しました。次の手順を実行すると、スクロール後に再度入力するとツールバーが白くなります

  1. スクロールダウンRecyclerView_Toolbar
  2. NavigationDrawer左にスライドして開く
  3. NavigationDrawer右端で閉じる
  4. スクロールアップRecyclerView
  5. Toolbarこれが白くなった後に現れる

膨らんだメニュー項目をクリックできるので、ツールバーがまだそこにあることを知っています。ツールバーのハンバーガー アイコンをクリックすると、元の色に戻ります。

これがどのように判明したかのイメージです 画像

コードで実装した方法は次のとおりです

ツールバー.xml

 <?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/my_awesome_toolbar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_gravity="top"
        android:background="?attr/colorPrimary"
        android:minHeight="?attr/actionBarSize"
        app:layout_scrollFlags="scroll|enterAlways"
        app:popupTheme="@style/ThemeOverlay.AppCompat.Light"
        app:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar"/>

activity_main.xml

<android.support.v4.widget.DrawerLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@+id/drawer_layout"
    >

    <android.support.design.widget.CoordinatorLayout
        android:layout_height="match_parent"
        android:layout_width="match_parent"
        >

        <android.support.design.widget.AppBarLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content">

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

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

      <FrameLayout
          android:id="@+id/container"
          android:layout_width="fill_parent"
          android:layout_height="fill_parent"
          app:layout_behavior="@string/appbar_scrolling_view_behavior"/>



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


        <fragment
            android:id="@+id/navigation_drawer"
            android:name="aungkyawpaing.yangonuniversity.Fragments.NavigationDrawerFragment"
            android:layout_width="@dimen/navigation_drawer_width"
            android:layout_height="match_parent"
            android:layout_gravity="start|left"
            tools:layout="@layout/fragment_navigation_drawer"/>

</android.support.v4.widget.DrawerLayout>
4

2 に答える 2

1

ライブラリ 23.3.0 を使用しています。そしてバグはまだ発生します。

これに対する回避策は、ほとんどスペースを必要とせず、非表示にできるビューを追加することです。以下の構造を参照してください。

<android.support.v4.widget.NestedScrollView
    app:layout_behavior="@string/appbar_scrolling_view_behavior">

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

<android.support.design.widget.AppBarLayout>

    <android.support.v7.widget.Toolbar
        app:layout_scrollFlags="scroll|enterAlways" />

    <android.support.design.widget.TabLayout
        app:layout_scrollFlags="scroll|enterAlways" />

    <View
        android:layout_width="match_parent"
        android:layout_height=".3dp"
        android:visibility="visible"/>

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

詳細については、https://code.google.com/p/android/issues/detail?id=178037を参照してください。

于 2016-05-30T23:44:32.377 に答える
0

デザイン ライブラリのバグです https://code.google.com/p/android/issues/detail?id=178037

このバグは v22.2.1 でリリースされて解決されました。

于 2015-08-03T07:53:08.580 に答える