7

我正在创建一个对话框,其中两个按钮相对于父 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"没有效果
4

1 回答 1

12

这是我认为您正在尝试完成的两个屏幕截图。

首先,用一些简短的文字:

在此处输入图像描述

现在有一些长文本:

在此处输入图像描述

我对布局采取了一些自由,并在按钮被限制的宽度的 33% 处引入了一个准则。您没有指定按钮可以水平扩展多少,所以我做了这个假设。

此布局的 XML 如下所示。我将按钮的宽度设置为0dpmatch_constraints调整它们的大小。这些按钮也被放置在一个packed链中,将两个按钮组合在一起。水平偏差设置为0.5现在,但如果它开始向您左移动,则增加它会使组向右移动。

ConstraintLayout 文档对这些功能以及如何使用它们有一些很好的描述。

<android.support.constraint.Guideline
    android:id="@+id/guideline"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="vertical"
    app:layout_constraintGuide_percent="0.33" />

<TextView
    android:id="@+id/dialog_title"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_marginTop="@dimen/dialog_text_margin"
    app:layout_constraintStart_toStartOf="parent"
    app:layout_constraintTop_toTopOf="parent"
    tools:text="Dialog title" />

<Button
    android:id="@+id/cancel_btn"
    android:layout_width="0dp"
    android:layout_height="wrap_content"
    app:layout_constraintEnd_toStartOf="@+id/ok_btn"
    app:layout_constraintHorizontal_chainStyle="packed"
    app:layout_constraintStart_toEndOf="@+id/guideline"
    app:layout_constraintTop_toBottomOf="@+id/dialog_title"
    tools:text="Dismiss" />

<Button
    android:id="@+id/ok_btn"
    android:layout_width="0dp"
    android:layout_height="wrap_content"
    android:layout_marginEnd="8dp"
    app:layout_constraintEnd_toEndOf="parent"
    app:layout_constraintHorizontal_bias="0.5"
    app:layout_constraintStart_toEndOf="@+id/cancel_btn"
    app:layout_constraintTop_toTopOf="@+id/cancel_btn"
    tools:text="Accept" />

于 2018-04-11T23:44:42.890 回答