ConstraintLayout 截断TextView中过长的文字
ConstraintLayout cuts off too long text in TextView
我正在尝试创建主从视图,我有一个 ListView,其中包含以下布局的项目:
<?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/tv_from"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:text="@string/start_point"
app:layout_constraintStart_toStartOf="@+id/tv_date"
app:layout_constraintTop_toBottomOf="@+id/tv_date_val" />
<TextView
android:id="@+id/tv_to_vall"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center"
android:text="@string/end_point"
android:textSize="18sp"
android:baselineAligned="false"
app:layout_constraintBaseline_toBaselineOf="@+id/tv_to"
app:layout_constraintStart_toStartOf="@+id/tv_from_vall" />
<TextView
android:id="@+id/tv_to"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:text="@string/end_point"
app:layout_constraintStart_toStartOf="@+id/tv_from"
app:layout_constraintTop_toBottomOf="@+id/tv_from_vall" />
<TextView
android:id="@+id/tv_from_vall"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="16dp"
android:layout_marginLeft="16dp"
android:gravity="center"
android:text="@string/start_point"
android:textSize="18sp"
app:layout_constraintBottom_toBottomOf="@+id/tv_from"
app:layout_constraintStart_toEndOf="@+id/tv_from"
app:layout_constraintTop_toTopOf="@+id/tv_from" />
<TextView
android:id="@+id/tv_date"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="16dp"
android:layout_marginLeft="16dp"
android:text="@string/date"
app:layout_constraintBaseline_toBaselineOf="@+id/tv_date_val"
app:layout_constraintStart_toStartOf="parent" />
<TextView
android:id="@+id/tv_date_val"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:gravity="center"
android:text="@string/date"
android:textSize="18sp"
app:layout_constraintStart_toStartOf="@+id/tv_from_vall"
app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
产生:
右边列表项最后两行的文字被截掉了。如果文本太长,我想要换行。
我试过了android:lines="4"
、android:singleLine = "false"
有没有办法在不改变整个布局的情况下在 TextView 中修复它?
您可以通过以下方式解决此问题:
- 使用每个
TextView
的匹配约束宽度,即 (0dp
) 而不是
wrap_content
- 将结束约束添加到父项的末尾
app:layout_constraintEnd_toEndOf="parent"
因此您的布局将是:
<?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/tv_from"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:text="@string/start_point"
app:layout_constraintStart_toStartOf="@+id/tv_date"
app:layout_constraintTop_toBottomOf="@+id/tv_date_val" />
<TextView
android:id="@+id/tv_to_vall"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:gravity="center"
android:text="@string/end_point"
android:textSize="18sp"
android:baselineAligned="false"
app:layout_constraintBaseline_toBaselineOf="@+id/tv_to"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="@+id/tv_from_vall" />
<TextView
android:id="@+id/tv_to"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:text="@string/end_point"
app:layout_constraintStart_toStartOf="@+id/tv_from"
app:layout_constraintTop_toBottomOf="@+id/tv_from_vall" />
<TextView
android:id="@+id/tv_from_vall"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginStart="16dp"
android:layout_marginLeft="16dp"
android:gravity="center"
android:text="@string/start_point"
android:textSize="18sp"
app:layout_constraintBottom_toBottomOf="@+id/tv_from"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toEndOf="@+id/tv_from"
app:layout_constraintTop_toTopOf="@+id/tv_from" />
<TextView
android:id="@+id/tv_date"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="16dp"
android:layout_marginLeft="16dp"
android:text="@string/date"
app:layout_constraintBaseline_toBaselineOf="@+id/tv_date_val"
app:layout_constraintStart_toStartOf="parent" />
<TextView
android:id="@+id/tv_date_val"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:gravity="center"
android:text="@string/date"
android:textSize="18sp"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="@+id/tv_from_vall"
app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
you need to change
- 使用
0dp
更改右侧文本视图宽度。您正在使用 wrap_content
,因此会产生此问题。
将从上到下的约束更改为所有正确的文本视图,因为当文本增加时它会在您的约束中重叠。
<?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"
android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:id="@+id/tv_date"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="16dp"
android:layout_marginLeft="16dp"
android:text="date"
app:layout_constraintBaseline_toBaselineOf="@+id/tv_date_val"
app:layout_constraintStart_toStartOf="parent" />
<TextView
android:id="@+id/tv_date_val"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:gravity="start"
android:text="date text date text date text date text date text date text date text date text"
android:textSize="18sp"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="@+id/tv_from_vall"
app:layout_constraintTop_toTopOf="parent" />
<TextView
android:id="@+id/tv_from"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:text="start_point"
app:layout_constraintStart_toStartOf="@+id/tv_date"
app:layout_constraintTop_toTopOf="@+id/tv_from_vall" />
<TextView
android:id="@+id/tv_from_vall"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginStart="16dp"
android:layout_marginLeft="16dp"
android:layout_marginTop="8dp"
android:gravity="start"
android:text="start_point start_point start_point start_point start_point start_point start_point"
android:textSize="18sp"
app:layout_constraintEnd_toEndOf="@+id/tv_date_val"
app:layout_constraintStart_toEndOf="@+id/tv_from"
app:layout_constraintTop_toBottomOf="@+id/tv_date_val" />
<TextView
android:id="@+id/tv_to"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:text="end_point"
app:layout_constraintStart_toStartOf="@+id/tv_from"
app:layout_constraintTop_toBottomOf="@+id/tv_from_vall" />
<TextView
android:id="@+id/tv_to_vall"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:baselineAligned="false"
android:gravity="start"
android:text="end_point end_point end_point end_point end_point end_point end_point"
android:textSize="18sp"
app:layout_constraintBaseline_toBaselineOf="@+id/tv_to"
app:layout_constraintEnd_toEndOf="@+id/tv_date_val"
app:layout_constraintStart_toStartOf="@+id/tv_from_vall" />
</androidx.constraintlayout.widget.ConstraintLayout>
我正在尝试创建主从视图,我有一个 ListView,其中包含以下布局的项目:
<?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/tv_from"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:text="@string/start_point"
app:layout_constraintStart_toStartOf="@+id/tv_date"
app:layout_constraintTop_toBottomOf="@+id/tv_date_val" />
<TextView
android:id="@+id/tv_to_vall"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center"
android:text="@string/end_point"
android:textSize="18sp"
android:baselineAligned="false"
app:layout_constraintBaseline_toBaselineOf="@+id/tv_to"
app:layout_constraintStart_toStartOf="@+id/tv_from_vall" />
<TextView
android:id="@+id/tv_to"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:text="@string/end_point"
app:layout_constraintStart_toStartOf="@+id/tv_from"
app:layout_constraintTop_toBottomOf="@+id/tv_from_vall" />
<TextView
android:id="@+id/tv_from_vall"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="16dp"
android:layout_marginLeft="16dp"
android:gravity="center"
android:text="@string/start_point"
android:textSize="18sp"
app:layout_constraintBottom_toBottomOf="@+id/tv_from"
app:layout_constraintStart_toEndOf="@+id/tv_from"
app:layout_constraintTop_toTopOf="@+id/tv_from" />
<TextView
android:id="@+id/tv_date"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="16dp"
android:layout_marginLeft="16dp"
android:text="@string/date"
app:layout_constraintBaseline_toBaselineOf="@+id/tv_date_val"
app:layout_constraintStart_toStartOf="parent" />
<TextView
android:id="@+id/tv_date_val"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:gravity="center"
android:text="@string/date"
android:textSize="18sp"
app:layout_constraintStart_toStartOf="@+id/tv_from_vall"
app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
产生:
右边列表项最后两行的文字被截掉了。如果文本太长,我想要换行。
我试过了android:lines="4"
、android:singleLine = "false"
有没有办法在不改变整个布局的情况下在 TextView 中修复它?
您可以通过以下方式解决此问题:
- 使用每个
TextView
的匹配约束宽度,即 (0dp
) 而不是wrap_content
- 将结束约束添加到父项的末尾
app:layout_constraintEnd_toEndOf="parent"
因此您的布局将是:
<?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/tv_from"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:text="@string/start_point"
app:layout_constraintStart_toStartOf="@+id/tv_date"
app:layout_constraintTop_toBottomOf="@+id/tv_date_val" />
<TextView
android:id="@+id/tv_to_vall"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:gravity="center"
android:text="@string/end_point"
android:textSize="18sp"
android:baselineAligned="false"
app:layout_constraintBaseline_toBaselineOf="@+id/tv_to"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="@+id/tv_from_vall" />
<TextView
android:id="@+id/tv_to"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:text="@string/end_point"
app:layout_constraintStart_toStartOf="@+id/tv_from"
app:layout_constraintTop_toBottomOf="@+id/tv_from_vall" />
<TextView
android:id="@+id/tv_from_vall"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginStart="16dp"
android:layout_marginLeft="16dp"
android:gravity="center"
android:text="@string/start_point"
android:textSize="18sp"
app:layout_constraintBottom_toBottomOf="@+id/tv_from"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toEndOf="@+id/tv_from"
app:layout_constraintTop_toTopOf="@+id/tv_from" />
<TextView
android:id="@+id/tv_date"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginStart="16dp"
android:layout_marginLeft="16dp"
android:text="@string/date"
app:layout_constraintBaseline_toBaselineOf="@+id/tv_date_val"
app:layout_constraintStart_toStartOf="parent" />
<TextView
android:id="@+id/tv_date_val"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_marginTop="8dp"
android:gravity="center"
android:text="@string/date"
android:textSize="18sp"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="@+id/tv_from_vall"
app:layout_constraintTop_toTopOf="parent" />
</androidx.constraintlayout.widget.ConstraintLayout>
you need to change
- 使用
0dp
更改右侧文本视图宽度。您正在使用wrap_content
,因此会产生此问题。 将从上到下的约束更改为所有正确的文本视图,因为当文本增加时它会在您的约束中重叠。
<?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" android:layout_width="match_parent" android:layout_height="match_parent"> <TextView android:id="@+id/tv_date" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginStart="16dp" android:layout_marginLeft="16dp" android:text="date" app:layout_constraintBaseline_toBaselineOf="@+id/tv_date_val" app:layout_constraintStart_toStartOf="parent" /> <TextView android:id="@+id/tv_date_val" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_marginTop="8dp" android:gravity="start" android:text="date text date text date text date text date text date text date text date text" android:textSize="18sp" app:layout_constraintEnd_toEndOf="parent" app:layout_constraintStart_toStartOf="@+id/tv_from_vall" app:layout_constraintTop_toTopOf="parent" /> <TextView android:id="@+id/tv_from" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginTop="8dp" android:text="start_point" app:layout_constraintStart_toStartOf="@+id/tv_date" app:layout_constraintTop_toTopOf="@+id/tv_from_vall" /> <TextView android:id="@+id/tv_from_vall" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_marginStart="16dp" android:layout_marginLeft="16dp" android:layout_marginTop="8dp" android:gravity="start" android:text="start_point start_point start_point start_point start_point start_point start_point" android:textSize="18sp" app:layout_constraintEnd_toEndOf="@+id/tv_date_val" app:layout_constraintStart_toEndOf="@+id/tv_from" app:layout_constraintTop_toBottomOf="@+id/tv_date_val" /> <TextView android:id="@+id/tv_to" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginTop="8dp" android:text="end_point" app:layout_constraintStart_toStartOf="@+id/tv_from" app:layout_constraintTop_toBottomOf="@+id/tv_from_vall" /> <TextView android:id="@+id/tv_to_vall" android:layout_width="0dp" android:layout_height="wrap_content" android:baselineAligned="false" android:gravity="start" android:text="end_point end_point end_point end_point end_point end_point end_point" android:textSize="18sp" app:layout_constraintBaseline_toBaselineOf="@+id/tv_to" app:layout_constraintEnd_toEndOf="@+id/tv_date_val" app:layout_constraintStart_toStartOf="@+id/tv_from_vall" /> </androidx.constraintlayout.widget.ConstraintLayout>