MotionLayout с Recyclerview Viewpager - PullRequest
       23

MotionLayout с Recyclerview Viewpager

0 голосов
/ 22 февраля 2020

У меня есть макет как таковой;

<androidx.constraintlayout.motion.widget.MotionLayout 
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/motion_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:animateLayoutChanges="true"
android:orientation="vertical"
app:layoutDescription="@xml/motion_layout_details">

<androidx.appcompat.widget.Toolbar
    android:id="@+id/toolbar"
    android:layout_width="0dp"
    android:layout_height="wrap_content"
    android:background="@color/white"
    app:layout_constraintEnd_toEndOf="parent"
    app:layout_constraintStart_toStartOf="parent"
    app:layout_constraintTop_toTopOf="parent"
    app:navigationIcon="@drawable/ic_back"
    app:title="ToolbarTitle" />

 <androidx.appcompat.widget.AppCompatImageView
    android:id="@+id/image"
    android:layout_width="0dp"
    android:layout_height="244dp"
    android:scaleType="fitXY" />

<com.google.android.material.tabs.TabLayout
    android:id="@+id/tl_menu"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:elevation="2dp"
    app:tabIndicator="@null"
    app:tabMode="scrollable"
    app:tabRippleColor="@null" />

<androidx.viewpager.widget.ViewPager
    android:id="@+id/vp_menu"
    android:layout_width="0dp"
    android:layout_height="0dp" />

</androidx.constraintlayout.motion.widget.MotionLayout>

С идентичными элементами видового пейджера, которые содержат обзор переработчика;

<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:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/white"
android:orientation="vertical"
android:paddingTop="@dimen/spacing_16dp">

<androidx.recyclerview.widget.RecyclerView
    android:id="@+id/recyclerview"
    android:layout_width="0dp"
    android:layout_height="0dp"
    android:clipToPadding="false"
    android:orientation="vertical"
    android:paddingBottom="@dimen/spacing_24dp"
    app:layoutManager="androidx.recyclerview.widget.LinearLayoutManager"
    app:layout_constraintBottom_toBottomOf="parent"
    app:layout_constraintEnd_toEndOf="parent"
    app:layout_constraintStart_toStartOf="parent"
    app:layout_constraintTop_toTopOf="parent"/>


</androidx.constraintlayout.widget.ConstraintLayout>

У меня есть сцена движения, которая сворачивает изображение при прокрутке вверх ( конфигурации для этого правильные). Если в элементах моего окна просмотра я обертываю свой RecyclerView во вложенный scrollview, мой переход -

   <Transition
    app:constraintSetEnd="@+id/end"
    app:constraintSetStart="@+id/start"
    app:duration="500"
    app:motionInterpolator="linear">

    <OnSwipe
        app:dragDirection="dragUp"
        app:touchAnchorId="@+id/vp_menu"
        app:touchAnchorSide="top" />

</Transition>

Работает просто отлично, и переходы, как я и ожидал. Но удаление этого вложенного вида прокрутки больше не вызывает макет движения вообще. Я копался в течение хороших нескольких часов и, кажется, не могу найти никакого объяснения. Я мог бы вернуть nestedscrollview, но в идеале я бы хотел оставить его как A), в котором он не нужен, и B) ломает некоторые вещи, которые я использую. это согласно моему комментарию. .isNestedScrollingEnabled = false останавливает обмен сообщениями с установщиком движения.

1 Ответ

0 голосов
/ 22 февраля 2020

Оказывается, с того момента, когда у меня было мое окно повторного просмотра в виде вложенного прокрутки, у меня было rv?.isNestedScrollingEnabled = false, которое должно было остановить какой-то триггер для замедления движения. Удаление этого исправило проблему и работает с приведенным выше кодом.

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