这种布局在Android中是否可行?

时间:2013-10-08 14:14:02

标签: android android-layout android-linearlayout

这种布局看起来很简单,但我无法在xml中使用LinearLayout或任何其他布局找到任何方法,而无需动态更改属性。这就是我想要的,如果文本很短,那么布局应该完全包装,如图所示:

enter image description here

但是如果TextView包含较长的文字,那么它应该展开,但必须为此Button留出空间:

enter image description here

4 个答案:

答案 0 :(得分:3)

在尝试了大量布局后,我能做的最好就是TableLayoutshrinkColumns

一起使用
<TableLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:shrinkColumns="0" >
    <TableRow>
        <TextView
            android:id="@+id/text"
            android:ellipsize="end"
            android:singleLine="true"
            android:text="This is a very long text and it cannot be displayed wholly" />

        <Button
            android:id="@+id/button"
            android:text="Button" />
    </TableRow>
</TableLayout>

答案 1 :(得分:0)

制作textview wrapcontent的宽度并提供按钮toRightOf文字视图 然后文本视图将根据文本进行扩展,按钮将始终位于文本视图右侧

        <TextView
        android:id="@+id/tV"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:maxWidth="400dp"
        android:text="what ever you want" />

      <Button
        android:id="@+id/btn"
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:layout_toRightOf="@id/tV"
        android:layout_alignParentRight="true"
        android:text="Button" />

答案 2 :(得分:0)

试试这个Wajeeh ........................

 <LinearLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content" >

    <TextView
        android:id="@+id/text1"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:ellipsize="end"
        android:maxLines="1"
        android:maxWidth="200dp"
        android:text="kdfjdk" />

    <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="Button" />
</LinearLayout>

答案 3 :(得分:0)

实现此目标的另一种方法是通过ConstraintLayout发布此问题时不可用。请查看此答案https://stackoverflow.com/a/60163899/826606

<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="wrap_content"
    android:padding="16dp">

    <TextView
        android:id="@+id/title"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:ellipsize="end"
        android:maxLines="1"
        android:text="April Ludgate April April "
        android:textColor="#000"
        android:textSize="16sp"
        android:textStyle="bold"
        app:layout_constraintEnd_toStartOf="@+id/threadType"
        app:layout_constraintHorizontal_bias="0.0"
        app:layout_constraintHorizontal_chainStyle="packed"
        app:layout_constraintStart_toStartOf="parent"
        app:layout_constraintTop_toTopOf="parent"
        app:layout_constraintWidth_default="wrap" />

    <TextView
        android:id="@+id/threadType"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginLeft="4dp"
        android:layout_marginRight="4dp"
        android:text="SMS"
        android:textSize="12sp"
        app:layout_constraintBottom_toBottomOf="@+id/title"
        app:layout_constraintEnd_toEndOf="parent"
        app:layout_constraintStart_toEndOf="@+id/title"
        app:layout_constraintTop_toTopOf="@+id/title"
        app:layout_constraintWidth_default="wrap" />


</androidx.constraintlayout.widget.ConstraintLayout>