-1

我想为ListView行构建一个自定义视图。下面是我行的样子带重量的LinearLayout在列表视图中不起作用

Img | Text 1   
    |------------ 
Text | Text 2   

下面是我的布局,我使用生成列视图

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 
android:layout_width="match_parent" 
android:layout_height="wrap_content" > 

<RelativeLayout 
    android:id="@+id/icon_status" 
    android:layout_width="wrap_content" 
    android:layout_height="wrap_content" 
    android:layout_alignParentLeft="true" 
    android:layout_centerVertical="true" 
    android:layout_margin="10dp" 
    android:padding="10dp" > 

    <ImageView 
     android:id="@+id/icon" 
     android:layout_width="wrap_content" 
     android:layout_height="60dp" 
     android:layout_centerHorizontal="true" 
     android:layout_marginBottom="10dp" 
     android:contentDescription="@string/app_name"/> 

    <TextView 
     android:id="@+id/status" 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:layout_below="@id/icon" 
     android:layout_centerHorizontal="true" 
     android:text="STATUS" /> 
</RelativeLayout> 

<View 
    android:id="@+id/ver_divider" 
    android:layout_width="2dp" 
    android:layout_height="fill_parent" 
    android:layout_alignBottom="@id/icon_status" 
    android:layout_alignTop="@id/icon_status" 
    android:layout_toRightOf="@id/icon_status" 
    android:background="@android:color/black" /> 

<View 
    android:id="@+id/hor_divider" 
    android:layout_width="match_parent" 
    android:layout_height="2dp" 
    android:layout_centerVertical="true" 
    android:layout_marginRight="10dp" 
    android:layout_toRightOf="@id/ver_divider" 
    android:background="@android:color/black" /> 

<LinearLayout 
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent" 
    android:layout_alignBottom="@id/icon_status" 
    android:layout_alignTop="@id/icon_status" 
    android:layout_marginLeft="10dp" 
    android:layout_marginRight="10dp" 
    android:layout_toRightOf="@id/ver_divider" 
    android:background="#99FF0000" 
    android:orientation="vertical" > 

    <TextView 
     android:layout_width="wrap_content" 
     android:layout_height="0dp" 
     android:layout_weight="1" 
     android:gravity="center" 
     android:text="Test ME" /> 

    <TextView 
     android:layout_width="wrap_content" 
     android:layout_height="0dp" 
     android:layout_weight="1" 
     android:gravity="center" 
     android:text="Test ME" /> 
</LinearLayout></RelativeLayout> 

列表视图是相当简单的不能定制。

文本1和文本2来自水平分隔符的等距离。虽然我试图在layout_below下面的分隔符下面设置Text2,但它不起作用。在上面的布局中,我尝试创建一个全高的线性图层作为视图,然后使用重量设置两个相同高度的文本视图,这也不起作用。

虽然相同的代码在Android 5.0上正常工作,但它在Android 4.4.4或更低版本上失败。

任何帮助,高度赞赏..不知道我应该怎么做,使之在Android 4.x.x

回答

0

Text 2不会工作设置layout_below工作,因为父是LinearLayout。我早就把hor_dividerLinearLayout里面,像这样:

<LinearLayout 
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent" 
    android:layout_alignBottom="@id/icon_status" 
    android:layout_alignTop="@id/icon_status" 
    android:layout_marginLeft="10dp" 
    android:layout_marginRight="10dp" 
    android:layout_toRightOf="@id/ver_divider" 
    android:background="#99FF0000" 
    android:orientation="vertical" 
    android:gravity="center_vertical"> 

    <TextView 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:gravity="center" 
     android:text="Test ME" /> 

    <View 
     android:id="@+id/hor_divider" 
     android:layout_width="match_parent" 
     android:layout_height="2dp" 
     android:background="@android:color/black" /> 

    <TextView 
     android:layout_width="wrap_content" 
     android:layout_height="wrap_content" 
     android:gravity="center" 
     android:text="Test ME" /> 
</LinearLayout> 

然后你就可以添加一些paddingText 1Text 2创造一些更大的空间。

+0

这将不起作用,因为图标高度会变化,整个解决方案将不会保持动态。 – Manish 2014-12-04 15:14:37

+0

@Manish:您已将其设置为60dp。但也许,只是一个正确的方向的快速建议。无论哪种方式,你也可以在4.x中指定行为,使它更容易帮助你。 – Carnal 2014-12-04 15:20:52

+0

@Manish:首先,我不会以root身份拥有RelativeLayout。我会在你的情况下使其为一个LinearLayout与orientation = horizo​​ntal,有3个孩子 – Carnal 2014-12-04 15:22:03