我正在创建一个对话框,其中两个按钮相对于父 ConstraintLayout 对齐。
一切都很好,直到按钮的文本变得很长。当一个或两个按钮的文本很长时,按钮会超出父级的边界,导致文本被剪切,如下图所示。我想处理文本较长的情况。
即期望的行为是
- 当文本很长时,按钮应该换行
- 按钮应保持在父级范围内并遵守父级填充
- 按钮应与父级保持对齐
当按钮文本很短时,布局按预期工作:
当按钮文本很长时:
布局代码
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.ConstraintLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:paddingBottom="@dimen/dialog_padding"
android:paddingLeft="@dimen/dialog_padding"
android:paddingRight="@dimen/dialog_padding"
android:paddingTop="@dimen/dialog_padding">
<TextView
android:id="@+id/dialog_title"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="@dimen/dialog_text_margin"
tools:text="Dialog title" />
<TextView
android:id="@+id/dialog_content"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginTop="@dimen/dialog_text_margin"
app:layout_constraintTop_toBottomOf="@id/dialog_title"
tools:text="Dialog text content" />
<Button
android:id="@+id/cancel_btn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:layout_constraintEnd_toStartOf="@id/ok_btn"
app:layout_constraintTop_toBottomOf="@id/dialog_content"
tools:text="Dismiss" />
<Button
android:id="@+id/ok_btn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintTop_toBottomOf="@id/dialog_content"
tools:text="Accept" />
</android.support.constraint.ConstraintLayout>
我尝试无济于事的事情:
- 添加
app:layout_constraintStart_toStartOf="parent"
到取消按钮会导致按钮不再正确对齐,因此解决方案不正确 - 将关闭按钮的结尾约束到接受按钮的开头会导致按钮不再右对齐
- 使用
layout_width="0dp"
按钮和使用app:layout_constrainedWidth="true"
没有效果