我想知道在GridView中的项目(当前是文本视图)之间绘制分隔符的最简单方法。我能想到的唯一方法是在这些文本视图周围绘制边框,这样当它们结合起来时,它们就像连续的水平和垂直分隔线。
列表视图有一个setDivider()而不是gridviews吗?
感谢。
答案 0 :(得分:35)
如果您只需要简单的线条作为边框,那么更简单的是为GridView
设置背景颜色并使用适当的填充&间距:
<GridView
(...)
android:background="@color/LightGold"
android:listSelector="@android:color/transparent"
android:horizontalSpacing="1dip"
android:verticalSpacing="1dip"
android:paddingLeft="1dip"
android:paddingTop="1dip" />
答案 1 :(得分:28)
不幸的是,在查看源代码后,除了采用向每个单元格添加边框的方法之外,我看不到添加边框的任何简单方法。作为参考,我将在此发布我的解决方案。
<强> list_item.xml 强>
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="horizontal"
android:background="@drawable/list_selector">
<!-- Cell contents -->
</LinearLayout>
<强> list_selector.xml 强>
<?xml version="1.0" encoding="utf-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<item
android:state_selected="true"
android:drawable="@drawable/item_border_selected"
/>
<item
android:state_pressed="true"
android:drawable="@drawable/item_border_selected"
/>
<item
android:drawable="@drawable/item_border"
/>
</selector>
<强> item_border.xml 强>
<?xml version="1.0" encoding="UTF-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<solid
android:color="@android:color/transparent"
/>
<stroke
android:width="1px"
android:color="@color/list_divider"
/>
</shape>
<强> item_border_selected.xml 强>
<?xml version="1.0" encoding="UTF-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android">
<solid
android:color="@color/list_select"
/>
<stroke
android:width="1px"
android:color="@color/list_divider"
/>
</shape>
<强> items_view.xml 强>
<?xml version="1.0" encoding="utf-8"?>
<GridView
xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:layout_marginLeft="-1px"
android:layout_marginRight="-1px"
android:listSelector="@android:color/transparent"
/>
由于所有线条在加入相邻单元格时尺寸加倍,因此我将分割器尺寸设为1px而不是1dp,因此在某些屏幕上看起来不会太大。此外,我使网格视图具有负边距以隐藏任一侧的线条。我希望这可以帮助别人。