最近我决定用最新的库更新我的旧项目,因为我想学习如何迁移以使用 Jetpack compose。
但不知何故,一旦我将我的约束布局库从 1.1.3 升级到 2.1.2,一些布局就坏了。我试图在互联网上搜索,但我还没有看到有人面临同样的问题。
基本上,只要包含以下属性的布局将在预览中正确显示,但一旦在物理设备上构建,视图就会被破坏:
- layout_constraintBaseline_toBaselineOf
- layout_constraintHorizontal_chainStyle="packed"
- 与 layout_constraintHorizontal_chainStyle 一起使用时,layout_constraintHorizontal_bias 不起作用
关于如何在不消除所有链式样式或偏见的情况下修复这些视图的想法已经不多了。
如果有人可以提供任何帮助,我们将不胜感激。
以下是适用于 1.1.3 而不适用于 2.1.2 的 XML 文件之一的示例。再次正确显示了 Android Studio 上的预览,但构建在物理设备上的应用程序已损坏。
<?xml version="1.0" encoding="utf-8"?>
<androidx.constraintlayout.widget.ConstraintLayout 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">
<TextView
android:id="@+id/text_battery"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="12dp"
android:text="Battery"
app:layout_constraintVertical_chainStyle="packed"
app:layout_constraintHorizontal_bias="0.0"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintBottom_toTopOf="@id/image_battery"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintEnd_toEndOf="parent"/>
<ImageView
android:id="@+id/image_battery"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="10dp"
android:src="@drawable/ic_battery"
app:layout_constraintHorizontal_chainStyle="packed"
app:layout_constraintHorizontal_bias="0.0"
app:layout_constraintTop_toBottomOf="@id/text_battery"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintStart_toStartOf="@id/text_battery"
app:layout_constraintEnd_toStartOf="@id/text_battery_percentage"/>
<TextView
android:id="@+id/text_battery_percentage"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="10dp"
app:layout_constraintTop_toTopOf="@id/image_battery"
app:layout_constraintBottom_toTopOf="@id/text_time"
app:layout_constraintVertical_chainStyle="packed"
app:layout_constraintStart_toEndOf="@id/image_battery"
app:layout_constraintEnd_toEndOf="parent"
tools:text="100%" />
<TextView
android:id="@+id/text_time"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textSize="12sp"
app:layout_constraintTop_toBottomOf="@id/text_battery_percentage"
app:layout_constraintBottom_toBottomOf="@id/image_battery"
app:layout_constraintStart_toStartOf="@id/text_battery_percentage"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintHorizontal_bias="0.0"
tools:text="12:00 am" />
<TextView
android:id="@+id/text_duration"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginEnd="16dp"
android:text="Duration"
app:layout_constraintVertical_chainStyle="packed"
app:layout_constraintHorizontal_bias="1.0"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintBottom_toTopOf="@id/image_clock"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintEnd_toEndOf="parent"/>
<ImageView
android:id="@+id/image_clock"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="10dp"
android:src="@drawable/ic_clock"
app:layout_constraintHorizontal_chainStyle="packed"
app:layout_constraintHorizontal_bias="1.0"
app:layout_constraintTop_toBottomOf="@id/text_duration"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintStart_toStartOf="@id/text_duration"
app:layout_constraintEnd_toStartOf="@id/image_calendar" />
<com.airbnb.lottie.LottieAnimationView
android:id="@+id/lottie_progress"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:scaleType="centerInside"
android:visibility="gone"
app:layout_constraintTop_toTopOf="@id/image_clock"
app:layout_constraintBottom_toBottomOf="@id/image_clock"
app:layout_constraintStart_toStartOf="@id/image_clock"
app:layout_constraintEnd_toEndOf="@id/image_clock" />
<ImageView
android:id="@+id/image_calendar"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/ic_phone"
app:tint="@color/black"
app:layout_constraintHorizontal_bias="1.0"
app:layout_constraintTop_toTopOf="@id/image_clock"
app:layout_constraintBottom_toBottomOf="@id/image_clock"
app:layout_constraintStart_toEndOf="@id/image_clock"
app:layout_constraintEnd_toEndOf="@id/text_duration"/>
</androidx.constraintlayout.widget.ConstraintLayout>