Как прокрутить Cardview и прикрепить TabLayout под панелью инструментов в Android? - PullRequest
1 голос
/ 29 мая 2020

Я пытаюсь прокрутить содержимое окна просмотра карты, когда прокрутка завершена, у меня есть пейджер просмотра, содержащий макет вкладок под видом карты, который я хочу прикрепить этот пейджер просмотра под панелью инструментов.

Например : Моя структура макета перед прокруткой

----------------
    ToolBar
----------------
   Cardview

   contents
      . 
      .
      .
      .
----------------
   ViewPager

   TabLayout
-----------------

, и когда прокручивается это содержимое Card View, мне нужна структура, как показано ниже.

----------------
    ToolBar
----------------
   ViewPager

   TabLayout
-----------------

Я пытаюсь прикрепить свой ViewPager под панелью инструментов, когда карточный вид полностью прокручен. Я разработал макет. xml, как показано ниже.

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
    android:orientation="vertical"
    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"
    android:background="#e6e6e6"
    tools:context=".ViewerActivity">

    <androidx.appcompat.widget.Toolbar
        app:title="Post View"
        android:id="@+id/PostViewerToolbar"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"/>

    <ScrollView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        tools:ignore="ScrollViewCount">
        <LinearLayout
            android:orientation="vertical"
            android:layout_width="match_parent"
            android:layout_height="match_parent">

            <androidx.cardview.widget.CardView
                android:layout_width="match_parent"
                android:layout_height="wrap_content">

                    <ImageView
                        android:layout_marginTop="10dp"
                        android:id="@+id/SharedImg"
                        android:layout_gravity="center_horizontal"
                        android:adjustViewBounds="true"
                        android:layout_width="match_parent"
                        android:layout_height="wrap_content"/>

                    <View
                        android:layout_marginTop="10dp"
                        android:background="#f1f1f1"
                        android:layout_width="match_parent"
                        android:layout_height="2dp"/>
                    <TextView
                        android:layout_marginTop="10dp"
                        android:id="@+id/DescriptionTv"
                        android:text="Post description"
                        android:layout_width="match_parent"
                        android:layout_height="wrap_content"/>
                </LinearLayout>
            </androidx.cardview.widget.CardView>
        </LinearLayout>

    </ScrollView>


    <androidx.viewpager.widget.ViewPager
        android:id="@+id/Viewpager"
        android:layout_marginTop="5dp"
        android:layout_width="match_parent"
        android:layout_height="match_parent">

        <com.google.android.material.tabs.TabLayout
            android:id="@+id/InvolveTabLayout"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"/>
    </androidx.viewpager.widget.ViewPager>
</LinearLayout>

Как это сделать. Пожалуйста, помогите.

Ответы [ 2 ]

0 голосов
/ 29 мая 2020

вы могли бы использовать макет координатора и внутри использовать сворачивающуюся панель инструментов с прокруткой и установить для setNestedScrollingEnabled значение true в scrollview. Таким образом, scrollview реагирует на прокрутку пользователя и может свернуться, когда прокручиваемый вид полностью прокручен вверх.

, а также у вас есть закрывающие теги в неправильном положении, которые я разрешаю здесь.

<LinearLayout 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"
android:background="#e6e6e6"
android:orientation="vertical">


<androidx.coordinatorlayout.widget.CoordinatorLayout
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <com.google.android.material.appbar.CollapsingToolbarLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:fitsSystemWindows="true"
        app:layout_scrollFlags="scroll|exitUntilCollapsed">

        <androidx.appcompat.widget.Toolbar
            android:id="@+id/PostViewerToolbar"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            app:title="Post View" />

    </androidx.constraintlayout.widget.ConstraintLayout>
</com.google.android.material.appbar.CollapsingToolbarLayout>

<ScrollView
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:nestedScrollingEnabled="true"
    tools:ignore="ScrollViewCount">

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

        <androidx.cardview.widget.CardView
            android:layout_width="match_parent"
            android:layout_height="wrap_content">

            <ImageView
                android:id="@+id/SharedImg"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_gravity="center_horizontal"
                android:layout_marginTop="10dp"
                android:adjustViewBounds="true" />

            <View
                android:layout_width="match_parent"
                android:layout_height="2dp"
                android:layout_marginTop="10dp"
                android:background="#f1f1f1" />

            <TextView
                android:id="@+id/DescriptionTv"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:layout_marginTop="10dp"
                android:text="Post description" />
        </androidx.cardview.widget.CardView>

    </LinearLayout>
</ScrollView>

<androidx.viewpager.widget.ViewPager
    android:id="@+id/Viewpager"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_marginTop="5dp">

    <com.google.android.material.tabs.TabLayout
        android:id="@+id/InvolveTabLayout"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" />
</androidx.viewpager.widget.ViewPager>

0 голосов
/ 29 мая 2020

Вы можете попробовать поместить содержимое CardView и в CollapsingToolbarLayout . Поэтому, когда вы прокручиваете свой CardView, и содержимое сворачивается.

[Обновлено] Я внес некоторые изменения. Просто измените источники, значения и дизайн для представлений в соответствии с вашими требованиями. Похоже на это . Вы можете настроить его как хотите.

Я сделал нечто подобное, используя следующий код.

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout 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">

    <androidx.coordinatorlayout.widget.CoordinatorLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent">

        <com.google.android.material.appbar.AppBarLayout
            android:id="@+id/appBarLayout"
            android:layout_width="match_parent"
            android:layout_height="400dp"
            android:background="@color/dark_grey">

            <com.google.android.material.appbar.CollapsingToolbarLayout
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:fitsSystemWindows="true"
                app:layout_scrollFlags="scroll|exitUntilCollapsed">

                <androidx.appcompat.widget.Toolbar
                    android:layout_width="match_parent"
                    android:layout_height="?attr/actionBarSize"
                    android:popupTheme="@style/Theme.AppCompat.NoActionBar"
                    app:layout_collapseMode="parallax">

                    <ImageView
                        android:layout_width="24dp"
                        android:layout_height="24dp"
                        android:contentDescription="TODO"
                        android:scaleType="centerCrop"
                        android:src="@drawable/ic_arrow_left_vector" />

                    <ImageView
                        android:layout_width="40dp"
                        android:layout_height="40dp"
                        android:layout_gravity="right"
                        android:layout_marginEnd="12dp"
                        android:contentDescription="TODO"
                        android:src="@mipmap/ic_launcher" />
                </androidx.appcompat.widget.Toolbar>

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

                    <androidx.constraintlayout.widget.Guideline
                        android:id="@+id/guideline"
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:orientation="horizontal"
                        app:layout_constraintGuide_begin="56dp" />

                    <androidx.constraintlayout.widget.Guideline
                        android:id="@+id/guideline2"
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:orientation="horizontal"
                        app:layout_constraintGuide_begin="359dp" />

                    <androidx.cardview.widget.CardView
                        android:id="@+id/cv_1"
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        app:layout_constraintBottom_toTopOf="@+id/guideline2"
                        app:layout_constraintEnd_toEndOf="parent"
                        app:layout_constraintStart_toStartOf="parent"
                        app:layout_constraintTop_toTopOf="@+id/guideline">

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

                            <TextView
                                android:layout_width="wrap_content"
                                android:layout_height="wrap_content"
                                android:layout_gravity="center_horizontal"
                                android:text="My CardView"
                                android:textStyle="bold" />

                            <ImageView
                                android:layout_width="wrap_content"
                                android:layout_height="wrap_content"
                                android:layout_gravity="center_horizontal"
                                android:src="@mipmap/ic_launcher" />
                        </LinearLayout>
                    </androidx.cardview.widget.CardView>

                    <LinearLayout
                        android:id="@+id/ll_1"
                        android:layout_width="match_parent"
                        android:layout_height="wrap_content"
                        android:orientation="vertical"
                        app:layout_constraintEnd_toEndOf="parent"
                        app:layout_constraintStart_toStartOf="parent"
                        app:layout_constraintTop_toBottomOf="@+id/cv_1">

                        <TextView
                            android:id="@+id/tv_1"
                            android:layout_width="145dp"
                            android:layout_height="wrap_content"
                            android:layout_gravity="center"
                            android:layout_marginStart="24dp"
                            android:text="content 1"
                            android:textColor="@color/md_red"
                            android:textSize="24sp"
                            android:textStyle="bold" />

                        <TextView
                            android:id="@+id/tv_2"
                            android:layout_width="150dp"
                            android:layout_height="wrap_content"
                            android:layout_gravity="center"
                            android:layout_marginStart="24dp"
                            android:text="Content 2"
                            android:textColor="@color/md_red"
                            android:textSize="24sp"
                            android:textStyle="bold" />
                    </LinearLayout>
                </androidx.constraintlayout.widget.ConstraintLayout>
            </com.google.android.material.appbar.CollapsingToolbarLayout>
        </com.google.android.material.appbar.AppBarLayout>

        <androidx.viewpager.widget.ViewPager
            android:id="@+id/view_pager"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:layout_above="@+id/bottom_navigation_bar"
            android:layout_below="@+id/tab_bar_main"
            app:layout_behavior="@string/appbar_scrolling_view_behavior">

        </androidx.viewpager.widget.ViewPager>
    </androidx.coordinatorlayout.widget.CoordinatorLayout>

    <com.google.android.material.tabs.TabLayout
        android:id="@+id/tab_bar_main"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:layout_centerHorizontal="true"
        android:layout_marginEnd="24dp">

        <com.google.android.material.tabs.TabItem
            android:id="@+id/ti_1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Menu 1" />

        <com.google.android.material.tabs.TabItem
            android:id="@+id/ti_2"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Menu 2" />

        <com.google.android.material.tabs.TabItem
            android:id="@+id/ti_3"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Menu 3" />

        <com.google.android.material.tabs.TabItem
            android:id="@+id/ti_4"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="Menu 4" />
    </com.google.android.material.tabs.TabLayout>


</RelativeLayout>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...