MotionLayout 的孩子忽略“setVisibility”

Iva*_*gor 10 android android-motionlayout

假设我有带有运动布局的简单 UI:

// 活动_main.xml

<?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"
    android:id="@+id/motion"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    app:layoutDescription="@transition/motion_scene"
    app:showPaths="true">

    <View
        android:id="@+id/view"
        android:layout_width="0dp"
        android:layout_height="250dp"
        android:background="#CCAA33"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        />

    <ProgressBar
        android:id="@+id/progress_bar"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:visibility="visible"
        android:progressTint="#3366CC"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintBottom_toBottomOf="parent"
        />
</androidx.constraintlayout.motion.widget.MotionLayout>
Run Code Online (Sandbox Code Playgroud)

带有运动布局场景:

<?xml version="1.0" encoding="utf-8"?>
<MotionScene
        xmlns:app="http://schemas.android.com/apk/res-auto"
        xmlns:android="http://schemas.android.com/apk/res/android">

    <Transition
            app:constraintSetStart="@id/collapsed"
            app:constraintSetEnd="@id/expanded"
            app:duration="1000">
        <OnSwipe
                app:touchAnchorId="@id/view"
                app:touchAnchorSide="top"
                app:dragDirection="dragUp" />
    </Transition>
    <ConstraintSet android:id="@+id/collapsed">

    </ConstraintSet>

    <ConstraintSet android:id="@+id/expanded">

    </ConstraintSet>
</MotionScene>
Run Code Online (Sandbox Code Playgroud)

图片1

(它没有做任何事情,因为我为了演示目的剥离了所有内容)。

现在,如果我尝试隐藏进度条(让我们说在视图的点击):

//主活动.kt

import android.content.res.ColorStateList
import android.graphics.Color
import android.os.Bundle
import android.view.View
import android.widget.ProgressBar
import androidx.appcompat.app.AppCompatActivity


class MainActivity : AppCompatActivity() {

    override fun onCreate(savedInstanceState: Bundle?) {

        super.onCreate(savedInstanceState)

        setContentView(R.layout.activity_main)

        val view = findViewById<View>(R.id.view)
        val progressBar = findViewById<ProgressBar>(R.id.progress_bar)

        view.setOnClickListener {
            view.setBackgroundColor(Color.parseColor("#006699"))
            progressBar.progressTintList = ColorStateList.valueOf(Color.parseColor("#FF3300"))
            progressBar.visibility = View.GONE
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

(颜色设置仅用于演示目的)。

图片2

出于某种原因,屏幕上仍显示进度条(背景颜色设置正确)。如果我再次单击,进度条会重新开始进度。

对我来说,布局似乎以某种方式无效。

我希望在单击视图后隐藏进度条。运动布局或我的理解有问题吗?如何避免这种效果并隐藏进度条?

谢谢!

kja*_*on2 17

是的!我也为此感到非常沮丧。我能够通过将标签visibilityMode="ignore"放在我想要的视图的约束标签内来解决它(注意:我为开始和结束约束添加了这个标签)。有关更多信息,您可以查看此 SO 帖子。所以在你的内心ConstraintSet你需要有一个Constraint这样的

<Constraint
        android:id="@id/progress_bar"
        motion:visibilityMode="ignore"/>
Run Code Online (Sandbox Code Playgroud)

对于每个视图并设置可见性模式。

希望对你有用!

  • 谢谢!我必须添加: &lt;Constraint android:id="@id/viewId"&gt; &lt;PropertySet app:applyMotionScene="false" app:visibilityMode="ignore" /&gt; &lt;/Constraint&gt; 才能使其正常工作。 (2认同)