我有一个带有TransitionListener的MotionLayout,对于我的MotionScene,进度似乎从0变为1:
<MotionScene xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:android="http://schemas.android.com/apk/res/android">
<Transition
app:constraintSetStart="@id/header_expanded"
app:constraintSetEnd="@id/header_condensed"
app:duration="2000">
<OnSwipe
app:touchAnchorId="@id/view_pager"
app:dragDirection="dragDown"
app:touchAnchorSide="top"/>
<KeyFrameSet>
<KeyAttribute
android:elevation="@dimen/header_elevation_expanded"
app:framePosition="0"
app:target="@id/header"/>
<KeyAttribute
android:elevation="@dimen/header_elevation_expanded"
app:framePosition="90"
app:target="@id/header"/>
<KeyAttribute
android:elevation="@dimen/header_elevation_collapsed"
app:framePosition="100"
app:target="@id/header" />
</KeyFrameSet>
</Transition>
<ConstraintSet android:id="@+id/header_expanded">
<Constraint
android:id="@+id/guideline_expanded_state"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal"
app:layout_constraintGuide_percent="0.5" />
</ConstraintSet>
<ConstraintSet android:id="@+id/header_condensed">
<Constraint
android:id="@+id/guideline_expanded_state"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal"
app:layout_constraintGuide_percent="0.18" />
</ConstraintSet>
</MotionScene>
如果在日志中显示进度,它似乎从0跳到1。我试图更改持续时间,或者只是将标题视图的约束更改为其他准则,但似乎并没有影响进度。
我在日志中看到的唯一奇怪的事实是它找不到OnSwipe touchAnchorId视图。
W / MotionLayout:警告找不到视图ID com.pitchero.ph:id/view_pager
使用此MotionScence的布局如下:
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.motion.widget.MotionLayout android:id="@+id/container"
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/activity_background"
app:layoutDescription="@xml/motion_scene_team">
<com.github.florent37.shapeofview.shapes.DiagonalView
android:id="@+id/header"
android:layout_width="match_parent"
android:layout_height="0dp"
android:elevation="@dimen/menu_header_elevation_expanded"
app:layout_constraintBottom_toTopOf="@+id/guideline_expanded_state"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:shape_diagonal_angle="@dimen/header_angle"
app:shape_diagonal_direction="left"
app:shape_diagonal_position="bottom">
<View
android:id="@+id/background"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/redE64"/>
</com.github.florent37.shapeofview.shapes.DiagonalView>
<androidx.appcompat.widget.Toolbar
android:id="@+id/toolbar"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@color/transparent"
app:layout_collapseMode="pin">
<LinearLayout
android:id="@+id/toolbar_title_container"
android:layout_width="wrap_content"
android:layout_height="match_parent"
android:layout_gravity="center"
android:elevation="5dp"
android:gravity="center"
android:orientation="horizontal">
<ImageView
android:id="@+id/toolbar_image"
android:layout_width="30dp"
android:layout_height="30dp"
android:layout_marginEnd="7dp"
android:visibility="gone"/>
<TextView
android:id="@+id/title"
style="@style/title.white"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:ellipsize="end"
android:gravity="center"
android:includeFontPadding="true"
android:maxLines="1"
tools:text="Help Center"/>
</LinearLayout>
</androidx.appcompat.widget.Toolbar>
<com.google.android.material.tabs.TabLayout
android:id="@+id/tabs_bar"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:background="@color/transparent"
android:elevation="2dp"
android:textAlignment="center"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@id/toolbar"
app:tabBackground="@color/transparent"
app:tabIndicatorColor="@color/white"
app:tabSelectedTextColor="@color/white"
app:tabTextColor="@color/white_50_percent"/>
<androidx.viewpager.widget.ViewPager
android:id="@+id/view_pager"
android:layout_width="0dp"
android:layout_height="0dp"
android:layout_marginTop="16dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@id/tabs_bar"/>
<androidx.constraintlayout.widget.Guideline
android:id="@+id/guideline_expanded_state"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="horizontal"
app:layout_constraintGuide_percent="0.5"/>
</androidx.constraintlayout.motion.widget.MotionLayout>
我真的不明白为什么在这种情况下会发生这种情况。我怀疑是因为它找不到ViewPager,但我不明白为什么会发生这种情况。
此外,我正在使用以下版本的ConstraintLayout库:
实现'androidx.constraintlayout:constraintlayout:2.0.0-alpha3'
实现'androidx.constraintlayout:constraintlayout-solver:2.0.0-alpha3'
任何帮助将不胜感激,谢谢!
答案 0 :(得分:1)
您以错误的方式实现了MotionLayout,首先,您不得使用准则来设置动画,而可以将 ViewGroup 容器或 View 用于动画。 / p>
接下来,您必须定义所有引用另一个布局的 ContraintSet 。 例如。
<androidx.viewpager.widget.ViewPager
android:id="@+id/view_pager"
android:layout_width="0dp"
android:layout_height="0dp"
android:layout_marginTop="16dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@id/tabs_bar"/>
此处使用的是 app:layout_constraintTop_toBottomOf =“ @ id / tabs_bar” 作为参考,因此,如果要对该viewpager进行动画处理,则需要添加 ConstraintSet 他们两个,那么只有您可以摆脱该警告。 :)