我想在滚动内容时隐藏TabLayout。目前我在网上搜索但我找到了隐藏工具栏的示例,但我想隐藏TabLayout。所以请帮助我。我试过下面的代码。
<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/main_content"
android:layout_width="match_parent"
android:layout_height="match_parent">
<android.support.design.widget.AppBarLayout
android:id="@+id/id_appbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:fitsSystemWindows="true">
<android.support.v7.widget.Toolbar
android:id="@+id/id_toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
app:layout_scrollFlags="scroll|enterAlways"/>
<android.support.design.widget.TabLayout
android:id="@+id/id_tabs"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
style="@style/MyCustomTabLayout"/>
</android.support.design.widget.AppBarLayout>
<android.support.v4.view.ViewPager
android:id="@+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>
以下是示例应用程序: https://play.google.com/store/apps/details?id=com.contextlogic.wish https://play.google.com/store/apps/details?id=co.vine.android
答案 0 :(得分:34)
尝试这种方法。主要思想是将工具栏移动到CoordinatorLayout之外,并使用其他容器布局包装此视图结构。
<RelativeLayout 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:id="@+id/id_toolbar_container"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:fitsSystemWindows="true">
<android.support.v7.widget.Toolbar
android:id="@+id/id_toolbar"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize"
app:layout_collapseMode="pin"
app:layout_scrollFlags="scroll|exitUntilCollapsed" />
</android.support.design.widget.AppBarLayout>
<android.support.design.widget.CoordinatorLayout
android:id="@+id/main_content"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_below="@id/id_toolbar_container">
<android.support.design.widget.AppBarLayout
android:id="@+id/id_appbar"
android:layout_width="match_parent"
android:layout_height="wrap_content">
<android.support.design.widget.CollapsingToolbarLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:layout_scrollFlags="scroll|enterAlways">
<android.support.design.widget.TabLayout
android:id="@+id/id_tabs"
android:layout_width="match_parent"
android:layout_height="?attr/actionBarSize" />
</android.support.design.widget.CollapsingToolbarLayout>
</android.support.design.widget.AppBarLayout>
<android.support.v4.view.ViewPager
android:id="@+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>
</RelativeLayout>
答案 1 :(得分:5)
在滚动动画时, CoordinatorLayout 开始以线性方式搜索 AppBarLayout 的所有子视图,并且一旦找到具有以下内容的布局,它将停止为布局设置动画非滚动标签。
Exp1:
<CoordinatorLayout>
<AppBarLayout>
<layout1 with scrollFlag = "scroll|enterAlways">
<layout2 with no scrollFlag>
</AppBarLayout>
</CoordinatorLayout>
Only layout1 will have animation
Exp2:
<CoordinatorLayout>
<AppBarLayout>
<layout1 with no scrollFlag>
<layout2 with scrollFlag = "scroll|enterAlways">
</AppBarLayout>
</CoordinatorLayout>
None of them will have animation
Exp3:如果它们都不具有scrollFlag,则它们都不具有动画
Exp4:如果它们都具有scrollFlag,则它们都将具有动画
在这种情况下,您需要将工具栏保持在协调器布局之外,并使用scrollFlags =“ scroll | enterAlway”将tablayout添加为AppBarLayout的子项
答案 2 :(得分:1)
您好希望消失工具栏并且标签仍然可以查看,您必须编写下一个代码:
<android.support.v7.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
app:layout_scrollFlags="scroll|enterAlways"
></android.support.v7.widget.Toolbar>
如果要隐藏TabLayout,请在TabLayout块中使用scrollFlags
app:layout_scrollFlags="scroll|enterAlways"
答案 3 :(得分:0)
您需要将storyBoard
作为顶视图移动到布局中,并将其替换为Toolbar
,该View
将保留前Toolbar
个空格,并将在TabLayout
内滚动,在里面你的AppBarLayout
。
以下是设置布局的方法。
<android.support.design.widget.CoordinatorLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
android:id="@+id/preview_top_parent"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fitsSystemWindows="true">
<android.support.design.widget.AppBarLayout...>
<android.support.v4.view.ViewPager...>
<android.support.v7.widget.Toolbar/> <-!--- Toolbar is direct child of CooridnatorLayout and z-order above all views --!->
</android.support.design.widget.CoordinatorLayout>
这是video