在滚动视图中滚动时,如何将滚动视图内的选项卡布局固定到顶部?

时间:2020-09-07 11:34:47

标签: android kotlin

我已经考虑了很长时间了。

问题是将滚动视图内的选项卡布局应用于滚动视图外的顶部固定工具栏。

当滚动到达滚动视图内的选项卡布局时,我需要确保该选项卡布局自然地固定在滚动视图区域之外的顶部工具栏上。

当然,页面没有刷新和滚动的位置必须准确地继续。

寻找了很多方法,但是没有。有人可以帮忙吗?

<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout
    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:id="@+id/constraintLayout"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <LinearLayout
        android:id="@+id/lay_first"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent">

        <androidx.constraintlayout.widget.ConstraintLayout
            android:id="@+id/top_bar"
            android:layout_width="match_parent"
            android:layout_height="80dp"
            android:background="#ffffff"
            app:layout_constraintEnd_toEndOf="parent"
            app:layout_constraintStart_toStartOf="parent"
            app:layout_constraintTop_toTopOf="@+id/lay_first"
            app:layout_constraintBottom_toTopOf="@+id/mainScrollview">

        </androidx.constraintlayout.widget.ConstraintLayout>

        
        <androidx.core.widget.NestedScrollView
            android:id="@+id/mainScrollview"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:fillViewport="true">

            <LinearLayout
                android:descendantFocusability="blocksDescendants"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:orientation="vertical">

                <com.wine.app.mashijago.util.SqaureFrameLayout
                    android:id="@+id/square_imageSlider"
                    android:layout_width="match_parent"
                    android:layout_height="wrap_content">

                    <com.example.imageslider.ImageSlider
                        android:id="@+id/image_slider"
                        android:layout_width="match_parent"
                        android:layout_height="match_parent"
                        app:layout_constraintDimensionRatio="1:1"
                        app:iss_auto_cycle="true"
                        app:iss_delay="0"
                        app:iss_error_image="@drawable/error"
                        app:iss_period="3000"
                        app:iss_selected_dot="@drawable/default_selected_dot"
                        app:iss_text_align="CENTER"
                        app:iss_title_background="@drawable/gradient"
                        app:iss_unselected_dot="@drawable/default_unselected_dot" />

                </com.wine.app.mashijago.util.SqaureFrameLayout>

                <androidx.constraintlayout.widget.ConstraintLayout
                    android:layout_width="match_parent"
                    android:layout_height="match_parent"
                    android:orientation="vertical">

                    <com.google.android.material.tabs.TabLayout
                        android:id="@+id/tab"
                        android:layout_width="match_parent"
                        android:layout_height="52dp"
                        android:layout_marginLeft="8dp"
                        android:layout_marginRight="8dp"
                        android:layout_marginBottom="4dp"
                        android:background="#ffffff"
                        android:visibility="visible"
                        app:layout_constraintBottom_toBottomOf="parent"
                        app:layout_constraintEnd_toEndOf="parent"
                        app:layout_constraintHorizontal_bias="0.0"
                        app:layout_constraintStart_toStartOf="parent"
                        app:layout_constraintTop_toTopOf="parent"
                        app:layout_constraintVertical_bias="0.0"
                        app:tabIndicatorColor="#000000"
                        app:tabSelectedTextColor="#101010"
                        app:tabTextColor="#b1b1b1"
                        tools:ignore="DuplicateIds">

                        <com.google.android.material.tabs.TabItem
                            android:layout_width="wrap_content"
                            android:layout_height="wrap_content"
                            android:text="1" />

                        <com.google.android.material.tabs.TabItem
                            android:layout_width="wrap_content"
                            android:layout_height="wrap_content"
                            android:text="2" />

                        <com.google.android.material.tabs.TabItem
                            android:layout_width="wrap_content"
                            android:layout_height="wrap_content"
                            android:text="3" />

                        <com.google.android.material.tabs.TabItem
                            android:layout_width="wrap_content"
                            android:layout_height="wrap_content"
                            android:text="4" />
                    </com.google.android.material.tabs.TabLayout>
                    
                    <com.wine.app.mashijago.adapter.WrapContentViewPager
                        android:id="@+id/category_viewpager"
                        android:layout_width="match_parent"
                        android:layout_height="wrap_content"
                        app:layout_constraintTop_toBottomOf="@+id/tab"
                        app:layout_constraintStart_toStartOf="parent"
                        app:layout_constraintEnd_toEndOf="parent"/>

                </androidx.constraintlayout.widget.ConstraintLayout>
            </LinearLayout>
        </androidx.core.widget.NestedScrollView>
    </LinearLayout>


    <include
        android:id="@+id/appbar"
        layout="@layout/activity_main_app_bar"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:elevation="1dp"
        android:layout_marginTop="20dp"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="@+id/lay_first"

       />

    <include
        android:id="@+id/main_footer"
        layout="@layout/view_footer"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:elevation="1dp"
        android:visibility="gone"
        app:layout_constraintBottom_toBottomOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        />


</androidx.constraintlayout.widget.ConstraintLayout>

Before image enter image description here

0 个答案:

没有答案