ConstraintLayout версия: 2.0.0-alpha3
Поэтому я использую MotionLayout, я хотел создать что-то похожее на это.https://blog.stylingandroid.com/motionlayout-collapsing-toolbar-part-2/
Я хочу достичь Когда пользователь входит в активность, ProgressBar
вращается, когда я загружаю данные (занимает некоторое время), я хочу ProgressBar
, чтобы скрыть.
Моя проблемачто, когда я начинаю взаимодействовать с пользовательским интерфейсом, состояние ProgressBar
сбрасывается и снова становится видимым
Что нужно сделать, чтобы не показывать progressBar после того, как пользователь начинает с ним взаимодействовать?
Вотупрощенная версия
layout file
<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/collapsing_toolbar"
tools:context=".MainActivity"
tools:showPaths="true">
<androidx.core.widget.NestedScrollView
android:id="@+id/scroll_view"
android:layout_width="0dp"
android:layout_height="0dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@+id/toolbar_image">
<FrameLayout
android:layout_width="match_parent"
android:layout_height="match_parent">
<View
android:layout_width="match_parent"
android:layout_height="2000dp"
android:background="#ff2"/>
</FrameLayout>
</androidx.core.widget.NestedScrollView>
<ImageView
android:id="@+id/toolbar_image"
android:layout_width="0dp"
android:layout_height="200dp"
android:background="@color/colorPrimary"
android:src="@color/colorAccent"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent"/>
<ProgressBar
android:id="@+id/progress_bar"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
<TextView
android:id="@+id/error"
android:text="ERROR"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
</androidx.constraintlayout.motion.widget.MotionLayout>
Вот описание макета (xml/collapsing_toolbar
)
<MotionScene xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto">
<Transition
app:constraintSetEnd="@id/collapsed"
app:constraintSetStart="@id/expanded">
<OnSwipe
app:dragDirection="dragUp"
app:touchAnchorId="@id/scroll_view"
app:touchAnchorSide="top"/>
</Transition>
<ConstraintSet android:id="@+id/expanded">
<Constraint
android:id="@id/toolbar_image"
android:layout_height="200dp"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent">
</Constraint>
</ConstraintSet>
<ConstraintSet android:id="@+id/collapsed">
<Constraint
android:id="@id/toolbar_image"
android:layout_height="?attr/actionBarSize"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toTopOf="parent">
</Constraint>
</ConstraintSet>
</MotionScene>
и это простое действие, где я скрываю ProgressBar через 1 секунду
class MainActivity : AppCompatActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
Handler().postDelayed({
progress_bar.visibility = View.GONE
error.text="NEW ERROR"
error.visibility = View.GONE
}, 1000)
}
}
Я использую androidx.constraintlayout:constraintlayout:2.0.0-alpha3
РЕДАКТИРОВАТЬ: Я также сообщил об этом как ошибка https://issuetracker.google.com/issues/124812189
РЕДАКТИРОВАТЬ: частичное решение для этого состоит в том, чтобы установить progress_bar и видимость ошибки в GONE << Однако тот же сценарий применяется здесь, так что если вы взаимодействуете с загрузкой, вы можете увидеть <code>scrollView, но этолучше, чем видеть ProgressBar, когда должен быть контент.