ListView中的Android自定义行布局具有灵活的高度

时间:2012-05-11 20:18:26

标签: android android-layout android-listview android-linearlayout android-view

您好我正在尝试创建这样的行: enter image description here

该行应具有灵活的高度,并且字幕文本较长时长高。 左侧的绿色视图也应该增长,以填充行的整个高度。 行高应仅根据文本(标题+字幕)确定。

这是我创建的布局:

<?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:orientation="horizontal" >

        <View
            android:id="@+id/is_in_range_view"
            android:layout_width="15dip"
            android:layout_height="fill_parent"
            android:background="#99CC00" />

        <LinearLayout
            android:layout_width="fill_parent"
            android:layout_height="match_parent"
            android:gravity="center_vertical"
            android:orientation="vertical" >

            <TextView
                android:id="@+id/row_title"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_marginLeft="10dip"
                android:layout_marginTop="5dip"
                android:text="@string/title"
                android:textSize="16sp" />

            <TextView
                android:id="@+id/row_subtitle"
                android:layout_width="wrap_content"
                android:layout_height="wrap_content"
                android:layout_marginBottom="5dip"
                android:layout_marginLeft="10dip"
                android:text="@string/subtitle"
                android:textSize="12sp" />

            <View
                style="@style/SeparatorLine"
                android:layout_width="fill_parent"
                android:layout_height="1dip"
                android:layout_marginTop="5dip" />
        </LinearLayout>
</LinearLayout>

但这是我得到的结果:

enter image description here

显然,View的layout_height属性的fill_parent值存在问题,但这正是我想要的! 我只想要行高将基于文本,而不是绿色视图。

我该怎么做?

1 个答案:

答案 0 :(得分:1)

好的,问题是我在layout_height的内部LinearLayout中放置了错误的值TextView's,其中包含两个fill_parent。 它设置为wrap_content而不是wrap_content

一旦设置为<?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:orientation="horizontal" > <View android:id="@+id/is_in_range_view" android:layout_width="15dip" android:layout_height="fill_parent" android:background="#99CC00" /> <LinearLayout android:layout_width="fill_parent" android:layout_height="wrap_content" android:gravity="center_vertical" android:orientation="vertical" > <TextView android:id="@+id/row_title" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginLeft="10dip" android:layout_marginTop="5dip" android:maxLines="1" android:text="@string/title" android:textSize="16sp" /> <TextView android:id="@+id/row_subtitle" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_marginBottom="5dip" android:layout_marginLeft="10dip" android:maxLines="3" android:text="@string/subtitle" android:textSize="12sp" /> <View style="@style/SeparatorLine" android:layout_width="fill_parent" android:layout_height="1dip" android:layout_marginTop="5dip" /> </LinearLayout> ,everythig就可以了。

正确的布局代码:

{{1}}