Android MotionLayout和约束组
我将开始使用Android MotionLayout和约束组,android,android-motionlayout,Android,Android Motionlayout,我将开始使用MotionLayout 用MotionLayout替换现有的ConstraintLayout后, 它有一个简单的运动场景, 我注意到,androidx.constraintlayout.widget.Group不再工作了。 最初,我根据情况显示了两组中的一组, 但现在它们都是可见的,即使我将“可见性”设置为“已消失” 我是否可以让MotionLayout与组一起工作,或者我应该使用不同的MotionLayout?ConstraintLayout的最新版本是2.0.0-beta2,并
MotionLayout
用MotionLayout替换现有的
ConstraintLayout
后,
它有一个简单的运动场景,我注意到,
androidx.constraintlayout.widget.Group
不再工作了。最初,我根据情况显示了两组中的一组,
但现在它们都是可见的,即使我将“可见性”设置为“已消失”
我是否可以让MotionLayout与组一起工作,或者我应该使用不同的MotionLayout?ConstraintLayout的最新版本是2.0.0-beta2,并验证MotionScene不关心androidx.ConstraintLayout.motion.widget.Group。因此,如果要更改可见性或高程值,应分别为每个视图处理,而不是应用于虚拟组 MotionLayout的最新稳定版本(2.0.4)允许您通过组更改可见性。不幸的是,它需要对组及其所有引用视图设置
visibilityMode=“ignore”
。下面是一个工作示例:
布局:
运动场景:
主要活动:
class MainActivity:AppCompatActivity(){
重写创建时的乐趣(savedInstanceState:Bundle?){
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
val按钮=findViewById(R.id.button)
button.setOnClickListener{
val组=findViewById(R.id.test_组)
group.isVisible=!group.isVisible
}
}
}
显示您的xml文件。(场景、布局)@DmitroIvanov似乎什么布局都不重要。只需在MotionLayout中创建一个组,并尝试更改该组的visibility@LeoDroidcoder我现在也面临同样的问题。有解决办法吗?
<?xml version="1.0" encoding="utf-8"?>
<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:layout_width="match_parent"
android:layout_height="match_parent"
app:layoutDescription="@xml/motion_scene"
tools:context=".MainActivity">
<androidx.constraintlayout.widget.Group
android:id="@+id/test_group"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:constraint_referenced_ids="text_view"
android:visibility="gone"
/>
<TextView
android:id="@+id/text_view"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Hello World!"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent" />
<View
android:id="@+id/button"
android:layout_width="100dp"
android:layout_height="100dp"
android:background="@android:color/holo_orange_dark"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"/>
</androidx.constraintlayout.motion.widget.MotionLayout>
<?xml version="1.0" encoding="utf-8"?>
<MotionScene
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:lol="http://schemas.android.com/apk/res-auto">
<Transition
lol:constraintSetStart="@id/start"
lol:constraintSetEnd="@id/end"
/>
<ConstraintSet android:id="@+id/start">
<Constraint android:id="@+id/text_view">
<PropertySet lol:visibilityMode="ignore" />
</Constraint>
<Constraint android:id="@+id/test_group">
<PropertySet lol:visibilityMode="ignore" />
</Constraint>
</ConstraintSet>
<ConstraintSet android:id="@+id/end">
<Constraint android:id="@+id/text_view">
<PropertySet lol:visibilityMode="ignore" />
</Constraint>
<Constraint android:id="@+id/test_group">
<PropertySet lol:visibilityMode="ignore" />
</Constraint>
</ConstraintSet>
</MotionScene>
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
val button = findViewById<View>(R.id.button)
button.setOnClickListener {
val group = findViewById<Group>(R.id.test_group)
group.isVisible = !group.isVisible
}
}
}