如何像Watsapp一样通过tablayout实现折叠工具栏

问题描述 投票:0回答:1

Xml 文件

<?xml version="1.0" encoding="utf-8"?>
<androidx.coordinatorlayout.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:context=".MainActivity">

    <com.google.android.material.appbar.AppBarLayout
        android:id="@+id/app_bar_layout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:fitsSystemWindows="true"
        android:theme="@style/ThemeOverlay.AppCompat.Dark.ActionBar">


        <com.google.android.material.appbar.CollapsingToolbarLayout
            android:id="@+id/collapsingToolbar"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            app:layout_scrollFlags="scroll|exitUntilCollapsed">

            <androidx.appcompat.widget.Toolbar
                android:id="@+id/toolbar"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
               >

                <TextView
                    android:layout_width="wrap_content"
                    android:layout_height="wrap_content"
                    android:text="@string/app_name"
                    android:textSize="22sp"
                    android:textColor="@color/black"
                    />

            </androidx.appcompat.widget.Toolbar>

        </com.google.android.material.appbar.CollapsingToolbarLayout>

        <com.google.android.material.tabs.TabLayout
            android:id="@+id/tab_layout"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            app:layout_collapseMode="pin"
            />

    </com.google.android.material.appbar.AppBarLayout>

    <androidx.viewpager2.widget.ViewPager2
        android:id="@+id/view_pager"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        app:layout_behavior="com.google.android.material.appbar.AppBarLayout$ScrollingViewBehavior"/>

</androidx.coordinatorlayout.widget.CoordinatorLayout>

在 Watsapp 主屏幕中,当用户向上滚动时,工具栏会消失,只有选项卡布局可见。我只是想实现这个功能。我浏览了很多 youtube 教程但找不到任何解决方案。

类似这样的东西 - https://i.stack.imgur.com/76m5h.gif

android kotlin android-tablayout android-collapsingtoolbarlayout
1个回答
0
投票

将工具栏放入

CollapsingToolbarLayout

app:layout_scrollFlags="scroll|exitUntilCollapsed"
添加到折叠工具栏

从工具栏中删除

app:layout_collapseMode="pin"

app:layout_collapseMode="pin"
添加到选项卡

app:layout_behavior="com.google.android.material.appbar.AppBarLayout$ScrollingViewBehavior"
添加到您的视图页面

© www.soinside.com 2019 - 2024. All rights reserved.