欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

Android中控件GridView实现设置行列分割线的方法示例

程序员文章站 2024-02-16 19:33:28
前言 虽然aandroid目前已经有recyclerview了、非常强大的一个view、可以直接控制成listview以及gridview等、而且画框线也比较方便、但是呢...

前言

虽然aandroid目前已经有recyclerview了、非常强大的一个view、可以直接控制成listview以及gridview等、而且画框线也比较方便、但是呢在很多情况下我们不得不仍然使用gridview来实现布局、那么在这个时候我们又要怎么来对gridviw进行画框线呢、下面将提供两种实现方式、大家可以选择一下

一、设置垂直、横向间距、通过gridview和item的背景色来实现

     1、设置gridview背景色

     2、设置水平和竖直方向间隔:android:horizontalspacingandroid:verticalspacing

      3、设置gridview的item的背景色及其选中后的颜色

xml代码如下

<gridview 
 android:id="@ id/gridview2" 
 android:layout_width="match_parent" 
 android:layout_height="wrap_content" 
 android:layout_below="@ id/textview1" 
 android:layout_margintop="30dp" 
 android:background="#999999" 
 android:horizontalspacing="0.5dp" 
 android:verticalspacing="0.5dp" 
 android:padding="2dp" 
 android:numcolumns="3" > 

item布局

<?xml version="1.0" encoding="utf-8"?> 
<linearlayout xmlns:android="http://schemas.android.com/apk/res/android" 
 android:layout_width="match_parent" 
 android:layout_height="match_parent" 
 android:orientation="vertical" 
 android:gravity="center" 
 android:background="@android:color/whith"> 
 
 <textview 
  android:id="@ id/textview1" 
  android:layout_width="wrap_content" 
  android:layout_height="wrap_content" 
  android:textsize="20sp" 
  android:padding="10dp" 
  android:text="textview" /> 
 
</linearlayout> 

二、设置选择器

这种方式就是设置item的选择器的android:background属性来实现的

gv_selector代码

<?xml version="1.0" encoding="utf-8"?> 
<selector xmlns:android="http://schemas.android.com/apk/res/android"> 
 <item 
  android:state_selected="true" > 
  <shape android:shape="rectangle"> 
    <solid 
    android:color="#cccccc" 
    /> 
    <stroke android:width="1.0px" android:color="#999999" /> 
  </shape> 
 </item> 
 <item 
  android:state_pressed="true" > 
  <shape android:shape="rectangle"> 
    <solid 
    android:color="#cccccc" 
    /> 
    <stroke android:width="1.0px" android:color="#999999" /> 
  </shape> 
 </item> 
 <item> 
  <shape android:shape="rectangle"> 
   <stroke android:width="1.0px" android:color="#999999" /> 
  </shape> 
 </item> 
</selector> 

至此两种方法已经写完了、有细心的朋友可能会发现第二种方法的中间的网格线比边线要粗两倍、这也是第二种方法的一个不足的地方

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。