即使在提供 "app:layout_scrollFlags" 标志后,工具栏也不会滚动
Toolbar is not scrolling off even after providing "app:layout_scrollFlags" flag
我正在尝试实现工具栏和 TabLayout,当您滚动回收视图时,它应该像 whatsapp 应用程序一样隐藏工具栏。我指的是 google Blog and Michal Z's Blog。我在 main activity 中有视图寻呼机,我正在使用 recycleview 显示其中的数据列表。
坦率地说,我被新的 google 设计库震惊了,因为仅需一行 XML 代码,它就可以改变完整的 UI 和 UI 行为。因此,理想情况下,我们需要在工具栏中添加 app:layout_scrollFlags="scroll|enterAlways"
行来实现此功能,它就可以正常工作。但对我来说它不起作用。我已经在 API 19 和 21 台设备上进行了测试。
通过 question question on stack overflow and various Blog Blog 我找到了实现此功能的两种方法 1. 通过为 recycleview 提供滚动侦听器和 2. 通过将可滚动内容放入 NestedScrollView
。但它并没有像预期的那样工作。
我认为它应该可以在不编写任何代码的情况下运行。
主要Activity.xml
<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.support.design.widget.AppBarLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:background="@color/colorPrimary"
android:layout_height="?attr/actionBarSize"
app:layout_scrollFlags="scroll|enterAlways"
app:popupTheme="@style/Base.ThemeOverlay.AppCompat.Dark"/>
<android.support.design.widget.TabLayout
android:id="@+id/sliding_tabs"
android:background="@color/colorPrimaryDark"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
</android.support.design.widget.AppBarLayout>
<android.support.v4.view.ViewPager
android:id="@+id/viewpager"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior"/>
</android.support.design.widget.CoordinatorLayout>
ViewPagerFragment.xml
<android.support.v4.widget.SwipeRefreshLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/swipe_refresh_layout"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:background="@color/windowBackground">
<android.support.v7.widget.RecyclerView
android:id="@+id/order_list"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_alignParentLeft= "true"
android:layout_alignParentStart="true"
android:layout_above="@+id/txtStatus" />
</android.support.v4.widget.SwipeRefreshLayout>
您的布局似乎是正确的。
检查您的 build.gradle
版本中的 recyclerView
是否恰好是 22.2.0
并且 buildToolsVersion
是 22.0.1
。您需要这样做,因为所有这些新功能都出现在 22.2.0 版本的支持库中,如前所述 here。
我正在尝试实现工具栏和 TabLayout,当您滚动回收视图时,它应该像 whatsapp 应用程序一样隐藏工具栏。我指的是 google Blog and Michal Z's Blog。我在 main activity 中有视图寻呼机,我正在使用 recycleview 显示其中的数据列表。
坦率地说,我被新的 google 设计库震惊了,因为仅需一行 XML 代码,它就可以改变完整的 UI 和 UI 行为。因此,理想情况下,我们需要在工具栏中添加 app:layout_scrollFlags="scroll|enterAlways"
行来实现此功能,它就可以正常工作。但对我来说它不起作用。我已经在 API 19 和 21 台设备上进行了测试。
通过 question question on stack overflow and various Blog Blog 我找到了实现此功能的两种方法 1. 通过为 recycleview 提供滚动侦听器和 2. 通过将可滚动内容放入 NestedScrollView
。但它并没有像预期的那样工作。
我认为它应该可以在不编写任何代码的情况下运行。
主要Activity.xml
<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.support.design.widget.AppBarLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:background="@color/colorPrimary"
android:layout_height="?attr/actionBarSize"
app:layout_scrollFlags="scroll|enterAlways"
app:popupTheme="@style/Base.ThemeOverlay.AppCompat.Dark"/>
<android.support.design.widget.TabLayout
android:id="@+id/sliding_tabs"
android:background="@color/colorPrimaryDark"
android:layout_width="match_parent"
android:layout_height="wrap_content" />
</android.support.design.widget.AppBarLayout>
<android.support.v4.view.ViewPager
android:id="@+id/viewpager"
android:layout_width="match_parent"
android:layout_height="match_parent"
app:layout_behavior="@string/appbar_scrolling_view_behavior"/>
</android.support.design.widget.CoordinatorLayout>
ViewPagerFragment.xml
<android.support.v4.widget.SwipeRefreshLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/swipe_refresh_layout"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:background="@color/windowBackground">
<android.support.v7.widget.RecyclerView
android:id="@+id/order_list"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentTop="true"
android:layout_alignParentLeft= "true"
android:layout_alignParentStart="true"
android:layout_above="@+id/txtStatus" />
</android.support.v4.widget.SwipeRefreshLayout>
您的布局似乎是正确的。
检查您的 build.gradle
版本中的 recyclerView
是否恰好是 22.2.0
并且 buildToolsVersion
是 22.0.1
。您需要这样做,因为所有这些新功能都出现在 22.2.0 版本的支持库中,如前所述 here。