如何在Android中为GridView添加单行边框

10

我已经用客户适配器创建了GridView。为了给每个单元格添加边框,我将它们放置在两个布局中。第一个布局具有黑色背景,第二个布局具有白色背景和内容。同时,我还给父布局添加了1dp的padding,看起来像是一个边框。

但问题是当两个单元格竖直相遇时,它们的边框大小变为2dp,即一个单元格的底部边框与另一个单元格的顶部边框合并。

但我想按照给定图像创建边框

border example

这里是我当前单元格xml文件的代码:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/layBorder"
    android:layout_width="77dp"
    android:layout_height="wrap_content"
    android:background="#000000"
    android:orientation="vertical"
    android:padding="1dp" >

    <FrameLayout
        android:id="@+id/FrameLayout1"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:background="#FFFFFF" >

        <ImageView
            android:id="@+id/ivElementName"
            android:layout_width="40dp"
            android:layout_height="60dp"
            android:layout_gravity="center_vertical|center_horizontal"
            android:layout_margin="1dp"
            android:adjustViewBounds="true"
            android:background="#00000000"
            android:maxHeight="60dp"
            android:maxWidth="40dp"
            android:minHeight="60dp"
            android:minWidth="40dp" />

        <ImageView
            android:id="@+id/ivElementImg"
            android:layout_width="30dp"
            android:layout_height="30dp"
            android:layout_gravity="bottom|center_vertical|center_horizontal"
            android:layout_marginLeft="1dp"
            android:layout_marginRight="1dp"
            android:adjustViewBounds="true"
            android:background="#00000000"
            android:baselineAlignBottom="true"
            android:cropToPadding="true"
            android:maxHeight="30dp"
            android:maxWidth="30dp"
            android:minHeight="30dp"
            android:minWidth="30dp"
            android:visibility="invisible" />

    </FrameLayout>

</LinearLayout>

我不确定你想要实现什么,但可以使用Tablelayout完成。 - Sushil
@Sushil,在表格布局中,我会遇到填充单元格的问题,即使在表格布局中,当单元格相遇时,边框也会加倍。 - Adil Bhatty
1个回答

26

你应该执行以下操作:

  • 设置你的GridView的背景色,这将成为边框颜色
  • 按照需要设置你的网格项的背景色
  • 设置垂直和水平间距,这将成为边框厚度

并且不要忘记将你的网格项布局高度更改为match_parent

GridView gv = findViewById(R.id.my_grid_view);
gv.setBackgroundColor(Color.WHITE);
gv.setVerticalSpacing(1);
gv.setHorizontalSpacing(1);

6
当 GridView 控件的列数为2且元素个数为奇数时,此代码将展示一个具有背景颜色的空元素。 - Parth mehta

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接