我试图做一个非常基本的事情:我有一个带有TextView的ConstraintLayout,我希望TextView根据其内容调整大小。但是,现在TextView溢出并且未完全显示。罪魁祸首是ConstraintLayout的填充。任何想法如何在保持填充的同时修复它? (我在ConstraintLayout中有更多的元素,所以我不想在每个元素上留下边距而不是父元素的填充)
图片(来自Android Studio的布局编辑器,但运行时结果相同):
代码:
<android.support.constraint.ConstraintLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:background="@drawable/msg_in_bg"
android:padding="10dp"
android:maxWidth="240dp">
<TextView
android:id="@+id/txtMessage"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="@color/messageTxt"
android:text="@{item.text}"
tools:text="Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi vel ex nec massa tincidunt dapibus eget quis nulla. Sed tristique justo sed vehicula congue. Nullam varius lacinia sagittis. Sed consectetur sit amet erat fringilla vehicula. Donec dapibus elit eu mauris congue, a dapibus mi laoreet. "
app:layout_constrainedWidth="true"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintBottom_toBottomOf="parent" />
</android.support.constraint.ConstraintLayout>
答案 0 :(得分:0)
将android:maxWidth
属性从父ConstraintLayout
移至TextView
。您还需要调整它以考虑填充(即将其更改为220dp
而不是240dp
,因为您将有20dp的水平填充。)
执行此操作后,无需app:layout_constrainedWidth
属性。
<android.support.constraint.ConstraintLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:padding="10dp"
android:background="@drawable/msg_in_bg">
<TextView
android:id="@+id/txtMessage"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="@color/messageTxt"
android:text="@{item.text}"
android:maxWidth="220dp"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintBottom_toBottomOf="parent"
tools:text="Lorem ipsum dolor sit amet, consectetur adipiscing elit. Morbi vel ex nec massa tincidunt dapibus eget quis nulla. Sed tristique justo sed vehicula congue. Nullam varius lacinia sagittis. Sed consectetur sit amet erat fringilla vehicula. Donec dapibus elit eu mauris congue, a dapibus mi laoreet. "/>
</android.support.constraint.ConstraintLayout>