Pei*_*ein 2 android android-motionlayout
所以,我有简单的场景:
<Transition
motion:constraintSetStart="@id/motion_01_cl_start"
motion:constraintSetEnd="@id/motion_01_cl_end"
motion:duration="300">
<OnSwipe
motion:touchRegionId="@id/imageView"
motion:dragDirection="dragUp"/>
</Transition>
<ConstraintSet android:id="@+id/motion_01_cl_start">
<Constraint
android:id="@+id/testView"
android:layout_width="200dp"
android:layout_height="250dp"
motion:layout_constraintBottom_toBottomOf="parent"
motion:layout_constraintStart_toStartOf="parent"
motion:layout_constraintTop_toTopOf="parent"
motion:layout_constraintEnd_toEndOf="parent"
android:layout_marginTop="0dp"
android:elevation="3dp"/>
<Constraint
android:id="@+id/imageView"
android:layout_width="200dp"
android:layout_height="250dp"
motion:layout_constraintBottom_toBottomOf="parent"
motion:layout_constraintStart_toStartOf="parent"
motion:layout_constraintTop_toTopOf="parent"
motion:layout_constraintEnd_toEndOf="parent"
android:layout_marginTop="0dp"
android:elevation="4dp"/>
</ConstraintSet>
<ConstraintSet android:id="@+id/motion_01_cl_end">
<Constraint
android:id="@+id/testView"
android:layout_width="300dp"
android:layout_height="300dp"
android:elevation="10dp"
android:layout_marginTop="100dp"
motion:layout_constraintStart_toStartOf="parent"
motion:layout_constraintTop_toTopOf="parent"
motion:layout_constraintEnd_toEndOf="parent"
/>
<Constraint
android:id="@+id/imageView"
android:layout_width="200dp"
android:layout_height="290dp"
android:elevation="25dp"
android:layout_marginTop="40dp"
motion:layout_constraintStart_toStartOf="parent"
motion:layout_constraintTop_toTopOf="parent"
motion:layout_constraintEnd_toEndOf="parent"
/>
</ConstraintSet>
Run Code Online (Sandbox Code Playgroud)
如您所见,在 Transition 中,我使用 dragDirection "dragUp" 进行了滑动处理。但问题是它作为dragDown 起作用,不明白为什么。我试图将dragDirection 设置为dragDown,但它按预期工作。方向处理有问题吗?
这是我的布局:
<androidx.constraintlayout.motion.widget.MotionLayout
android:layout_width="match_parent"
app:layoutDescription="@xml/scene"
android:layout_height="match_parent"
android:id="@+id/motionLayout">
<androidx.cardview.widget.CardView
android:id='@+id/testView'
android:layout_height="400dp"
android:layout_width="300dp"/>
<ImageView
android:layout_width="300dp"
android:layout_height="400dp"
android:id="@+id/imageView"
android:src="@drawable/img"
android:scaleType="centerInside"/>
</androidx.constraintlayout.motion.widget.MotionLayout>
Run Code Online (Sandbox Code Playgroud)
你现在为什么会出现这个问题?
为什么 onSwipe 不处理正确的拖动事件?
拖动方向由MotionLayout
渲染引擎本身根据touchAnchorId
.
要解决此问题,请添加一个虚拟视图作为 ,touchAnchorId
并在所需方向上为该视图添加滑动动画。由于我们不需要让这个虚拟视图在 UI 上可见,我们可以使用android SDK 提供的“空间”视图作为虚拟视图。
<Space
android:id="@+id/space"
android:layout_width="1dp"
android:layout_height="1dp"
motion:layout_constraintEnd_toEndOf="parent"
motion:layout_constraintTop_toTopOf="parent" />
Run Code Online (Sandbox Code Playgroud)
将 ConstraintLayout 依赖项添加到您的 build.gradle 文件中
dependencies {
implementation 'androidx.constraintlayout:constraintlayout:2.0.0-beta2'
}
Run Code Online (Sandbox Code Playgroud)
因此,您的布局和运动资源文件将如下所示
活动_main.xml
<androidx.constraintlayout.motion.widget.MotionLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:motion="http://schemas.android.com/apk/res-auto"
android:id="@+id/motionLayout"
android:layout_width="match_parent"
android:layout_height="match_parent"
motion:layoutDescription="@xml/motionscene">
<androidx.cardview.widget.CardView
android:id='@+id/testView'
android:layout_height="400dp"
android:layout_width="300dp"/>
<ImageView
android:layout_width="300dp"
android:layout_height="400dp"
android:id="@+id/imageView"
android:src="@drawable/abd"
android:scaleType="centerInside"/>
<Space
android:id="@+id/space"
android:layout_width="1dp"
android:layout_height="1dp"
motion:layout_constraintEnd_toEndOf="parent"
motion:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.motion.widget.MotionLayout>
Run Code Online (Sandbox Code Playgroud)
运动场景.xml
<MotionScene xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:motion="http://schemas.android.com/apk/res-auto">
<Transition
motion:constraintSetStart="@id/motion_01_cl_start"
motion:constraintSetEnd="@id/motion_01_cl_end"
motion:duration="300">
<OnSwipe
motion:touchAnchorId="@id/space"
motion:dragDirection="dragUp"/>
</Transition>
<ConstraintSet android:id="@+id/motion_01_cl_start">
<Constraint
android:id="@+id/testView"
android:layout_width="200dp"
android:layout_height="250dp"
motion:layout_constraintBottom_toBottomOf="parent"
motion:layout_constraintStart_toStartOf="parent"
motion:layout_constraintTop_toTopOf="parent"
motion:layout_constraintEnd_toEndOf="parent"
android:layout_marginTop="0dp"
android:elevation="3dp"/>
<Constraint
android:id="@+id/imageView"
android:layout_width="200dp"
android:layout_height="250dp"
motion:layout_constraintBottom_toBottomOf="parent"
motion:layout_constraintStart_toStartOf="parent"
motion:layout_constraintTop_toTopOf="parent"
motion:layout_constraintEnd_toEndOf="parent"
android:layout_marginTop="0dp"
android:elevation="4dp"/>
<Constraint
android:id="@+id/space"
motion:layout_constraintBottom_toBottomOf="parent"
motion:layout_constraintStart_toStartOf="parent"
/>
</ConstraintSet>
<ConstraintSet android:id="@+id/motion_01_cl_end">
<Constraint
android:id="@+id/testView"
android:layout_width="300dp"
android:layout_height="300dp"
android:elevation="10dp"
android:layout_marginTop="100dp"
motion:layout_constraintStart_toStartOf="parent"
motion:layout_constraintTop_toTopOf="parent"
motion:layout_constraintEnd_toEndOf="parent"
/>
<Constraint
android:id="@+id/imageView"
android:layout_width="200dp"
android:layout_height="290dp"
android:elevation="25dp"
android:layout_marginTop="40dp"
motion:layout_constraintStart_toStartOf="parent"
motion:layout_constraintTop_toTopOf="parent"
motion:layout_constraintEnd_toEndOf="parent"
/>
<Constraint
android:id="@+id/space"
motion:layout_constraintTop_toTopOf="parent"
motion:layout_constraintStart_toStartOf="parent"
/>
</ConstraintSet>
</MotionScene>
Run Code Online (Sandbox Code Playgroud)
输出看起来像下面的gif
归档时间: |
|
查看次数: |
3985 次 |
最近记录: |