Saya mencoba menerapkan gelembung obrolan sederhana menggunakan a ConstraintLayout
. Inilah yang saya coba capai:
Namun, wrap_content
sepertinya tidak berfungsi dengan baik dengan kendala. Itu menghormati margin, tetapi tidak menghitung ruang yang tersedia dengan benar. Inilah tata letak saya:
<?xml version="1.0" encoding="utf-8"?>
<android.support.constraint.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="wrap_content">
<TextView
android:id="@+id/chat_message"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:padding="16dp"
app:layout_constraintBottom_toBottomOf="parent"
app:layout_constraintLeft_toLeftOf="parent"
app:layout_constraintRight_toRightOf="parent"
app:layout_constraintTop_toTopOf="parent"
app:layout_constraintHorizontal_bias="0"
tools:background="@drawable/chat_message_bubble"
tools:text="Lorem ipsum dolor sit amet, consectetur adipiscing elit. Mauris sodales accumsan tortor at bibendum."
android:layout_marginStart="64dp"
android:layout_marginLeft="64dp"
android:layout_marginEnd="32dp"
android:layout_marginRight="32dp"
android:layout_marginTop="8dp"
android:layout_marginBottom="8dp" />
</android.support.constraint.ConstraintLayout>
Ini membuat sebagai berikut:
Saya menggunakan com.android.support.constraint:constraint-layout:1.0.0-beta4
.
Apakah saya melakukan sesuatu yang salah? Apakah itu bug atau hanya perilaku yang tidak intuitif? Dapatkah saya mencapai perilaku yang tepat menggunakan a ConstraintLayout
(Saya tahu saya bisa menggunakan tata letak lain, saya bertanya ConstrainLayout
secara spesifik).
tools:background="@drawable/chat_message_bubble"
. Untuk menerapkannya, Anda harus membuat file chat_message_bubble.xml di folder drawable kemudian tambahkan kode ini: <shape xmlns:android="http://schemas.android.com/apk/res/android"> <solid android:color="#FB4382"/> <corners android:radius="10dip"/> </shape>