Android GridView实现设置行列分割线
2017-01-19 14:12:53  By: shinyuu

虽然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>  


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

若资源对你有帮助、浏览后有很大收获、不妨小额打赏我一下、你的鼓励是维持我不断写博客最大动力

想获取DD博客最新代码、你可以扫描下方的二维码、关注DD博客微信公众号(ddblogs)

或者你也可以关注我的新浪微博、了解DD博客的最新动态:DD博客官方微博(dwtedx的微博)

如对资源有任何疑问或觉得仍然有很大的改善空间、可以对该博文进行评论、希望不吝赐教

为保证及时回复、可以使用博客留言板给我留言: DD博客留言板(dwtedx的留言板)

感谢你的访问、祝你生活愉快、工作顺心、欢迎常来逛逛


快速评论


技术评论

  • 该技术还没有评论、赶快抢沙发吧...
DD记账
top
+