与match_parent或wrap_content一起使用时,RelativeLayout奇怪地破坏了

时间:2014-02-09 17:14:19

标签: android android-layout android-listview android-ui

我正在尝试在中间分隔两个TextView,一个在左侧,一个在右侧。但是,当RelativeLayout宽度设置为match_parent或wrap_content时,这会以一种奇怪的方式中断。当RelativeLayout设置为手动值(例如200dp)时,它可以正常工作。

请注意,两种布局都在Eclipse中正确预览,它们​​在手机或模拟器上无法正常工作。

这是具有match_parent的RelativeLayout代码:

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

    <LinearLayout
        android:id="@+id/linearLayout1"
        android:layout_width="match_parent"
        android:layout_height="2dp"
        android:layout_alignParentBottom="true"
        android:layout_alignParentLeft="true"
        android:orientation="horizontal" >
    </LinearLayout>

    <LinearLayout
        android:id="@+id/linearLayoutSeparator"
        android:layout_width="1dp"
        android:layout_height="1dp"
        android:layout_centerHorizontal="true"
        android:layout_centerVertical="true"
        android:background="@color/transparent"
        android:orientation="vertical" >
    </LinearLayout>

    <TextView
        android:id="@+id/textViewPrompt"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:layout_alignRight="@+id/linearLayoutSeparator"
        android:ellipsize="end"
        android:maxLines="2"
        android:paddingRight="5dp"
        android:text="Prompt"
        android:textAppearance="?android:attr/textAppearanceSmall"
        android:textColor="@color/default_text"
        android:textSize="16sp" />

    <TextView
        android:id="@+id/textViewAnswer"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignLeft="@+id/linearLayoutSeparator"
        android:layout_alignParentRight="true"
        android:layout_alignParentTop="true"
        android:ellipsize="end"
        android:maxLines="2"
        android:paddingLeft="5dp"
        android:text="Answer"
        android:textAppearance="?android:attr/textAppearanceSmall"
        android:textColor="@color/default_text"
        android:textSize="16sp" />

</RelativeLayout>

结果如下:Broken Layout

以下是具有手动宽度值(在本例中为200dp)的代码,它可以创建正确的结果:

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

    <LinearLayout
        android:id="@+id/linearLayout1"
        android:layout_width="match_parent"
        android:layout_height="2dp"
        android:layout_alignParentBottom="true"
        android:layout_alignParentLeft="true"
        android:orientation="horizontal" >
    </LinearLayout>

    <LinearLayout
        android:id="@+id/linearLayoutSeparator"
        android:layout_width="1dp"
        android:layout_height="1dp"
        android:layout_centerHorizontal="true"
        android:layout_centerVertical="true"
        android:background="@color/transparent"
        android:orientation="vertical" >
    </LinearLayout>

    <TextView
        android:id="@+id/textViewPrompt"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignParentLeft="true"
        android:layout_alignParentTop="true"
        android:layout_alignRight="@+id/linearLayoutSeparator"
        android:ellipsize="end"
        android:maxLines="2"
        android:paddingRight="5dp"
        android:text="Prompt"
        android:textAppearance="?android:attr/textAppearanceSmall"
        android:textColor="@color/default_text"
        android:textSize="16sp" />

    <TextView
        android:id="@+id/textViewAnswer"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_alignLeft="@+id/linearLayoutSeparator"
        android:layout_alignParentRight="true"
        android:layout_alignParentTop="true"
        android:ellipsize="end"
        android:maxLines="2"
        android:paddingLeft="5dp"
        android:text="Answer"
        android:textAppearance="?android:attr/textAppearanceSmall"
        android:textColor="@color/default_text"
        android:textSize="16sp" />

</RelativeLayout>

结果如下:Working Layout

两种布局之间的唯一区别是行:

android:layout_width="200dp"

有谁知道这个问题是什么?在此先感谢您的帮助!

1 个答案:

答案 0 :(得分:1)

// try this way 
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:gravity="center"
    android:padding="5dp"
    android:orientation="vertical" >

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content">
        <TextView
            android:id="@+id/textViewPrompt"
            android:layout_width="0dp"
            android:layout_weight="1"
            android:layout_height="wrap_content"
            android:ellipsize="end"
            android:maxLines="2"
            android:paddingRight="5dp"
            android:gravity="left"
            android:text="Prompt"
            android:textAppearance="?android:attr/textAppearanceSmall"
            android:textSize="16sp" />

        <TextView
            android:id="@+id/textViewAnswer"
            android:layout_width="0dp"
            android:layout_weight="1"
            android:layout_height="wrap_content"
            android:ellipsize="end"
            android:maxLines="2"
            android:paddingLeft="5dp"
            android:text="Answer"
            android:gravity="right"
            android:textAppearance="?android:attr/textAppearanceSmall"
            android:textSize="16sp" />
        </LinearLayout>

    <LinearLayout
        android:id="@+id/linearLayoutSeparator"
        android:layout_width="1dp"
        android:layout_height="1dp"
        android:layout_marginTop="5dp"
        android:orientation="vertical" >
    </LinearLayout>

    <LinearLayout
        android:id="@+id/linearLayout1"
        android:layout_width="match_parent"
        android:layout_height="2dp"
        android:layout_marginTop="5dp"
        android:orientation="horizontal" >
    </LinearLayout>

</LinearLayout>