如何设置GridView的边框。
类似于ListView的Divider和DividerHeight。
或者如何显示边框。
以下是在GridView中使用边框的一些示例。
您可以看到我在XML中定义了红色和蓝色的边框。
这是我的main.xml布局:
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/root"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@color/red" >
<GridView
android:id="@+id/gridview"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:layout_margin="10dp"
android:background="@color/blue"
android:columnWidth="90dp"
android:gravity="center"
android:horizontalSpacing="10dp"
android:numColumns="auto_fit"
android:stretchMode="columnWidth"
android:verticalSpacing="10dp"
/>
</RelativeLayout>
GridView中红色边框的厚度由layout_margin
属性控制,而蓝色边框则由horizontalSpacing
和verticalSpacing
控制。
为了制作黑色单元格背景,我使用了这个布局,并将其保存为list_item.xml:
<TextView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/text1"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@android:color/black"
android:gravity="center_vertical"
android:minHeight="?android:attr/listPreferredItemHeight"
android:paddingLeft="6dip"
android:textAppearance="?android:attr/textAppearanceLarge" />
我的活动:
public class Example extends Activity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
String[] array = new String[] {"one", "two", "three", "four", "five", "six", "seven", "eight", "nine", "ten"};
List<String> list = new ArrayList<String>(Arrays.asList(array));
GridView grid = (GridView) findViewById(R.id.gridview);
grid.setAdapter(new ArrayAdapter<String>(this, R.layout.list_item, list));
}
}
layout_margin
更改为layout_padding
即可。 - Samandroid:padding
基本上可以得到与 android:layout_margin
相同的结果。 - mduplsandroid:clipToPadding="false"
添加到GridView中,它将在其周围添加填充,但当视图滚动时不会保留。 - Cameron Ketcham在网格项 XML 文件中使用以下 XML 文件作为背景。
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<solid android:color="@android:color/transparent" />
<corners
android:bottomRightRadius="12dp"
android:bottomLeftRadius="12dp"
android:topLeftRadius="12dp"
android:topRightRadius="12dp" />
<stroke
android:color="@android:color/white"
android:width="1dp" />
</shape>
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<solid android:color="@android:color/transparent" />
<corners
android:bottomRightRadius="5dp"
android:bottomLeftRadius="5dp"
android:topLeftRadius="5dp"
android:topRightRadius="5dp" />
<stroke
android:color="@color/material_grey_600"
android:width="1dp" />
</shape>
android:background="@drawable/grid_row_border"
提供填充[android:padding="5dp"]和外边距[android:layout_margin="5dp"],以使界面更美观。
我在图片行的xml中添加了这些视图:
<View
android:layout_width="@dimen/listGalleryItemWidthLarge"
android:layout_height="2dip"
android:layout_above="@+id/gallery_row_iv"
android:layout_centerHorizontal="true"
android:background="#FFFFFF" />
<View
android:layout_width="@dimen/listGalleryItemWidthLarge"
android:layout_height="2dip"
android:layout_below="@+id/gallery_row_iv"
android:layout_centerHorizontal="true"
android:background="#FFFFFF" />
<View
android:layout_width="2dip"
android:layout_height="@dimen/listGalleryItemHeightLarge"
android:layout_centerVertical="true"
android:layout_toRightOf="@+id/gallery_row_iv"
android:background="#FFFFFF" />
<View
android:layout_width="2dip"
android:layout_height="@dimen/listGalleryItemHeightLarge"
android:layout_centerVertical="true"
android:layout_toLeftOf="@+id/gallery_row_iv"
android:background="#FFFFFF" />