8

我正在使用 Android Listview,并且我希望在 listview 项目的两侧都有一个 1px 的分隔线,这意味着在两种不同颜色的顶部和底部。但问题是我没有登录以在底部显示分隔线。我试过android:layout_below了,但显示无效。

这是列表视图代码

<ListView
        android:id="@+id/myphnview"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_below="@drawable/dividerheight"
        android:background="#E9EAEC"
        android:clickable="true"
        android:divider="@drawable/dividerheight" >
    </ListView>

这是我用于顶部边框的 xml 文件。分割高度.xml

<?xml version="1.0" encoding="utf-8"?>
<layer-list xmlns:android="http://schemas.android.com/apk/res/android" >

    <item>
        <shape android:shape="line" >
            <stroke android:color="#c6c7c9" />

            <size android:height="1px" />
        </shape>
    </item>


</layer-list>

这是我的行的布局

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/rowlayout"
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:background="#E9EAEC"
    android:orientation="horizontal" >

    <LinearLayout
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_weight="2" >

        <ImageView
            android:id="@+id/icon"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_margin="5dp" 
            android:background="@drawable/ic_launcher"/>
    </LinearLayout>

    <LinearLayout
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_marginTop="10dp"
        android:layout_weight="1" >

        <TextView
            android:id="@+id/file_name"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_gravity="left"
            android:layout_margin="5dp"
            android:text="Hello Android "
            android:textColor="@android:color/black"
            android:textSize="20dp" >
        </TextView>
    </LinearLayout>

    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_margin="5dp" >

        <ImageView
            android:id="@+id/share_button"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_gravity="left"
            android:background="@drawable/ic_launcher"/>
    </LinearLayout>



</LinearLayout>
4

3 回答 3

18

有几种方法可以实现这一点。一种简单的方法是在列表中完全隐藏分隔线(将分隔线宽度设置为 0 或将分隔线设置为 null),并让每个列表项在顶部包含一行,在底部包含一行。考虑这个xml:

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

    <View
        android:layout_width="match_parent"
        android:layout_height="1dp"
        android:layout_alignParentTop="true"
        android:background="@android:color/white" />

    <LinearLayout ...>
        <!-- this is your current list item LinearLayout -->
    </LinearLayout>

    <View
        android:layout_width="match_parent"
        android:layout_height="1dp"
        android:layout_alignParentBottom="true"
        android:background="@android:color/black" />

</RelativeLayout>

由于您已经在使用自定义适配器,因此只需在getView适配器的方法中使用上述 XML 进行列表项布局即可。这将生成 60dp 高的列表项,顶部有一条白线,底部有一条黑线。

于 2013-04-23T11:16:25.410 回答
4

您似乎想在列表视图的顶部和底部放置线条(边框)。如果这是你想要的,我会建议下面的代码。

按以下方式在res/values/styles.xml中准备一行。

<style name="Line">
    <item name="android:layout_width">fill_parent</item>
    <item name="android:layout_height">2px</item>
    <item name="android:layout_marginLeft">10dp</item>
    <item name="android:layout_marginRight">10dp</item>
    <item name="android:background">@drawable/line_gradient</item>
</style>

res/drawable/line_gradient.xml:

<shape xmlns:android="http://schemas.android.com/apk/res/android"
    android:shape="rectangle">
<gradient
    android:startColor="@color/white"
    android:endColor="@color/white"
    android:centerColor="@color/blue"
    android:useLevel="false"
    android:type="linear"
    android:angle="0"/>
</shape>

最后以下面的方式在您需要的地方使用该行。

 <View
        style="@style/Line"/>
<ListView
................
................
/>
 <View
        style="@style/Line"/>

这是我在我的应用程序中使用的代码,但您可以根据需要自定义或着色。甚至您可以直接在listview. 但是单独创建一个 instyles.xml会使其在多个地方使用而没有代码冗余。

于 2013-04-23T11:02:35.960 回答
2

我不认为有办法做到这一点。但是您可以footerviewheaderview您的ListView. 我想它会带来你想要的。

例如:

TextView tv1 = new Textview(this);
tv1.setBackgroundResource(R.drawable.dividerheight);

listview.addHeaderView(totalExpense);
listview.addFooterView(totalExpense);

我希望这能帮到您。

于 2013-04-23T11:03:16.810 回答