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

Android GridView实现设置行列分割线

程序员文章站 2021-12-12 11:39:36
...

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


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

1、设置GridView背景色

2、设置水平和竖直方向间隔:android:horizontalSpacing和android: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>  


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