如何在 android 列表视图中对齐文本视图?

How to align text view in android list view?

我的列表视图看起来像那样,而且非常糟糕,因为如果姓名长于姓氏,文本视图会超过我的日期和前缀 A,这意味着到达,但如果姓氏长于姓名,则一切正常。 但是我在这里问也许有人知道如何对齐它们以使文本视图不会相互重叠? 这是我的 xml 单行项目:

    <?xml version="1.0" encoding="utf-8"?>
 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
          android:layout_width="fill_parent"
          android:layout_height="fill_parent"
          android:orientation="vertical">

<TextView android:id="@+id/name"
          android:layout_width="wrap_content"
          android:layout_height="wrap_content"
          android:text="Sample Data"
          android:textSize="15sp"
          android:paddingBottom="5dp" />

<TextView android:id="@+id/surName"
          android:layout_width="wrap_content"
          android:layout_height="wrap_content"
          android:text="Sample Data 2"
          android:textSize="15sp"
          android:layout_below="@id/name"
          android:paddingBottom="5dp" />

  <TextView
      android:id="@+id/textA"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_toRightOf="@+id/surName"
      android:paddingBottom="5dp"
      android:paddingLeft="10dp"
      android:paddingRight="5dp"
      android:text="A:"
      android:textSize="15sp" />

<TextView
    android:id="@+id/date"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:paddingBottom="5dp"
    android:paddingLeft="5dp"
    android:paddingRight="5dp"
    android:layout_toRightOf="@id/textA"
    android:text="Sample Data 3"
    android:textSize="15sp" />
 <TextView
      android:id="@+id/time"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_alignBaseline="@+id/surName"
      android:layout_alignBottom="@+id/surName"
      android:layout_alignLeft="@id/date"
      android:paddingBottom="5dp"
      android:paddingLeft="5dp"
      android:paddingRight="5dp"
      android:text="Sample Data 4"
      android:textSize="15sp" />
<TextView
      android:id="@+id/textD"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_toRightOf="@id/date"
      android:paddingBottom="5dp"
      android:paddingLeft="5dp"
      android:paddingRight="5dp"
      android:text="D:"
      android:textSize="15sp" />
 <TextView
    android:id="@+id/date2"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:paddingBottom="5dp"
    android:paddingLeft="5dp"
    android:paddingRight="5dp"
    android:layout_toRightOf="@id/textD"
    android:text="Sample Data 3"
    android:textSize="15sp" />
 <TextView
      android:id="@+id/time2"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_below="@id/date2"
      android:layout_alignBottom="@id/time"
      android:layout_alignLeft="@id/date2"
      android:paddingBottom="5dp"
      android:paddingLeft="5dp"
      android:paddingRight="5dp"
      android:text="Sample Data 4"
      android:textSize="15sp" />



  </RelativeLayout>

您正在使用相对布局,因此请添加:

android:layout_toLeftOf
android:layout_toRightOf

在您的文本视图中,这样它们就不会相互重叠

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
          android:layout_width="fill_parent"
          android:layout_height="fill_parent"
          android:orientation="vertical">
<LinearLayout 
 android:id="@+id/namesur"
 android:layout_width="wrap_content"
 android:layout_height="wrap_content"
 android:orientation="vertical"
 >
<TextView android:id="@+id/name"
          android:layout_width="wrap_content"
          android:layout_height="wrap_content"
          android:text="Sample Data"
            android:layout_weight="1"
          android:textSize="15sp"
          android:paddingBottom="5dp" />

<TextView android:id="@+id/surName"
          android:layout_width="wrap_content"
          android:layout_height="wrap_content"
          android:text="Sample Data 2"
          android:layout_weight="1"
          android:textSize="15sp"
          android:layout_below="@id/name"
          android:paddingBottom="5dp" />
</LinearLayout>
  <TextView
      android:id="@+id/textA"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_toRightOf="@id/namesur"
      android:paddingBottom="5dp"
      android:paddingLeft="10dp"
      android:paddingRight="5dp"
      android:text="A:"
      android:textSize="15sp" />

<TextView
    android:id="@+id/date"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:paddingBottom="5dp"
    android:paddingLeft="5dp"
    android:paddingRight="5dp"
    android:layout_toRightOf="@id/textA"
    android:text="Sample Data 3"
    android:textSize="15sp" />
 <TextView
      android:id="@+id/time"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_alignBaseline="@id/namesur"
      android:layout_alignBottom="@id/namesur"
      android:layout_alignLeft="@id/date"
      android:paddingBottom="5dp"
      android:paddingLeft="5dp"
      android:paddingRight="5dp"
      android:text="Sample Data 4"
      android:textSize="15sp" />
<TextView
      android:id="@+id/textD"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_toRightOf="@id/date"
      android:paddingBottom="5dp"
      android:paddingLeft="5dp"
      android:paddingRight="5dp"
      android:text="D:"
      android:textSize="15sp" />
 <TextView
    android:id="@+id/date2"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:paddingBottom="5dp"
    android:paddingLeft="5dp"
    android:paddingRight="5dp"
    android:layout_toRightOf="@id/textD"
    android:text="Sample Data 3"
    android:textSize="15sp" />
 <TextView
      android:id="@+id/time2"
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:layout_below="@id/date2"
      android:layout_alignBottom="@id/time"
      android:layout_alignLeft="@id/date2"
      android:paddingBottom="5dp"
      android:paddingLeft="5dp"
      android:paddingRight="5dp"
      android:text="Sample Data 4"
      android:textSize="15sp" />

这非常适合我::

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:padding="5dp"
    android:orientation="horizontal">

    <TableLayout
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:shrinkColumns="*"
        android:stretchColumns="*"
        android:weightSum="2">

        <TableRow android:weightSum="15"
            android:paddingBottom="5dp">

            <TextView
                android:id="@+id/name"
                android:ellipsize="marquee"
                android:maxWidth="120dp"
                android:singleLine="true"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_weight="5"
                android:text="Sample Data"
                android:textSize="15sp" />

            <TextView
                android:id="@+id/textA"
                android:ellipsize="marquee"
                android:singleLine="true"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_weight="2"
                android:text="A:"
                android:textSize="15sp" />

            <TextView
                android:id="@+id/date"
                android:ellipsize="marquee"
                android:maxWidth="90dp"
                android:singleLine="true"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_weight="3"
                android:text="Sample Data 3"
                android:textSize="15sp" />

            <TextView
                android:id="@+id/textD"
                android:ellipsize="marquee"
                android:singleLine="true"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_weight="2"
                android:text="D:"
                android:textSize="15sp" />

            <TextView
                android:id="@+id/date2"
                android:ellipsize="marquee"
                android:maxWidth="90dp"
                android:singleLine="true"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_weight="3"
                android:text="Sample Data 3"
                android:textSize="15sp" />
        </TableRow>

        <TableRow android:weightSum="15"
            android:paddingBottom="5dp">

            <TextView
                android:id="@+id/surName"
                android:ellipsize="marquee"
                android:maxWidth="120dp"
                android:singleLine="true"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_weight="5"
                android:text="Sample Data 2"
                android:textSize="15sp" />

            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_weight="2"
                android:ellipsize="marquee"
                android:singleLine="true"
                android:text="  "
                android:textSize="15sp" />

            <TextView
                android:id="@+id/time"
                android:ellipsize="marquee"
                android:maxWidth="90dp"
                android:singleLine="true"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_weight="3"
                android:text="Sample Data 4"
                android:textSize="15sp" />

            <TextView
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_weight="2"
                android:ellipsize="marquee"
                android:singleLine="true"
                android:text="  "
                android:textSize="15sp" />

            <TextView
                android:id="@+id/time2"
                android:ellipsize="marquee"
                android:maxWidth="90dp"
                android:singleLine="true"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_weight="3"
                android:text="Sample Data 4"
                android:textSize="15sp" />
        </TableRow>

    </TableLayout>

</LinearLayout>

我创建了一个包含两行的 table,并使用 weightSum 来调整文本视图的比例。设置 ellipsize="marquee"maxWidth 可确保文本不会与行中的下一项重叠。